环境变量这个概念,在linux里面应该是一个很普通的事物了。
在shell命令里面输入命令env或者printenv,可以查看系统运行的环境变量
$ env
或者查看某个进程的自身的环境变量
$ cat /proc/[pid]/environ | strings #strings 可以换行显示信息
在shell里面执行执行文件(命令)时,如何传入一个环境变量参数呢。零时使用的一般的做法是
在shell里面,输入命令:
# 关闭该shell后失效,或者用 unset [key]失效
$ export [key]=[value]
这种做法下,环境变量会在shell内生效,对以后执行的所有文件都起效
如果不想干扰后续的文件,又不想用unset来手动清除,还有一种做法:
# 直接在执行文件前加上“[key]=[value]”
$ chain@Debug:~$ SLEEP_ENV=100 sleep 60 &
$ [1] 33778
$ chain@Debug:~$ cat /proc/33778/environ | strings
$ SLEEP_ENV=100 # 环境变量生效了
$ ......
# 如果想加入两个参数,直接挨着加就可以了
$ chain@Debug:~$ SLEEP_ENV=100 SLEEP_ENV2=100 sleep 60 &
也许大多数时候,我们就是知道这样做就可以了。其实应该更深一步去探究,为什么这样可以。
在嵌入式linux上,一般的shell都是使用的busybox,研究busybox/shell/ash.c就可以发现:
输入命令时,会解析命令前的参数,作为shell执行一个命令的变量。在fork后执行文件时把环境变量参数通过execve传入执行文件里。