[root@linuxcoolbin]#export

declare-xBASH_ENV=”/root/.bashrc”

declare-xG_BROKEN_FILENAMES=”1″

declare-xHISTSIZE=”1000″

declare-xHOME=”/root”

declare-xHOSTNAME=”linuxcool.localdomain”

declare-xINPUTRC=”/etc/inputrc”

declare-xLANG=”zh_CN.GB18030″

declare-xLANGUAGE=”zh_CN.GB18030:zh_CN.GB2312:zh_CN”

declare-xLESSOPEN=”|/usr/bin/lesspipe.sh%s”

declare-xLOGNAME=”root”

declare-xLS_COLORS=”no=00:fi=00:di=01;34:ln=01;36:pi=40;33:so=01;35:bd=40;33;01:cd=40;33;01:or=01;05;37;41:mi=01;05;37;41:ex=01;32:*.cmd=01;32:*.exe=01;32:*.com=01;32:*.btm=01;32:*.bat=01;32:*.sh=01;32:*.csh=01;32:*.tar=01;31:*.tgz=01;31:*.arj=01;31:*.taz=01;31:*.lzh=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.gz=01;31:*.bz2=01;31:*.bz=01;31:*.tz=01;31:*.rpm=01;31:*.cpio=01;31:*.jpg=01;35:*.gif=01;35:*.bmp=01;35:*.xbm=01;35:*.xpm=01;35:*.png=01;35:*.tif=01;35:”

命令英文_linux export命令_命令方块指令

declare-xMAIL=”/var/spool/mail/root”

declare-xOLDPWD=”/opt/au1200_rm/build_tools”

declare-xPATH=”/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/X11R6/bin:/root/bin:/opt/au1200_rm/build_tools/bin”

declare-xPWD=”/opt/au1200_rm/build_tools/bin”

declare-xSHELL=”/bin/bash”

declare-xSHLVL=”1″

declare-xSSH_ASKPASS=”/usr/libexec/openssh/gnome-ssh-askpass”

declare-xSSH_AUTH_SOCK=”/tmp/ssh-XX3LKWhz/agent.4242″

declare-xSSH_CLIENT=”10.3.37.152223622″

declare-xSSH_CONNECTION=”10.3.37.152223610.3.37.18622″

declare-xSSH_TTY=”/dev/pts/2″

declare-xTERM=”linux”

declare-xUSER=”root”

declare-xUSERNAME=”root”

可以看见红色部份有设置的路径,说明环境变量早已设好,PATH上面早已有了我要加的编译器的路径。

2、修改profile文件:

#vi/etc/profile

在上面加入:

exportPATH=”$PATH:/opt/au1200_rm/build_tools/bin”

3.更改.bashrc文件:

#vi/root/.bashrc

在上面加入:

linux export命令_命令方块指令_命令英文

exportPATH=”$PATH:/opt/au1200_rm/build_tools/bin”

后两种方式通常须要重新注销系统才会生效,最后可以通过echo命令测试一下:

#echo$PATH

瞧瞧输出上面是不是早已有了/my_new_path这个路径了。

另有:4.更改/etc/re.local文件:

#vi/etc/re.local

在上面加入:

exportPATH=”$PATH:/opt/au1200_rm/build_tools/bin”

———————————————————————————————————————--

“/bin”、“/sbin”、“/usr/bin”、“/usr/sbin”、“/usr/local/bin”等路径早已在系统环境变量中了,若果可执行文件在这几个标准位置,在终端命令行输入该软件可执行文件的文件名和参数(假如须要参数),回车即可。

若果不在标准位置,文件名后面须要加上完整的路径。不过每次都这样跑就太麻烦了,一个“一劳永逸”的办法是把这个路径加入环境变量。命令export$PATH=”路径”(或“PATH=$PATH:路径”)($PATH为环境变量名,如DVSDK;调用时用$DVSDK)可以把这个路径加入环境变量,并且退出这个命令行就失效了。要想永久生效,须要把这行添加到环境变量文件里。有两个文件可选:“/etc/profile”和用房主目录下的“.bash_profile”,“/etc/profile”对系统里所有用户都有效,用房主目录下的“.bash_profile”只对这个用户有效。

linux export命令_命令英文_命令方块指令

export$PATH=”$PATH:路径1:路径2:…:路径n”(或“PATH=$PATH:路径1:路径2:…:路径n”),意思是可执行文件的路径包括原来设定的路径,也包括从“路径1”到“路径n”的所有路径。当用户输入一个一串字符并按回车后,shell会依次在这种路径里找对应的可执行文件并交给系统核心执行。那种“$PATH”表示原本设定的路径依然有效,注意不要漏掉。个别软件可能还有“PATH”以外类型的环境变量须要添加,但方式与此相同,但是也须要注意“$”。

注意,与DOS/Window不同,UNIX类系统环境变量中路径名用逗号分隔,不是分号。另外,软件越装越多,环境变量越添越多,为了防止引起混乱,建议所有句子都添加在文件结尾,按软件的安装次序添加。

格式如下():

#软件名-版本号

PATH=$PATH:路径1:路径2:…:路径n

其他环境变量=$其他环境变量:…

在“profile”和“.bash_profile”中,“#”是注释符号,写在这儿不仅视觉分隔外没有任何疗效。

设置完毕,注销并重新登陆,设置就生效了。若果不注销,直接在shell里执行这种句子,也能生效,并且作用范围只限于执行了这种句子的shell。

相关的环境变量生效后,就毋须老挪到软件的可执行文件目录里去操作了。

———————————————————————————————————————--

执行一个脚本时,会先开启一个子shell环境(不晓得执行其它程序是不是这样)linux export命令,之后将父shell中的所有系统环境变量复制过来,这个脚本中的句子就在子shell中执行。(也就是说父shell的环境变量在子shell中可以调用,但反过来就不行,假如在子shell中定义了环境变量,则只对该shell或则它的子shell有效,当该子shell结束时,也可以理解为脚本执行完时,变量消失。)为了证明这一点,请看脚本内容:

linux export命令_命令英文_命令方块指令

test=’value’

exporttest

这样的脚本执行完后,test实际上是不存在的。接着看下边的:

test=’value’

exporttest

bash

这儿在脚本最后一行再开一个子shell,该shell应当是脚本文件所在shell的子shell,这个脚本执行完后,是可以看见test这个变量的,由于现今是处于它的子shell中,当用exit退出子shell后,test变量消失。

假如用source对脚本进行执行时,假若不加export,就不会在子shell中听到这个变量,由于它还不是一个系统环境变量呀,如脚本内容是:

test=’value’

用source执行后,在shell下是能看见这个变量,但再执行bash开一个子shell时,test是不会被复制到子shell中的,由于执行脚本文件或许也是在一个子shell中运行,所以我再建另一个脚本文件执行时,是不会输入任何东西的,内容如:echo$test。所以这点非常注意了linux export命令,明明在提示符下可以用echo$test输出变量值,为何把它放进脚本文件就不行了呢?

所以得出的推论是:1、执行脚本时是在一个子shell环境运行的,脚本执行完后该子shell手动退出;2、一个shell中的系统环境变量就会被复制到子shell中(用export定义的变量);3、一个shell中的系统环境变量只对该shell或则它的子shell有效,该shell结束时变量消失(并不能返回到父shell中)。3、不用export定义的变量只对该shell有效linux设置默认网关,对子shell也是无效的。

后来按照版主的提示,整理了一下帖子:为何一个脚本直接执行和用source执行不一行呢?这也是我自己遇到的一个问题。manual原文是这样的:Readandexecutecommandsfromfilenameinthecurrentshellenvironmentandreturntheexitstatusofthelastcommandexecutedfromfilename.明白了为何不一样了吧?直接执行一个脚本文件是在一个子shell中运行的,而source则是在当前shell环境中运行的。

Author

这篇优质的内容由TA贡献而来

刘遄

《Linux就该这么学》书籍作者,RHCA认证架构师,教育学(计算机专业硕士)。

发表回复