10.4.3 bash 的環境設定檔
你是否會覺得奇怪,怎麼我們什麼動作都沒有進行,但是一進入 bash 就取得一堆有用的變數了?
這是因為系統有一些環境設定檔案的存在,讓 bash 在啟動時直接讀取這些設定檔,以規劃好 bash 的操作環境啦!
而這些設定檔又可以分為全體系統的設定檔以及使用者個人偏好設定檔。要注意的是,
我們前幾個小節談到的命令別名啦、自訂的變數啦,在你登出 bash 後就會失效,所以你想要保留你的設定,
就得要將這些設定寫入設定檔才行。底下就讓我們來聊聊吧!
login 與 non-login shell
在開始介紹 bash 的設定檔前,我們一定要先知道的就是 login shell 與 non-login shell!
重點在於有沒有登入 (login) 啦!
login shell:取得 bash 時需要完整的登入流程的,就稱為 login shell。舉例來說,你要由 tty1 ~ tty6
登入,需要輸入使用者的帳號與密碼,此時取得的 bash 就稱為『 login shell 』囉;
non-login shell:取得 bash 介面的方法不需要重複登入的舉動,舉例來說,(1)你以 X window 登入 Linux 後,
再以 X 的圖形化介面啟動終端機,此時那個終端介面並沒有需要再次的輸入帳號與密碼,那個 bash 的環境就稱為
non-login shell了。(2)你在原本的 bash 環境下再次下達 bash 這個指令,同樣的也沒有輸入帳號密碼,
那第二個 bash (子程序) 也是 non-login shell 。
為什麼要介紹 login, non-login shell 呢?這是因為這兩個取得 bash 的情況中,讀取的設定檔資料並不一樣所致。
由於我們需要登入系統,所以先談談 login shell 會讀取哪些設定檔?一般來說,login shell 其實只會讀取這兩個設定檔:
/etc/profile:這是系統整體的設定,你最好不要修改這個檔案;
~/.bash_profile 或 ~/.bash_login 或 ~/.profile:屬於使用者個人設定,你要改自己的資料,就寫入這裡!
那麼,就讓我們來聊一聊這兩個檔案吧!這兩個檔案的內容可是非常繁複的喔!
/etc/profile (login shell 才會讀)
你可以使用 vim 去閱讀一下這個檔案的內容。這個設定檔可以利用使用者的識別碼 (UID) 來決定很多重要的變數資料,
這也是每個使用者登入取得 bash 時一定會讀取的設定檔!
所以如果你想要幫所有使用者設定整體環境,那就是改這裡囉!不過,沒事還是不要隨便改這個檔案喔
這個檔案設定的變數主要有:
PATH:會依據 UID 決定 PATH 變數要不要含有 sbin 的系統指令目錄;
MAIL:依據帳號設定好使用者的 mailbox 到 /var/spool/mail/帳號名;
USER:根據使用者的帳號設定此一變數內容;
HOSTNAME:依據主機的 hostname 指令決定此一變數內容;
HISTSIZE:歷史命令記錄筆數。CentOS 7.x 設定為 1000 ;
umask:包括 root 預設為 022 而一般用戶為 002 等!
/etc/profile 可不止會做這些事而已,他還會去呼叫外部的設定資料喔!在 CentOS 7.x 預設的情況下,底下這些資料會依序的被呼叫進來:
/etc/profile.d/*.sh
其實這是個目錄內的眾多檔案!只要在 /etc/profile.d/ 這個目錄內且副檔名為 .sh ,另外,使用者能夠具有 r 的權限,
那麼該檔案就會被 /etc/profile 呼叫進來。在 CentOS 7.x 中,這個目錄底下的檔案規範了 bash 操作介面的顏色、
語系、ll 與 ls 指令的命令別名、vi 的命令別名、which 的命令別名等等。如果你需要幫所有使用者設定一些共用的命令別名時,
可以在這個目錄底下自行建立副檔名為 .sh 的檔案,並將所需要的資料寫入即可喔!
/etc/locale.conf
這個檔案是由 /etc/profile.d/lang.sh 呼叫進來的!這也是我們決定 bash 預設使用何種語系的重要設定檔!
檔案裡最重要的就是 LANG/LC_ALL 這些個變數的設定啦!我們在前面的 locale 討論過這個檔案囉!
自行回去瞧瞧先!
/usr/share/bash-completion/completions/*
記得我們上頭談過 [tab] 的妙用吧?除了命令補齊、檔名補齊之外,還可以進行指令的選項/參數補齊功能!那就是從這個目錄裡面找到相對應的指令來處理的!
其實這個目錄底下的內容是由 /etc/profile.d/bash_completion.sh 這個檔案載入的啦!
反正你只要記得,bash 的 login shell 情況下所讀取的整體環境設定檔其實只有
/etc/profile,但是 /etc/profile 還會呼叫出其他的設定檔,所以讓我們的 bash 操作介面變的非常的友善啦!
接下來,讓我們來瞧瞧,那麼個人偏好的設定檔又是怎麼回事?
~/.bash_profile (login shell 才會讀)
bash 在讀完了整體環境設定的 /etc/profile 並藉此呼叫其他設定檔後,接下來則是會讀取使用者的個人設定檔。
在 login shell 的 bash 環境中,所讀取的個人偏好設定檔其實主要有三個,依序分別是:
~/.bash_profile
~/.bash_login
~/.profile
其實 bash 的 login shell 設定只會讀取上面三個檔案的其中一個,
而讀取的順序則是依照上面的順序。也就是說,如果 ~/.bash_profile 存在,那麼其他兩個檔案不論有無存在,都不會被讀取。
如果 ~/.bash_profile 不存在才會去讀取 ~/.bash_login,而前兩者都不存在才會讀取 ~/.profile 的意思。
會有這麼多的檔案,其實是因應其他 shell 轉換過來的使用者的習慣而已。
先讓我們來看一下 dmtsai 的 /home/dmtsai/.bash_profile 的內容是怎樣呢?
[dmtsai@study ~]$ cat ~/.bash_profile
# .bash_profile
# Get the aliases and functions
if [ -f ~/.bashrc ]; then <==底下這三行在判斷並讀取 ~/.bashrc
. ~/.bashrc
fi
# User specific environment and startup programs
PATH=$PATH:$HOME/.local/bin:$HOME/bin <==底下這幾行在處理個人化設定
export PATH
這個檔案內有設定 PATH 這個變數喔!而且還使用了 export 將 PATH 變成環境變數呢!
由於 PATH 在 /etc/profile 當中已經設定過,所以在這裡就以累加的方式增加使用者家目錄下的 ~/bin/
為額外的執行檔放置目錄。這也就是說,你可以將自己建立的執行檔放置到你自己家目錄下的 ~/bin/ 目錄啦!
那就可以直接執行該執行檔而不需要使用絕對/相對路徑來執行該檔案。
這個檔案的內容比較有趣的地方在於 if ... then ... 那一段!那一段程式碼我們會在第十二章 shell script 談到,假設你現在是看不懂的。
該段的內容指的是『判斷家目錄下的 ~/.bashrc 存在否,若存在則讀入 ~/.bashrc 的設定』。
bash 設定檔的讀入方式比較有趣,主要是透過一個指令『 source 』來讀取的!
也就是說 ~/.bash_profile 其實會再呼叫 ~/.bashrc 的設定內容喔!最後,我們來看看整個 login shell
的讀取流程:
圖10.4.1、login shell 的設定檔讀取流程
實線的的方向是主線流程,虛線的方向則是被呼叫的設定檔!從上面我們也可以清楚的知道,在 CentOS
的 login shell 環境下,最終被讀取的設定檔是『 ~/.bashrc 』這個檔案喔!所以,你當然可以將自己的偏好設定寫入該檔案即可。
底下我們還要討論一下 source 與 ~/.bashrc 喔!
source :讀入環境設定檔的指令
由於 /etc/profile 與 ~/.bash_profile 都是在取得 login shell 的時候才會讀取的設定檔,所以,
如果你將自己的偏好設定寫入上述的檔案後,通常都是得登出再登入後,該設定才會生效。那麼,能不能直接讀取設定檔而不登出登入呢?
可以的!那就得要利用 source 這個指令了!
[dmtsai@study ~]$ source 設定檔檔名
範例:將家目錄的 ~/.bashrc 的設定讀入目前的 bash 環境中
[dmtsai@study ~]$ source ~/.bashrc <==底下這兩個指令是一樣的!
[dmtsai@study ~]$ . ~/.bashrc
利用 source 或小數點 (.) 都可以將設定檔的內容讀進來目前的 shell 環境中!
舉例來說,我修改了 ~/.bashrc ,那麼不需要登出,立即以 source ~/.bashrc
就可以將剛剛最新設定的內容讀進來目前的環境中!很不錯吧!還有,包括 ~/bash_profile 以及 /etc/profile 的設定中,
很多時候也都是利用到這個 source (或小數點) 的功能喔!
有沒有可能會使用到不同環境設定檔的時候?有啊!
最常發生在一個人的工作環境分為多種情況的時候了!舉個例子來說,在鳥哥的大型主機中,
常常需要負責兩到三個不同的案子,每個案子所需要處理的環境變數訂定並不相同,
那麼鳥哥就將這兩三個案子分別編寫屬於該案子的環境變數設定檔案,當需要該環境時,就直接『
source 變數檔 』,如此一來,環境變數的設定就變的更簡便而靈活了!
~/.bashrc (non-login shell 會讀)
談完了 login shell 後,那麼 non-login shell 這種非登入情況取得 bash 操作介面的環境設定檔又是什麼?
當你取得 non-login shell 時,該 bash 設定檔僅會讀取 ~/.bashrc 而已啦!那麼預設的 ~/.bashrc 內容是如何?
[root@study ~]# cat ~/.bashrc
# .bashrc
# User specific aliases and functions
alias rm='rm -i' <==使用者的個人設定
alias cp='cp -i'
alias mv='mv -i'
# Source global definitions
if [ -f /etc/bashrc ]; then <==整體的環境設定
. /etc/bashrc
fi
特別注意一下,由於 root 的身份與一般使用者不同,鳥哥是以 root 的身份取得上述的資料,
如果是一般使用者的 ~/.bashrc 會有些許不同。看一下,你會發現在 root 的 ~/.bashrc 中其實已經規範了較為保險的命令別名了。
此外,咱們的 CentOS 7.x 還會主動的呼叫 /etc/bashrc 這個檔案喔!為什麼需要呼叫 /etc/bashrc 呢?
因為 /etc/bashrc 幫我們的 bash 定義出底下的資料:
依據不同的 UID 規範出 umask 的值;
依據不同的 UID 規範出提示字元 (就是 PS1 變數);
呼叫 /etc/profile.d/*.sh 的設定
你要注意的是,這個 /etc/bashrc 是 CentOS 特有的 (其實是 Red Hat 系統特有的),其他不同的 distributions
可能會放置在不同的檔名就是了。由於這個 ~/.bashrc 會呼叫 /etc/bashrc 及 /etc/profile.d/*.sh ,
所以,萬一你沒有 ~/.bashrc (可能自己不小心將他刪除了),那麼你會發現你的 bash 提示字元可能會變成這個樣子:
-bash-4.2$
不要太擔心啦!這是正常的,因為你並沒有呼叫 /etc/bashrc 來規範 PS1 變數啦!而且這樣的情況也不會影響你的 bash 使用。
如果你想要將命令提示字元捉回來,那麼可以複製 /etc/skel/.bashrc 到你的家目錄,再修訂一下你所想要的內容,
並使用 source 去呼叫 ~/.bashrc ,那你的命令提示字元就會回來啦!
其他相關設定檔
事實上還有一些設定檔可能會影響到你的 bash 操作的,底下就來談一談:
/etc/man_db.conf
這個檔案乍看之下好像跟 bash 沒相關性,但是對於系統管理員來說,
卻也是很重要的一個檔案!這的檔案的內容『規範了使用
man 的時候, man page
的路徑到哪裡去尋找!』所以說的簡單一點,這個檔案規定了下達
man 的時候,該去哪裡查看資料的路徑設定!
那麼什麼時候要來修改這個檔案呢?如果你是以
tarball 的方式來安裝你的資料,那麼你的 man page 可能會放置在
/usr/local/softpackage/man 裡頭,那個 softpackage 是你的套件名稱,
這個時候你就得以手動的方式將該路徑加到 /etc/man_db.conf 裡頭,否則使用 man
的時候就會找不到相關的說明檔囉。
~/.bash_history
還記得我們在歷史命令提到過這個檔案吧?預設的情況下,
我們的歷史命令就記錄在這裡啊!而這個檔案能夠記錄幾筆資料,則與 HISTFILESIZE
這個變數有關啊。每次登入 bash 後,bash 會先讀取這個檔案,將所有的歷史指令讀入記憶體,
因此,當我們登入 bash 後就可以查知上次使用過哪些指令囉。至於更多的歷史指令,
請自行回去參考喔!
~/.bash_logout
這個檔案則記錄了『當我登出 bash 後,系統再幫我做完什麼動作後才離開』的意思。
你可以去讀取一下這個檔案的內容,預設的情況下,登出時, bash 只是幫我們清掉螢幕的訊息而已。
不過,你也可以將一些備份或者是其他你認為重要的工作寫在這個檔案中 (例如清空暫存檔),
那麼當你離開 Linux 的時候,就可以解決一些煩人的事情囉!