LINUX中 export的作用

功能說明:設置或顯示環境變量。

語  法:export [-fnp][變量名稱]=[變量設置值]

補充說明:在shell中執行程序時,shell會提供一組環境變量。export可新增,修改或刪除環境變量,供後續執行的程序使用。export的效力僅及於該此登陸操作。

參  數:
 -f  代表[變量名稱]中爲函數名稱。 
 -n  刪除指定的變量。變量實際上並未刪除,只是不會輸出到後續指令的執行環境中。 
 -p  列出所有的shell賦予程序的環境變量。

linux export 的作用 (2009-06-08 17:50)



shell與export命令

用戶登錄到Linux系統後,系統將啓動一個用戶shell。在這個shell中,可以使用shell命令或聲明變量,也可以創建並運行 shell腳本程序。運行shell腳本程序時,系統將創建一個子shell。此時,系統中將有兩個shell,一個是登錄時系統啓動的shell,另一 個是系統爲運行腳本程序創建的shell。當一個腳本程序運行完畢,它的腳本shell將終止,可以返回到執行該腳本之前的shell。從這種意義上來 說,用戶可以有許多 shell,每個shell都是由某個shell(稱爲父shell)派生的。
在子 shell中定義的變量只在該子shell內有效。如果在一個shell腳本程序中定義了一個變量,當該腳本程序運行時,這個定義的變量只是該腳本程序內 的一個局部變量,其他的shell不能引用它,要使某個變量的值可以在其他shell中被改變,可以使用export命令對已定義的變量進行輸出。 export命令將使系統在創建每一個新的shell時定義這個變量的一個拷貝。這個過程稱之爲變量輸出。
[例]在本例中,變量myfile是在dispfile腳本程序中定義的。然後用export命令將變量myfile輸出至任何子shell,例如當執行printfile腳本程序時產生的子shell。
dispfile腳本程序清單:
/**************begin dispfile**************/
myfile=”List”
export myfile
echo “Displaying $myfile”
pr –t –n $myfile
printfile
/**************end dispfile***************/
 
printfile腳本程序清單:
/**************begin printfile**************/
echo “Printing $myfile”
lpr $myfile&
/**************end printfile**************/
$dispfile
Displaying List
1 screen
2 modem
3 paper
Printing List
$

Linux 指令:系統設置--export 

 功能說明:設置或顯示環境變量。

語  法:export [-fnp][變量名稱]=[變量設置值]

補充說明:在shell中執行程序時,shell會提供一組環境變量。export可新增,修改或刪除環境變量,供後續執行的程序使用。export的效力僅及於該此登陸操作。

參  數:
 -f  代表[變量名稱]中爲函數名稱。 
 -n  刪除指定的變量。變量實際上並未刪除,只是不會輸出到後續指令的執行環境中。 
 -p  列出所有的shell賦予程序的環境變量。

http://linux.chinaitlab.com/command/723900.html


從學習export命令理解到的Shell環境和變量生存期

 
  我自己也是一個菜鳥,接觸linux沒有多久,最近在學習BASH的export命令時碰到了一個難道(書上說export是將自定義變量變成系統環 境變量):我在一個腳本文件中定義一個了變量,然後export變量,按照我自己的想法,執行完這個腳本後,在提示符下一定可以用echo顯示出它的值, 可結果卻不是這樣,腳本執行完後用set根本看不到有這個變量存在。爲什麼呢?我百思不得其解,最後將問題貼出來,一位前輩告訴我說用source+腳本 文件就可以了,我試了一下果然可以,但一個新的問題又出來了。我將腳本中export命令刪除後,用source一樣可以。那這個export好像沒有什 麼用呀。

  在經過多次嘗試後發現了一些東西,是我自己猜的,如果有什麼不對的地方,請指正,謝謝。

  執行一個腳本 時,會先開啓一個子shell環境(不知道執行其它程序是不是這樣),然後將父shell中的所有系統環境變量複製過來,這個腳本中的語句就在子 shell中執行。(也就是說父shell的環境變量在子shell中可以調用,但反過來就不行,如果在子shell中定義了環境變量,只對該shell 或者它的子shell有效,當該子shell結束時,也可以理解爲腳本執行完時,變量消失。)爲了證明這一點,請看腳本內容:

  test='value'

  export test

  這樣的腳本執行完後,test實際上是不存在的。接着看下面的:

  test='value'

  export test

  bash

  這裏在腳本最後一行再開一個子shell,該shell應該是腳本文件所在shell的子shell,這個腳本執行完後,是可以看到test這個變量的,因爲現在是處於它的子shell中,當用exit退出子shell後,test變量消失。

  如果用source對腳本進行執行時,如果不加export,就不會在子shell中看到這個變量,因爲它還不是一個系統環境變量呀,如腳本內容是:

  test='value'

   用source執行後,在shell下是能看到這個變量,但再執行bash開一個子shell時,test是不會被複制到子shell中的,因爲執行腳 本文件其實也是在一個子shell中運行,所以我再建另一個腳本文件執行時,是不會輸入任何東西的,內容如:echo $test。所以這點特別注意了,明明在提示符下可以用echo $test輸出變量值,爲什麼把它放進腳本文件就不行了呢?

  所以得 出的結論是:1、執行腳本時是在一個子shell環境運行的,腳本執行完後該子shell自動退出;2、一個shell中的系統環境變量纔會被複制到子 shell中(用export定義的變量);3、一個shell中的系統環境變量只對該shell或者它的子shell有效,該shell結束時變量消失 (並不能返回到父shell中)。3、不用export定義的變量只對該shell有效,對子shell也是無效的。

  後來根據版主的 提示,整理了一下貼子:爲什麼一個腳本直接執行和用source執行不一行呢?這也是我自己碰到的一個問題。manual原文是這樣的:Read and execute commands from filename in the current shell environment and return the exit status of the last command executed from filename.明白了爲什麼不一樣了吧?直接執行一個腳本文件是在一個子shell中運行的,而source則是在當前shell環境中運行的。根據 前面的內容,你也已經明白其中的道理了吧。

  困擾了我幾天的問題終於可以圓滿的解決了。


在Linux裏設置環境變量的方法(export PATH)

一般來說,配置交叉編譯工具鏈的時候需要指定編譯工具的路徑,此時就需要設置環境變量。例如我的mips-linux-gcc編譯器在“/opt/au1200_rm/build_tools/bin”目錄下,build_tools就是我的編譯工具,則有如下三種方法來設置環境變量:

1、直接用export命令:
#export PATH=$PATH:/opt/au1200_rm/build_tools/bin
查看是否已經設好,可用命令export查看:
[root@localhost bin]# export
declare -x BASH_ENV="/root/.bashrc"
declare -x G_BROKEN_FILENAMES="1"
declare -x HISTSIZE="1000"
declare -x HOME="/root"
declare -x HOSTNAME="localhost.localdomain"
declare -x INPUTRC="/etc/inputrc"
declare -x LANG="zh_CN.GB18030"
declare -x LANGUAGE="zh_CN.GB18030:zh_CN.GB2312:zh_CN"
declare -x LESSOPEN="|/usr/bin/lesspipe.sh %s"
declare -x LOGNAME="root"
declare -x LS_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:"
declare -x MAIL="/var/spool/mail/root"
declare -x OLDPWD="/opt/au1200_rm/build_tools"
declare -x PATH="/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/X11R6/bin:/root/bin:/opt/au1200_rm/build_tools/bin"
declare -x PWD="/opt/au1200_rm/build_tools/bin"
declare -x SHELL="/bin/bash"
declare -x SHLVL="1"
declare -x SSH_ASKPASS="/usr/libexec/openssh/gnome-ssh-askpass"
declare -x SSH_AUTH_SOCK="/tmp/ssh-XX3LKWhz/agent.4242"
declare -x SSH_CLIENT="10.3.37.152 2236 22"
declare -x SSH_CONNECTION="10.3.37.152 2236 10.3.37.186 22"
declare -x SSH_TTY="/dev/pts/2"
declare -x TERM="linux"
declare -x USER="root"
declare -x USERNAME="root"

可以看到,環境變量已經設好,PATH裏面已經有了我要加的編譯器的路徑。

2、修改profile文件: 
#vi /etc/profile 
在裏面加入:
export PATH="$PATH:/opt/au1200_rm/build_tools/bin"

3. 修改.bashrc文件:
# vi /root/.bashrc
在裏面加入:
export PATH="$PATH:/opt/au1200_rm/build_tools/bin"

後兩種方法一般需要重新註銷系統才能生效,最後可以通過echo命令測試一下:
# echo $PATH
看看輸出裏面是不是已經有了/my_new_path這個路徑了。

-----------------------------------------------------------------------------------------------------------------------

 “/bin”、“/sbin”、“/usr/bin”、“/usr/sbin”、“/usr/local/bin”等路徑已經在系統環境變量中了,如果可執行文件在這幾個標準位置,在終端命令行輸入該軟件可執行文件的文件名和參數(如果需要參數),回車即可。

  如果不在標準位置,文件名前面需要加上完整的路徑。不過每次都這樣跑就太麻煩了,一個“一勞永逸”的辦法是把這個路徑加入環境變量。命令 “PATH=$PATH:路徑”可以把這個路徑加入環境變量,但是退出這個命令行就失效了。要想永久生效,需要把這行添加到環境變量文件裏。有兩個文件可 選:“/etc/profile”和用戶主目錄下的“.bash_profile”,“/etc/profile”對系統裏所有用戶都有效,用戶主目錄下 的“.bash_profile”只對這個用戶有效。

  “PATH=$PATH:路徑1:路徑2:...:路徑n”,意思是可執行文件的路徑包括原先設定的路徑,也包括從“路徑1”到“路徑n”的所 有路徑。當用戶輸入一個一串字符並按回車後,shell會依次在這些路徑裏找對應的可執行文件並交給系統核心執行。那個“$PATH”表示原先設定的路徑 仍然有效,注意不要漏掉。某些軟件可能還有“PATH”以外類型的環境變量需要添加,但方法與此相同,並且也需要注意“$”。

  注意,與DOS/Window不同,UNIX類系統環境變量中路徑名用冒號分隔,不是分號。另外,軟件越裝越多,環境變量越添越多,爲了避免造成混亂,建議所有語句都添加在文件結尾,按軟件的安裝順序添加。

  格式如下():

  # 軟件名-版本號

  PATH=$PATH:路徑1:路徑2:...:路徑n

  其他環境變量=$其他環境變量:...

  在“profile”和“.bash_profile”中,“#”是註釋符號,寫在這裏除了視覺分隔外沒有任何效果。

  設置完畢,註銷並重新登錄,設置就生效了。如果不註銷,直接在shell裏執行這些語句,也能生效,但是作用範圍只限於執行了這些語句的shell。

  相關的環境變量生效後,就不必老跑到軟件的可執行文件目錄裏去操作了。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章