在bash shell中,环境变量分为:

>全局变量

>局部变量

全局变量,不仅对shell可见,对其子进程也可见

查看预设的全局环境变量:

ghostwu@dev:~$ printenv
ghostwu@dev:~$ env

这两个命令都可以打印全局环境变量

ghostwu@dev:~$ printenv | grep HOME
HOME=/home/ghostwu
ghostwu@dev:~$

HOME是一个全局环境变量,保存用户的家目录

ghostwu@dev:~$ echo $HOME
/home/ghostwu

上面说了,全局环境变量对子shell也有用,我们就开启一个子进程,来验证一下:

ghostwu@dev:~$ bash
ghostwu@dev:~$ ps -f
UID PID PPID C STIME TTY TIME CMD
ghostwu : pts/ :: bash
ghostwu : pts/ :: bash
ghostwu : pts/ :: ps -f
ghostwu@dev:~$ echo $HOME
/home/ghostwu
ghostwu@dev:~$ exit
exit
ghostwu@dev:~$ echo $HOME
/home/ghostwu

由此可见,在当前的shell 以及子shell中 都能访问到全局环境变量

局部环境变量:只能在定义他们他们的进程中可见

设置局部变量,跟php的语法差不多,只不过不需要美元符号,读取局部变量需要用$符号

ghostwu@dev:~$ echo $my_var

读取一个没有定义的局部环境变量,值为空

ghostwu@dev:~$ echo $my_var

ghostwu@dev:~$ my_var=ghostwu
ghostwu@dev:~$ echo $my_var
ghostwu

定义局部变量的=号左右不要用空格,否则会被当做命令执行

ghostwu@dev:~$ myvar = 'hello'
myvar: command not found

在子shell中,是不能访问到父shell(进程)定义的局部变量.

ghostwu@dev:~$ echo $my_var
ghostwu
ghostwu@dev:~$ ps -f
UID PID PPID C STIME TTY TIME CMD
ghostwu : pts/ :: bash
ghostwu : pts/ :: ps -f
ghostwu@dev:~$ bash
ghostwu@dev:~$ echo $my_var ghostwu@dev:~$ exit
exit
ghostwu@dev:~$ echo $my_var
ghostwu

如果需要在子shell中访问到父shell中定义的局部变量,我们可以把局部变量导入到全局变量中,怎么导入?用export 变量名称 即可,导入的时候,变量名称前面

不要用$符号

ghostwu@dev:~$ printenv | grep my_var
ghostwu@dev:~$ export my_var
ghostwu@dev:~$ !p
printenv | grep my_var
my_var=ghostwu
ghostwu@dev:~$ echo $my_var
ghostwu
ghostwu@dev:~$ bash
ghostwu@dev:~$ ps -f
UID PID PPID C STIME TTY TIME CMD
ghostwu : pts/ :: bash
ghostwu : pts/ :: bash
ghostwu : pts/ :: ps -f
ghostwu@dev:~$ echo $my_var
ghostwu
ghostwu@dev:~$ exit
exit
ghostwu@dev:~$ echo $my_var
ghostwu
ghostwu@dev:~$ printenv | grep my_var
my_var=ghostwu

删除环境变量,用unset。

>在父shell中,删除一个导入到全局变量的 环境变量,之后就访问不到这个变量了

ghostwu@dev:~$ printenv | grep my_var
my_var=ghostwu
ghostwu@dev:~$ echo $my_var
ghostwu
ghostwu@dev:~$ unset my_var
ghostwu@dev:~$ echo $my_var ghostwu@dev:~$ bash
ghostwu@dev:~$ echo $my_var ghostwu@dev:~$ exit
exit

>如果在子shell中,导入一个全局变量,然后删除,那么子shell中访问不到,但是在父shell中,还可以访问到

ghostwu@dev:~$ echo $my_var

ghostwu@dev:~$ my_var="ghostwu"
ghostwu@dev:~$ export my_var
ghostwu@dev:~$ printenv | grep my_var
my_var=ghostwu
ghostwu@dev:~$ bash
ghostwu@dev:~$ echo $my_var
ghostwu
ghostwu@dev:~$ unset my_var
ghostwu@dev:~$ echo $my_var ghostwu@dev:~$ exit
exit
ghostwu@dev:~$ echo $my_var
ghostwu

PATH环境变量,定义了一堆路径,这些路径的作用是,当命令行输入一个命令的时候,在去PATH变量中定义的路径中去寻找。所以,如果想让一个自定义的可执行

程序能够在任意目录下执行,就需要把这个可执行的程序所在的目录设置到PATH环境变量。怎么设置呢? 在PATH变量中,路径用:号分隔。

假如,我在root的家目录下面创建了一个bin目录,用来放一个shell脚本,名字为ghost

ghostwu@dev:~/bin$ pwd
/home/ghostwu/bin
ghostwu@dev:~/bin$ ls -l
total
-rwxrwxr-x ghostwu ghostwu 5月 : ghost
ghostwu@dev:~/bin$ cat ghost
#!/bin/bash
ls -l /
ghostwu@dev:~/bin$ ./ghost
total
drwxr-xr-x root root 5月 : bin
drwxr-xr-x root root 2月 : boot
drwxr-xr-x root root 2月 : cdrom
drwxr-xr-x root root 5月 : dev
drwxr-xr-x root root 5月 : etc
drwxr-xr-x root root 2月 : home
lrwxrwxrwx root root 2月 : initrd.img -> boot/initrd.img-4.10.--generic
drwxr-xr-x root root 5月 : lib
drwxr-xr-x root root 5月 : lib64
drwx------ root root 2月 : lost+found
drwxr-xr-x root root 2月 : media
drwxr-xr-x root root 4月 : mnt
drwxr-xr-x root root 5月 : opt
drwxr-xr-x root root 5月 : patch
dr-xr-xr-x root root 5月 : proc
drwx------ root root 5月 : root
drwxr-xr-x root root 5月 : run
drwxr-xr-x root root 2月 : sbin
drwxr-xr-x root root 4月 snap
drwxr-xr-x root root 8月 srv
dr-xr-xr-x root root 5月 : sys
drwxrwxrwt root root 5月 : tmp
drwxr-xr-x root root 8月 usr
drwxr-xr-x root root 5月 : var
lrwxrwxrwx root root 2月 : vmlinuz -> boot/vmlinuz-4.10.--generic
drwxr-xr-x root root 5月 : www

由于我的PATH变量,已经包含了/home/ghostwu/bin这个路径,所以在任意的目录下,都会搜素这个目录,就会执行ghost

ghostwu@dev:~$ cd /etc
ghostwu@dev:/etc$ ghost
total
drwxr-xr-x root root 5月 : bin
drwxr-xr-x root root 2月 : boot
drwxr-xr-x root root 2月 : cdrom
drwxr-xr-x root root 5月 : dev
drwxr-xr-x root root 5月 : etc
drwxr-xr-x root root 2月 : home
lrwxrwxrwx root root 2月 : initrd.img -> boot/initrd.img-4.10.--generic
drwxr-xr-x root root 5月 : lib
drwxr-xr-x root root 5月 : lib64
drwx------ root root 2月 : lost+found
drwxr-xr-x root root 2月 : media
drwxr-xr-x root root 4月 : mnt
drwxr-xr-x root root 5月 : opt
drwxr-xr-x root root 5月 : patch
dr-xr-xr-x root root 5月 : proc
drwx------ root root 5月 : root
drwxr-xr-x root root 5月 : run
drwxr-xr-x root root 2月 : sbin
drwxr-xr-x root root 4月 snap
drwxr-xr-x root root 8月 srv
dr-xr-xr-x root root 5月 : sys
drwxrwxrwt root root 5月 : tmp
drwxr-xr-x root root 8月 usr
drwxr-xr-x root root 5月 : var
lrwxrwxrwx root root 2月 : vmlinuz -> boot/vmlinuz-4.10.--generic
drwxr-xr-x root root 5月 : www

在ubuntu16.04下面,这个路径设置是在.profile这个文件中的,而用户登录系统时,会执行这个.profile,所以PATH中的设置就会生效,接下来把他删除.

ghostwu@dev:~$ tail - .profile
PATH="$HOME/bin:$HOME/.local/bin:$PATH"

删除之后,你会发现,他依然存在,但是文件中确实是删除了,这个时候,我们要重启系统.

ghostwu@dev:~$ vim .profile
ghostwu@dev:~$ tail - .profile
#PATH="$HOME/bin:$HOME/.local/bin:$PATH"
PATH="$HOME/.local/bin:$PATH"
ghostwu@dev:~$ echo $PATH
/home/ghostwu/bin:/home/ghostwu/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin

注销系统也可以,我们删除的路径,已经生效了

ghostwu@dev:~$ echo $PATH
/home/ghostwu/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin
ghostwu@dev:~$ cd /etc
ghostwu@dev:/etc$ ghost ghostwu@dev:/etc$

我们可以临时把路径设置回去,在bin目录下创建一个脚本ghost2.,没有设置路径之前,ghost2是找不到的

ghostwu@dev:~$ echo $PATH
/home/ghostwu/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin
ghostwu@dev:~$ cat ~/bin/ghost2
#!/bin/bash
ls -l /etc
ghostwu@dev:~$ ghost2
ghost2: command not found

现在,就生效了,但是这个生效,在当前shell进程退出,或者另外的shell里面访问,是访问不到的,如果我们想永久让设置的环境保存下来,应该把他写在文件中,

一般写在下面4个文件中

/etc/profile: 这个是所有登录的用户都会加载的文件

$HOME/.bash_profile

$HOME/.bash_login

$HOME/.profile

后面3个文件是用户专用。我们之前的变量就是设置在.profile中。其实,还有一个文件,也可以设置:.bashrc。为甚呢?因为.profile会判断是否存在.bashrc。从而

加载.bashrc。所以在.bashrc中设置的环境变量,也会永久保存在当前用户环境下.

ghostwu@dev:~$ echo $PATH
/home/ghostwu/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin
ghostwu@dev:~$ cat ~/bin/ghost2
#!/bin/bash
ls -l /etc
ghostwu@dev:~$ ghost2
ghost2: command not found
ghostwu@dev:~$
ghostwu@dev:~$ PATH=$PATH:$HOME/bin
ghostwu@dev:~$ echo $PATH
/home/ghostwu/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/home/ghostwu/bin
ghostwu@dev:~$ ghost2
total
drwxr-xr-x root root 8月 acpi
....

Linux环境变量详解与应用的更多相关文章

  1. Linux 环境变量详解

    1. $HOME变量从哪里获得的? HOME 本身是 shell 来设置的,你可以自己手工设置(例如使用 bash 的 export),也可以在 shell 的初始化文件中设置(例如 bash 的 . ...

  2. net core体系-web应用程序-4net core2.0大白话带你入门-5asp.net core环境变量详解

    asp.net core环境变量详解   环境变量详解 Windows操作系统的环境变量在哪设置应该都知道了. Linux(centos版本)的环境变量在/etc/profile里面进行设置.用户级的 ...

  3. asp.net core环境变量详解

    环境变量详解 Windows操作系统的环境变量在哪设置应该都知道了. Linux(centos版本)的环境变量在/etc/profile里面进行设置.用户级的环境变量在其它文件里面,不多说了,有兴趣的 ...

  4. 【转】asp.net core环境变量详解

    asp.net core环境变量详解 环境变量详解 Windows操作系统的环境变量在哪设置应该都知道了. Linux(centos版本)的环境变量在/etc/profile里面进行设置.用户级的环境 ...

  5. Maya 常用环境变量详解

    Maya 常用环境变量详解 前言: Maya 的环境变量让用户可以很方便的自定义 Maya 的功能. 在 Maya 的 Help 帮助文档中有专门的一个章节< Environment Varia ...

  6. 如何查找YUM安装的JAVA_HOME环境变量详解

    如何查找YUM安装的JAVA_HOME环境变量详解  更新时间:2017年10月27日 09:44:56   作者:铁锚   我要评论 这篇文章主要给大家介绍了关于如何查找YUM安装的JAVA_HOM ...

  7. .NET Core 环境变量详解

    一.概述 软件从开发到正式上线,在这个过程中我们会分为多个阶段,通常会有开发.测试.以及上线等.每个阶段对应的环境参数配置我们会使用不同的参数.比如数据库的连接字符串,开发环境一般我们都是连接的测试库 ...

  8. PATH环境变量和CLASSPATH环境变量详解

    大凡装过JDK的人都知道要安装完成后要设置环境变量,可是为什么要设置环境变量呢?环境变量有什么作用? 1)PATH详解: 计算机安装JDK之后,输入“javac”“java”之类的命令是不能马上被计算 ...

  9. Hyperledger Fabric 通道配置文件和容器环境变量详解

    摘要 Fabric 网络启动的过程中需要进行大量配置,新学时对各个配置的作用一无所知,这导致我曾在网络出问题时先对配置文件的内容进行排列组合后再祈祷它能在某个时刻顺利运行,因此掌握 fabric 各个 ...

随机推荐

  1. 函数round和trunc

    1.round函数. round函数能够按照数学规则进行四舍五入的进位,以保留小数点后要求的位数. 使用方法为 round(<小数>,<保留的位数>) 下面是两个例子: ) f ...

  2. 枚举类型enum详解——C语言

    enum enum是C语言中的一个关键字,enum叫枚举数据类型,枚举数据类型描述的是一组整型值的集合(这句话其实不太妥当),枚举型是预处理指令#define的替代,枚举和宏其实非常类似,宏在预处理阶 ...

  3. Struts2再爆远程命令执行漏洞![W3bSafe]Struts2-048 Poc Shell及防御修复方案抢先看!

    漏洞概述 Apache Struts是美国阿帕奇(Apache)软件基金会负责维护的一个开源项目,是一套用于创建企业级Java Web应用的开源MVC框架.在Struts 2.3.x 系列的 Show ...

  4. 10.TreeSet、比较器

    Comparable和Comparator  Comparable 简介 Comparable 是排序接口.若一个类实现了Comparable接口,就意味着"该类支持排序".  即 ...

  5. 微信小程序:scroll滑到指定位置

    概述 这是我开发微信小程序遇到的坑中的一个,专门记录下来,供以后开发时参考,相信对其他人也有用. scroll滑到指定位置,有两种解决方案,一种是用scroll-view标签,另一种是用wx.page ...

  6. MongoDB 用法入门(windows)①

    概述 大家对数据库肯定不陌生,肯定也有很多人用过MySQL,但是在用MySQL的时候各种建表,写表之间的关联让人非常头疼. MongoDB也是一种数据库,但是它不是用表,而是用集合来装数据的,我对这种 ...

  7. Java学习笔记32(集合框架六:Map接口)

    Map接口与Collection不同: Collection中的集合元素是孤立的,可理解为单身,是一个一个存进去的,称为单列集合 Map中的集合元素是成对存在的,可理解为夫妻,是一对一对存进去的,称为 ...

  8. 声反馈抑制使用matlab/simulink仿真

    第一份工作时做啸叫抑制的仿真,调大0.3可以有大的啸叫产生,下图的SIMULINK仿真模型 实现移相有多种方法: 1.iir实现 2.FFT实现 3.使用FIR实现 所有信号均可以由正弦信号叠加而成.

  9. linux中Java项目占用cpu、内存过高时的排查经历

    一.使用top命令查看占用高资源的java项目的进程ID(pid): top 二.查看该进程中的线程所占用资源的情况:top -Hp pid 三.查看该线程对应的16进制:printf %x 1112 ...

  10. 线程误区-join,wait(里边还是调用的wait)

    1.一个线程执行结束后会执行该线程自身对象的notifyAll方法,这个是在jvm中实现的. 2.join的作用是:当我们调用某个线程的这个方法时,这个方法会挂起调用线程,直到被调用线程(thread ...