跳到主要內容

Linux 操作不求人系列 - 壹章之肆 - 進入Linux操作環境(IV) - 編輯個人環境變數

     承上一節,我們已經學得 vim 的編輯能力,在這一節,我們就要來編輯我們在Bash Shell內的環境變數檔,按照登入時的存取順序為  ~/.bash_profile,  ~/.bash_login, ~/.profile。緊接著下壹章,便是進入學習使用Linux工作主軸之一,來撰寫自己的 Shell Scripts 程式吧
首先,我們在命令提示字元,輸入指令 cd ~ && ls -al | more ,用分頁的方式,來找找bash的相關設定檔案,如圖1-27。說明如下
$ cd ~ && ls -al | more    /*  將路徑改變至使用帳號的家目錄,&&為 cd~ 執行成功後,接著執行 la -al,若用 ; 取代,為不判斷是否成功直接執行下個指令。指令 ls -al,也是把家目錄下,包含隱藏的所有檔案與資料夾列出,再利用 | ,把列出的結果,利用more指令,分頁列出來,若資料沒有列完,則出現如圖1-27左下方的 -- More --
的提示,等使用者一直按空白鍵,才接續列出下一頁。 順帶一提,若想回到上一次停留的資料夾,亦可使用指令 cd - */





























(圖1-27)

     從圖1-27黃色框內亦可看出,有關於Bash Shell 的設定檔為 .bash_history, .bash_logout, .bash_profile, .bashrc, 對各個檔案的作用以及與其它Shell設定檔的比較有興趣的讀者,可以參考wikipedia:https://en.wikipedia.org/wiki/Bash_(Unix_shell)內Startup Scripts的部分 ,筆者僅說明.bash_profile與.bashrc這兩檔案的內容與調整。那如何把檔案內容一次列出來看呢?我們可以使用 cat (concatenate)指令,先把檔案 .bash_profile 的內容一次列出來,如圖1-28。說明如下
$ pwd     #先確認是否為使用者個人家目錄

$ cat -n .bash_profile   /* 把 .bash_profile 的所有內容,像"貓扒東西"似的都列出來,並且利用參數 -n 把行數也顯示出來。若要從後面列到前面,要用指令 tac (想像 cat 倒寫回來)  */

$ wc -l .bash_profile    /* 接著我們再利用 wc (word count)的指令,加上參數 -l (line) ,把 .bash_profle 內容的總行數算出,可以看出結果亦為共12行。註:亦可以用指令 cat .bash_profile | wc -l 的方式列出總行數   */
--------------------------------------------------------

     以上cat 與 wc指令的詳細說明,有興趣的讀者,可用man cat 或 man wc 來查詢之。cat 亦可用來上下合併兩個檔案,cat afile bfile cfile > newfile,如 MS Windows下的 type 指令,那若要左右合併欄位式的資料檔案,則就需利用指令 paste afile bfile cfile > newfile,方式產生。































(圖1-28)

     圖1-28用指令 cat 列出的 .bash_profile 檔案內容,依列出的行數說明如下:
第1行,當讀者看到 # 時,便可知單行內,後方的文字為說明,這前幾節已說明過,第三行亦然。第4至第6行,為bash 特有的 if 表達式,結尾必須使用 fi ,if的條件判斷式放置於 [ ] (square brackets) 內,條件 -f  ~/.bashrc,為檢查 ~/.bashrc 檔案是否存在且為正規檔案(各式的判斷參數,可參閱http://www.gnu.org/software/bash/manual/html_node/Bash-Conditional-Expressions.html)。再接著為 ;  才可以接 then ,若無 ; 則 then 需寫在 if 下一行。第5行為當判斷式為真時,就會執行這一行的. ~/.bashrc_profile (在與.bash_profile同樣的位置裡,執行~/.bashrc),第8行為說明下面指令的功用,第10行為宣告環境變數PATH,該行視為,PATH為環境變數名稱,其值為 $PATH:$HOME/bin ,也就是假設原本PATH已有預設值,我們僅將 $HOME/bin 值在疊加上去,並非完全取代預設值。在接著第12行為將環境變數重輸出,來產生作用。若讀者對各種變數名稱有存何值,可以使用echo指令,如以下
$ echo $PATH                   #   將PATH變數的值列印出來,echo 對往後寫Scripts的除錯很重要

$ echo $HOME                /* 將HOME變數的值列印出來,$開頭的字串代表變數與MS Windows 包再 %%內的字串同。  */

$ set                                   #  列出系統所有環境變數

$ env                                 #  列出已設定的變數名稱與其值。

$ export | grep SHELL    /*  僅列出有關於SHELL字串的行,讓我們得知自己現為哪種Shell下工作  */
--------------------------------------------

     以上既然已得知  ~/.bash_profile 檔案會去調用 ~/.bashrc 檔案的變數值,那我們就利用 cat 指令,再來看一下 ~/.bashrc 檔案內容有那些東西吧,如圖1-29。




























(圖1-29)

     接續圖1-28的操作所在位置,圖1-29第一個指令為利用 cat 指令,列出 .bashrc 檔案內容,可得知,除第1,3,8行為說明行外,有意義的僅if 表達式為第4至6行,僅判斷的目的檔案是否存在,已改為/etc/bashrc。到這裡,相信讀者很快就能整理出bash環境設定的各設定檔的指向:~/.bash_profile -> ~/.bashrc -> /etc/profile
且相信 /etc/profile的設定檔,為各個使用 Bash Shell 的使用者,必定都會匯入的環境變數,當然不能讓每個"個人"的喜好,就隨意更改,所以我們考量安全上,待會,僅會更改最基本的~/.bash_profile 檔案的變數設定,但基於人有無窮的好奇心,我們就來"偷看"一下/etc/profile吧。(圖1-30, 1-31)



(圖1-30)






























(圖1-31)

     WOW! 筆者認為,/etc/profile檔案內容,是很完整的 BASH Shell Script 範本,因為下一章要深入 Shell Script 的撰寫,故筆者在這裡利用圖1-30,1-31內的行數,僅大致說明其內容,第11至22行,我們可以了解到 bash 內自訂函式( function/subroutine ) pathmunge 的宣告方式,第12至21可以了解到分岐式判斷的 case 寫法,第13與第16行出現了外部輸入的預設變數名稱與其值 $1, $2。第25行的 if,利用 -x 判斷/usr/bin/id是否為執行檔,第26行的 if,利用 -z 判斷 $EUID 之值的字串長度是否為零。第28行,就出現利用`id -u`(執行指令 id -u 所產生的結果,指令給變數EUID當值。` `(backquote,通常在鍵盤左上角,Esc鍵下) 包於內的為該指令執行 )。第47行,為命令執行利用轉向子 2> (Angle bracket, 註:2表示標準錯誤輸出(stderr),0表標準輸入(stdin),1表標準輸出(stdout) ),將執行結果丟入系統 /dev/null 空裝置(bit bucket),便不會在螢幕視窗上看到任何訊息。第62與第64行,用 umask 指令設定系統預設需取消那些權限,umask 002 或 umask 022 這三個數字,如 umask 002 數字由左自右代表意義為:
0 代表使用者權限(U)一律准許,若為4,代表不准許使用者讀取權限,若為2,代表不准許使用者寫入權限,若為1,代表不准許使用者執行權限
0 代表群組權限(G)一律准許 ,若為4,代表不准許同群組讀取權限,若為2,代表不准許同群組使用者寫入權限,若為1,代表不准許同群組使用者執行權限
2 代表不准許其他非同群組使用者(O)寫入權限,其他0,4,1 之數字意義,亦同上述。
故 umask 022 亦可推得其意義,為使用者權限一律准許,群組與其他之無寫入權限。接著第67至75行,為for迴圈的宣告方法,而第77與78行的 unset 指令,便是要取消變數所存的值,差異在參數 -f 是為了自訂函數。

     最後,我們趕緊利用指令 vim  ~/.bash_profile來編輯~/.bash_profile,加上自己想要的環境變數吧。如圖1-32,筆者僅更動黃色框的部分,由上而下第一個黃色框加上紅色的路徑,每個路徑以 : 隔開,第二個黃色框,利用alias指令將 cp, rm 等指令擴展,個別直接使用參數 -ru, -rf,新增一個 la 的虛擬指令,來擴展 ls 指令直接使用 -al 參數。除外,並修改命令提示字元環境變數 PS1 換成想要的字串(老話一句,您送丟後)。修改前,建議讀者可以參考指令 echo $PS1 所印出來的預設值,對照並留存。若是不想讓它產生效果的指令,可以用 # 來將之變成說明,便不會執行。若習慣 MS Windows 指令的人,也可以試著玩一玩 alias 把 Linux 指令改成 MS Windows 的樣式,如 alias dir='ls -l' ( ' ' single quote)。附帶一提,若要禁止覆寫變數或檔案內容,可以使用
set -o noclobber
修改回default為
set +o noclobber 
用set可列出已設置的變數(附註: LPIC很愛考)
 




























(圖1-32)

     改完圖1-23的檔案內容後,記得在命列模式使用 w 儲存,建議讀者可以找另一個 Terminal 畫面(若已經開啟的狀態,而尚未使用),執行指令 source  ~/.bash_profile,就可以對剛剛修改的內容,看到馬上產生效果了。筆者為了教學方便,還是回到環境變數的系統預設值,故不變更 PS1 的環境變數值。到目前為止,我們已經學得很多 BASH 下的操作指令,讀者可以自行慢慢回想各種指令的作用,以及指令組合執行,可以得到那些意想不到的效果,再來,就是進入Linux重頭戲之一的下一篇章,Shell Script 程式設計




If you have any feedback or question, please go to my forum to discuss.

這個網誌中的熱門文章

Linux 操作不求人系列 - 貳章之貳 - Shell Script 程式設計(II) - BASH 與 TCSH / CSH

     在上章,我們介紹很多bash shell指令的應用方式,並讓它們變成 script,在這章此節,我們要承襲上節,繼續討論 bash shell script 的其它程式設計概念,與讓程式可重複使用的方法,就是利用函式(function)。      首先,我們來創作一個判斷是否為閏年的函數,script的名稱就取為 check_year.sh ,請自行將其設為可執行。程式碼如圖2-6,為了解說方便,筆者利用指令 nl check_year.sh 將程式碼包含行數印出(圖2-7),其他除顏色外,都與圖2-6同。以下 export 宣告環境變數,自訂變數無需加宣告保留字。(2021.10.07更正export說明,以下自訂變數宣告請直接去除export開頭) (圖2-6) (圖2-7)        圖2-7第2-6行,與之前的範例相似,皆有防堵參數個數輸入錯誤的判斷。第7-11行為接著判斷輸入的年分,是否為真的正整數,也就是大於零的數字。其中第7行可解釋為,利用正規表示式搜尋 $2 字串值得頭至尾部的字元,皆由 0-9 組成,若有,則為真(True)會進入 if 內的陳述執行, 但我們想要的,應該是僅要字串其中一字元為非正整數,便進入if 內的警告並跳出 。故,筆者在判斷式前多加一個 ! ,代表著當字元完全是正整數時,就不要執行  if  內陳述,而直接往第12行執行,但若其中有一個字元為非正整數,則會進入 if 內印出錯誤訊息並跳出 Script 。在此例使用者輸入非正整數等字串(如:12ab、cde、1a1b),便會出現錯誤訊息"Error Value",並跳出 Script 。而第8行的判斷式,效果跟第7行相同,但只能在BASH 3.0才能支援,故筆者故意保留,讓讀者可以學到另一種表示方式。         第12-28行,為宣告一個函式 leapyr () ,在 BASH Script內若要使用含式,必須在使用之前先建立函式的功能,如函式建立在第12-28行,則若要呼叫使用(Call)函式,則必須在第29行之後才能呼叫,並且可重複呼叫。第13行...

Linux操作不求人- 肆章之壹 - 伺服器架設(I) - SSH(SFTP、SCP)、FTP伺服器與遠端連線

@ ssh, sftp      通常安裝好 CentOS6_x64 作業系統後,sshd, ssh daemon 的服務功能是預設開啟的,如筆者的前面篇章所述,預設的 iptables 防火牆設定,亦是開啟讓 ssh 的連線是可通過的,不僅可以連出,也可以被連入。若要確認是否有安裝 sshd 套件以及在啟動時的 runlevel 2 3 5 是否有被載入,可以使用以下指令搜尋: $   rpm  -qa  |   grep  openssh     #  ssh 與 sshd 連線服務皆由 openssh 應用軟體提供。 或使用以下 $   rpm  -qa  |   grep  ssh         #  比用關鍵字 openssh 搜尋更模糊,故符合的條件更多。      如圖4-1可以查詢到有關於 openssh-client 與 openssh-server 的套件, openssh-server 便是提供連入服務的軟體,openssh-client 為提供可以連出的工具。若無以上套件,則使用 yum install openssh ,則可下載安裝。 (圖4-1) 再接著輸入以下指令查詢到 sshd 這個服務,是否有再開機程序內載入,如圖4-2 $ chkconfig | grep ssh   # 查詢 sshd 是否有於 開機 runlevel 啟動 再利用以下指令,來查詢是否防火牆有允許連線 $ iptables  -L  |  grep ssh   # 出現如圖4-2 允許通過之條件 (圖4-2)      接下來,我們要先來調整 sshd 的設定檔,利用 vim  /etc/sshd/sshd_conf ,如圖4-3-1與4-3-2。因為設定...

Linux 操作不求人系列 - 參章之貳 - 系統管理(II) - 新增網路卡與顯示卡

#新增網路卡  @ Driving Ethernet Network Card     現代人若一刻沒網路使用,可能會有焦慮並開始失去人生方向的感覺,故筆者先來說明如何讓CenOS6_x64可以使用網路。開始之前,我們先假設網路為固定式網路,非家用利用PPPoE(https://en.wikipedia.org/wiki/Point-to-point_protocol_over_Ethernet)的ADSL撥接方式,故只要我們 確認網路卡驅動正常 、 設定網路上網參數(如DHCP(https://en.wikipedia.org/wiki/Dynamic_Host_Configuration_Protocol),或是須設定 IP、Netmask、Gateway、DNS ) ,皆符合網路提供者的規定,通常這樣就可以連上網際網路,且網卡為 Intel系列(GT、MT、PT、iXXX等...)的網卡,在驅動程式更是省事,在CentOS6_x64下,通常皆可直接使用驅動成功,但系統預設是不啟動網路。在配合 GNOME 搭配的 NetworkManager 軟體,直接點選Gnome桌面右上 NetworkManager 圖示內的 Connect ( 因筆者的網路已經連線了,故僅顯示Disconnect )即可上網(圖3-14上),若要使用命令列,啟動第一塊網卡路之網路功能,可以輸入指令 ifup eth0 ,若要暫停網路功能,請輸入指令 ifdown eth0 ,其中 eth 為乙太網路硬體代號, 0 為安裝的網路卡硬體裝置順序,如多張網卡,為 eth0、eth1、eth2...  之排序,若想知道網卡對應的排序,可利用指令 dmesg | grep 'eth' ,如圖3-14下,因筆者只有一張虛擬出來的網路卡,故僅為 eth0 。 (圖3-14)       因筆者在 VirtualBox 虛擬裝置執行,故其網路卡裝置已經被虛擬成 Intel PRO MT(圖3-15),所以直接利用DHCP方式即上網,但筆者接著還是要介紹無法順利驅動的網路卡,要如何來驅動,如常見在 PC 主機板上的,RealTek RTL8111B 乙太網路...