在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. Tomcat 多项目部署方法整理

    Tomcat 多项目部署方法整理 说明:tomcat-deploy-aaa和tomcat-deploy-bbb是两个不同的web项目,为了方便以下简称aaa和bbb,请先自行创建并跑通 导航: NO1 ...

  2. cf 20C Dijkstra?

    带队列  dijkstra #include <iostream> #include <cstdio> #include <queue> #include < ...

  3. CPP之内存分配

    new & delete expression 1. Introduction A new expression allocates and constructs an object of a ...

  4. MyBatis 源码分析 - SQL 的执行过程

    * 本文速览 本篇文章较为详细的介绍了 MyBatis 执行 SQL 的过程.该过程本身比较复杂,牵涉到的技术点比较多.包括但不限于 Mapper 接口代理类的生成.接口方法的解析.SQL 语句的解析 ...

  5. Java集合框架之二:LinkedList源码解析

    版权声明:本文为博主原创文章,转载请注明出处,欢迎交流学习! LinkedList底层是通过双向循环链表来实现的,其结构如下图所示: 链表的组成元素我们称之为节点,节点由三部分组成:前一个节点的引用地 ...

  6. vue keep-alive解决关闭标签动态缓存问题

    直接上代码: <keep-alive :include='topNavMentNames'> <router-view ></router-view> </k ...

  7. 【洛谷4770】 [NOI2018]你的名字(SAM,线段树合并)

    传送门 洛谷 Solution 做过的比较玄学的后缀自动机. 果然就像\(Tham\)所讲,后缀自动机这种东西考场考了不可能做的出来的... 考虑如果\(l=1,r=|S|\)的怎么做? 直接建后缀自 ...

  8. shell 中的三种引号的作用

    1. 单引号(' ') 单引号里的任何字符都会原样输出,单引号字符串中的变量是无效的: 单引号字串中不能出现单独一个的单引号(对单引号使用转义符后也不行),但可成对出现,作为字符串拼接使用. 2. 双 ...

  9. oracle中查询用户表/索引/视图创建语句

    不多说,直接上干货 1.查询当前用户下表的创建语句 select dbms_metadata.get_ddl('TABLE','ux_future') from dual; 2.查询其他用户下表的创建 ...

  10. 13-03 Java 基本类型包装类概述,Integer类,Character

    基本类型包装类概述 将基本数据类型封装成对象的好处在于可以在对象中定义更多的功能方法操作该数据.常用的操作之一:用于基本数据类型与字符串之间的转换.基本类型和包装类的对应Byte,Short,Inte ...