Linux中環(huán)境變量配置的步驟詳解
簡介
我們大家在平時(shí)使用Linux的時(shí)候,經(jīng)常需要配置一些環(huán)境變量,這時(shí)候一般都是網(wǎng)上隨便搜搜就有人介紹經(jīng)驗(yàn)的。不過問題在于他們的方法各不相同,有人說配置在/etc/profile里,有人說配置在/etc/environment,有人說配置在~/.bash_profile里,有人說配置在~/.bashrc里,有人說配置在~/.bash_login里,還有人說配置在~/.profile里。。。這真是公說公有理。。。那么問題來了,Linux到底是怎么讀取配置文件的呢,依據(jù)又是什么呢?下面這篇文章就來給大家詳細(xì)的介紹下,一起來看看吧。
文檔
我一向討厭那種說結(jié)論不說出處的行為,這會給人一種“我憑什么相信你”的感覺。而且事實(shí)上沒有出處就隨便議論得出的結(jié)論也基本上是人云亦云的。事實(shí)上,與其去問別人,不如去問文檔。 找了一會,發(fā)現(xiàn)關(guān)于環(huán)境變量配置的相關(guān)文檔其實(shí)是在bash命令的man文檔里,畢竟我們常用的就是這個(gè)shell。
在$man bash里,我發(fā)現(xiàn)了下面的一段文字:
INVOCATION A login shell is one whose first character of argument zero is a -, or one started with the --login option. An interactive shell is one started without non-option arguments and without the -c option whose standard input and error are both connected to terminals (as determined by isatty(3)), or one started with the -i option. PS1 is set and $- includes i if bash is interactive, allowing a shell script or a startup file to test this state. The following paragraphs describe how bash executes its startup files. If any of the files exist but cannot be read, bash reports an error. Tildes are expanded in filenames as described below under Tilde Expan‐ sion in the EXPANSION section. When bash is invoked as an interactive login shell, or as a non-inter‐ active shell with the --login option, it first reads and executes com‐ mands from the file /etc/profile, if that file exists. After reading that file, it looks for ~/.bash_profile, ~/.bash_login, and ~/.profile, in that order, and reads and executes commands from the first one that exists and is readable. The --noprofile option may be used when the shell is started to inhibit this behavior. When a login shell exits, bash reads and executes commands from the file ~/.bash_logout, if it exists. When an interactive shell that is not a login shell is started, bash reads and executes commands from /etc/bash.bashrc and ~/.bashrc, if these files exist. This may be inhibited by using the --norc option. The --rcfile file option will force bash to read and execute commands from file instead of /etc/bash.bashrc and ~/.bashrc. When bash is started non-interactively, to run a shell script, for example, it looks for the variable BASH_ENV in the environment, expands its value if it appears there, and uses the expanded value as the name of a file to read and execute. Bash behaves as if the following com‐ mand were executed: if [ -n "$BASH_ENV" ]; then . "$BASH_ENV"; fi but the value of the PATH variable is not used to search for the file‐ name.
通過這段文字,我們發(fā)現(xiàn)其實(shí)所謂的環(huán)境變量配置文件,就是在shell登陸的時(shí)候自動加載的那些文件。不過他所定義的登陸卻分為兩種:
- login shell登陸。
- interactive shell登陸。
login shell 登陸
所謂的login shell登陸,實(shí)際上就是指需要輸入密碼的登陸。具體的說,包括開機(jī)登陸、ssh登陸,或者是輸入bash --login這種“假裝自己輸入密碼登陸”的方式。 在這種登陸方式下,系統(tǒng)會先讀取/etc/profile文件,然后,系統(tǒng)會依次搜索~/.bash_profile、~/.bash_login、~/.profile 這三個(gè)文件,并運(yùn)行只其中第一個(gè)存在的文件。 尤其要注意到后三個(gè)文件的“邏輯或”的關(guān)系。很多情況下我們會發(fā)現(xiàn),明明已經(jīng)修改了~/.profile文件為什么重新登陸后配置不生效呢?這是因?yàn)槲覀兊南到y(tǒng)可能存在了前面兩個(gè)文件中的一個(gè),導(dǎo)致不會繼續(xù)讀取剩下的文件。
下面的三張圖很好的說明了這個(gè)問題:
interactive shell 登陸
所謂的interactive shell登陸,其實(shí)就是相對于login shell登陸而言的。我們平時(shí)在登陸后右鍵打開終端、或者CTRL+ALT+T打開終端都是interactive shell登陸。 在這種登陸方式下,系統(tǒng)會依次讀取/etc/bash.bashrc和~/.bashrc,并加以執(zhí)行。 通常情況下,~/.bashrc文件里會默認(rèn)記錄一些常量和一些別名,尤其是$PS1變量,這個(gè)變量決定著bash提示符的格式、樣式以及顏色等。
注意:
需要注意的是,這兩種登陸方式讀取的是不同的配置文件,而且互相之間沒有交集,因此當(dāng)我們需要配置環(huán)境變量時(shí),我們要根據(jù)自己的登陸方式將需要的變量配置到不同的文件里。 例如下面這個(gè)經(jīng)典的問題。
典型問題
環(huán)境配置文件配置異常的例子是,當(dāng)我用ssh登錄服務(wù)器的時(shí)候,發(fā)現(xiàn)提示符是這樣的:
bash-4.3$
沒錯(cuò),就像上面第三張圖片里的那個(gè)bash一樣,提示符非常奇怪,而且當(dāng)輸入ls時(shí)文件和文件夾的顏色也沒有區(qū)分。 這個(gè)問題顯然是由于$PS1這個(gè)環(huán)境變量沒有配置,導(dǎo)致他用了默認(rèn)值,雖然查看.bashrc文件時(shí)發(fā)現(xiàn)有$PS1這個(gè)變量的定義。,但是由于ssh屬于login shell,因此他在登陸時(shí)讀入的配置文件是/etc/profile一類的文件,并沒有讀入.bashrc。 導(dǎo)致這個(gè)問題的原因通常是我們誤刪除了/etc/profile里默認(rèn)的配置文件,因此解決的辦法也很簡單。。。把.bashrc里的部分文件復(fù)制到/etc/profile里就行了。
這個(gè)問題給我們的啟示是,當(dāng)我們?yōu)榉?wù)器配置變量時(shí),盡量配置到/etc/profile里或者~/.bash_profile里,因?yàn)橛胹sh登錄服務(wù)器是基本上用不到.bashrc文件的;當(dāng)我們給自己的電腦配置環(huán)境變量時(shí),盡量配置到.bashrc里,因?yàn)檫@樣我們只要打開終端就會讀入這個(gè)文件,這樣就可以不用注銷就能應(yīng)用配置了(只有注銷重新登錄才會應(yīng)用/etc/profile一類的配置文件)。
總結(jié)
以上就是這篇文章的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
使用 bind 設(shè)置 DNS 服務(wù)器的方法
Bind9是一個(gè)強(qiáng)大的Linux下開放源代碼的DNS服務(wù)器軟件,這篇文章主要介紹了使用 bind 設(shè)置 DNS 服務(wù)器的方法,需要的朋友可以參考下2020-03-03linux下通過rsync+inotify 實(shí)現(xiàn)數(shù)據(jù)實(shí)時(shí)備份(遠(yuǎn)程容災(zāi)備份系統(tǒng))
linux下為了數(shù)據(jù)安全或者網(wǎng)站同步鏡像,不得不考慮一些實(shí)時(shí)備份的問題,這篇linux下通過rsync+inotify 實(shí)現(xiàn)數(shù)據(jù)實(shí)時(shí)備份配置過程記錄下來,防止遺忘2013-09-09Ubuntu 18.04上安裝Apache、MySQL、PHP、LAMP的完整教程
這篇文章主要介紹了Ubuntu 18.04上安裝Apache, MySQL, PHP, LAMP的完整教程,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12ubuntu18.0.4安裝mysql并解決ERROR 1698 (28000): Access denied for
這篇文章主要介紹了ubuntu18.0.4安裝mysql并解決ERROR 1698 (28000): Access denied for user 'root'@'localhost',現(xiàn)在將ubuntu18.0.4上安裝mysql并將碰到的問題記錄下來,感興趣的朋友一起看看吧2019-11-11