跳到主要內容

Linux 操作不求人系列 - 壹章之貳 - 進入Linux操作環境(II) - Linux FHS

     承上一節,為方便教學,我們先開啟四個Terminal,如圖(1-11)(註2021現在也可以藉由安裝tmux軟體來切割Terminal),這樣的好處,就是可以在其中一個Terminal執行命令後,等待的時間(如複製大量資料),我們還可以對其他沒有執行命令的Terminal下命令,這樣一來,就可以達到真正多工(multi-tasking)的操作目的,讀者可注意到右下角兩個虛擬工作桌面(以下簡稱workspace),左邊的已經被我們開啟四個Terminal,所以讀者可以點一下右邊的workspace,並一樣開啟Terminal來玩玩,這對於抄寫編碼、指令查詢或文件對照改錯等等的方便性有相當大的助益,且現在同時可以讓 8 個( 2 x 4 ) Terminals執行命令,也是可以提高工作的效率,除了多工狀態的穩定,這也是Linux環境下工作的優勢之一。除此之外,讀者亦可試著利用鍵盤Ctrl+Alt+F[1-7](註:Ctrl+Alt 搭配 F1 到 F7 會進入不同的 tty 環境,http://tldp.org/HOWTO/Text-Terminal-HOWTO-7.html),來切換其他的 Terminal 與 X  Windows 的工作環境,這些方式,也是當命令執行造成系統緩慢時,或某一個 Terminal 狀態下,命令執行時產生凍結,來對其拯救並回春系統的好工具。






























(圖1-11)

     接下來,筆者還是需介紹 Linux Shell(http://www.programering.com/a/MDMyQTNwATE.html)概念,與 Linux 系統的基本架構,如圖1-12。電腦硬體資源(Computer Resource/Hardware)為最基本的需求,Linux Kernel 需建立在其上,且依硬體效能而有不同的效能表現。再來需建立一個可供各軟體資源使用與置放的檔案系統(File System),可能為 ext3ext4xfs、或 btrfs 等格式(關於檔案系統比較,可參考https://en.wikipedia.org/wiki/Comparison_of_file_systems),就如同 MS Windows下,需要給定 NTFS 當預設的檔案系統。在外圍的 Linux Shell 的操作,便依附於 Kernel之上,而我們就是在 Shell 內工作,可以使用X Windows、文書處理、使用工具軟體,開發軟體等,並不會影響到 Kernel 的運作,但 Kernel 的穩定性,會影響 File System、 ShellApplication Software
























(圖1-12,修改自http://www.programering.com/a/MDMyQTNwATE.html)


     我們先將其中一個 Terminal 獨立出來看,如圖1-13黃色框處,可以看到等待命令的提示字元為 [newuser@localhost Desktop],如 MS Windows 的命令列模式 C:\>,Shell的命令提示字元為環境變數,這是可以自己更改的,因為系統一般預設在 BASH(Bourne Again Shell) 的環境下,故這些環境變數存在於以下並可以繼承變數數值。
/etc/profile
/etc/bashrc
/home/.bashrc
(若習慣使用C Shell(csh)的讀者,以上 bashrc 部分便改為 tcshrc,因 csh 已經被改成 tcsh,註:/bin/csh 軟連結指向至 /bin/tcsh ,如圖1-14,關於 csh 的說明,可參考https://en.wikipedia.org/wiki/C_shell)





























(圖1-13)




(圖1-14)

     圖1-14第一個命令提示字元內輸入指令 ls -l /bin/t 按鍵盤 Tab 鍵兩次(如果只有一個相關檔,則僅按一次便會補齊所鍵入的檔名),不需按 Enter 鍵,便會出現下方的搜尋 /bin/t 開頭字母的檔案共有那些項目,可以看到包含 tcsh ,第二個指令,用同方法,換成搜尋 /bin/c 開頭的字母的檔案項目,可以看到也有 csh ,這時利用第三個指令 ls -l /bin/csh ,按下 Enter鍵執行後,可知/bin/csh其實是指向tcsh這個檔案,也是僅有執行 tcsh 這檔案,而 /bin/csh 所用的方式,在Linux下,便稱為軟(符號)連結,為利用指令 ln -s  /bin/tcsh /bin/csh 來達成,在 Linux 下查詢指令各項參數的用法為在命令提示字元下輸入man [指令](man指令與要查詢的指令記得要空格,Linux下各種指令與後面要接上的參數或輸入輸出之間,皆須要空格),往後利用文字舉例之提示字元,皆表示為僅 $ 字元,說明字元為 # (sharp),表示在 # 字元的後方單行文字皆為說明文字,若為多行說明文字,則利用 /* 說明文字 */ 此種常用的說明方式表示。指令打完皆須按 Enter鍵,才能執行,Tab鍵通常是用來作即時查詢檔名,便不需搭配 Enter鍵,在此先敘明,如:
-----------------------------------------------------
$ man ls    # 查詢 ls 指令的參數與用法
$ man ln   /*  查詢 ln 指令的參數與用法,
  並試著操作其他檔名看看  */
$clear       # 試著把正使用的Terminal畫面清理乾淨
--------------------------------------------------------

     圖1-14 第三個指令所列出的結果,可以看到此檔案(符號連結)的屬性,我們可將結果放大並分成七個部份挑重點來說明,如圖1-15。



(圖1-15)

     第一部分,為在 Linux 下的檔案屬性,利用十個字元表示,筆者將其分類成ABCD四個部分來說明(圖1-15)。A為檔案的樣態,一般常見符號連結便顯示 l(link),Terminal下檔名著色成洋青色,若為檔案,則為顯示基本 - (hyphen),Terminal下可執行的檔名著色為綠色,若為資料夾,則顯示d(directory),檔名著色成藍色。B為擁有者(user)的權限,擁有者為何,顯示第三部分,代表此檔案擁有者為root。r代表可讀取,w代表可寫入,x代表可執行(註:若是s代表SUID,s在C區則代表SGID,SUID與SGID代表檔案使用時,暫時使用檔案擁有者或是擁有群組的權限),沒有開啟權限則顯示 - ,在CD部分之rwx代表的意義亦同,僅差別C部分代表群組(group)的權限,C部分代表其他群組(other group,在此例,就是除root群組以外的群組)的權限,而群組名稱為何,顯示在第四部份,群組名稱亦為root。第五部分為檔案大小,單位為bytes,第六部分為檔案最後修改日期,若距離修改時間太久,僅會顯示年分。第七部分為檔案的路徑與名稱





























(圖1-16)

     通常檔案的位置,包含著檔案的路徑與檔案的名稱,而如圖1-15列出的檔案,可知道檔案絕對路徑為/bin/下的檔名tcsh,而在 Linux 下,所有檔案絕對路徑,皆是從/(root),開始算起。
Linux各預設路徑的分配,詳細可參考Wikipeida: https://en.wikipedia.org/wiki/Filesystem_Hierarchy_Standard
筆者僅說明一般常用重點資料夾,從圖1-16第五個指令所顯示的結果,逐行從左到右
/bin       #為儲存所有使用帳號都能使用的指令或執行檔
/etc        #為系統設定的參數設定檔案放置處,若為系統管理者,必須熟稔。
/opt       #可以放置自行安裝的程式,如 Intel Fortran Compiler很喜歡叫安裝者放這裡
/var       #主要放置可以共用的伺服器軟體服務資料檔案(如Apache的網頁服務),或系統紀錄等
/boot     #主要啟動區,放置開啟需要的檔案
/home   #這是使用帳號個人資料夾區,人生的前途可能都存在這裡了。
/dev       /* 應體資源設施,都存放在這裡,如SATA硬碟或USB隨身碟便為/dev/sd,如有好幾顆,sd後面以英文字表示,如sda,sdb,...,遵照裝置插入的順序。 */
/media   /* 通常在圖形介面中,掛載(mount)外接USB的裝置大都放這裡,讀者也可以自己手動掛載到 /mnt  */
/root      #這是root帳號的預設存放資料區,root的人生也可能都在這了。
/usr       /* 此資料夾下,一般放置使用者帳號自定義的執行檔或安裝軟體,如/usr/local/bin,但其實實務上來說,丟系您用ㄟ送丟後。  */

     圖1-16第一個指令為 pwd ,此指令可以列出現在的工作目錄(Print Working Directory),主要讓讀者可以知道自己正位處哪個路徑(PATH)下,以確認絕對路徑,接著第二個指令為 cd / ,便是改變資料夾(Change Directory)到 / ,所以再第三個指令輸入pwd,它就顯示 / ,無庸置疑。接著輸入第四個指令 df -h,便可以列出我們磁碟使用與剩餘空間(Disk Free),與分別掛載的位置,詳細可參考man df,了解 -h 參數與其他參數的用法,甚或可搭配指令 lsblk 來瞭解硬碟分割狀態,與分割的格式。那如果要了解單一的資料夾所占用的檔案大小呢?那就是用 du -sh,如圖1-17第三個指令 du (Disk Usage) ,若對du參數想詳細了解的讀者,同樣可以參閱 man du 的說明文件,在 Linux下,裡用 - (hyphen)的參數是可以是可以一直疊加上去,如du -sh -sh 便代表著 -s (summarize,資料夾下所有資料大小數值合併計算)和 -h (human-readable,顯示出人類看得懂的表示方式)同時發生作用,故結果僅顯示出4.0K,等同於4*1024Bytes = 4*1024*8 bits(乘出來太長,人類可能看不太懂了...)。



(圖1-17)

     圖1-17第 1 個指令為 cd ~ ,而參數 ~ (鍵盤按鍵常出現在Esc鍵下方)便是使用者帳號的家目錄縮寫(原本應該為變數${HOME},該變數為環境變數之一,在 Linux Shell 下變數大多為 $ 開頭,在後面接上變數名稱,而 MS Windows 是將變數名稱包在%%裡面,如%HomePath%),第 2 個指令 pwd 顯示結果為/home/newuser,表現在位置的絕對路徑,第 3 個指令 du -sh Desktop,便是利用相對路徑的觀念,來獲得/home/newuser/Desktop的大小,亦可以下du -sh ./Desktop,在 Linux下,. (dot)代表著現在位置下,但若 . 後接上檔案名,那該檔案在 Linux環境下,便為隱藏檔案或資料夾,如 .bashrc,要顯示隱藏檔,必須用指令 ls (list) 加參數 -a 才能顯示,如下:
$ ls -al  ~    #詳列出使用者家目錄下所有(含隱藏)檔案與資料夾。
若為 .. (double dot),則代表著上層的位置,如第 4 個指令,將位置進入到 Desktop 資料夾,如第 5 個指令所顯示之結果。若讀者再自行輸入cd ..,再輸入pwd,便可知,又回到了 /home/newuser。
接著第 6 個指令為利用 touch,新增一個新檔案,指令 touch 亦可用來變更檔案日期(有興趣讀者可以利用指令 man touch 查詢)。第 7 個指令,列出所產生出的檔案權限與日期。第 8 個指令為利用 mkdir,新增一個新資料夾
$ touch myfirstfile      #新增一個檔案,檔案名稱為myfirstfile
$ mkdir myfirstfolder   #新增一個新資料夾,檔案名稱為myfirstfolder

     第 9 個指令為利用 ls,來列出我們剛剛操作的結果,可以看到 ~/Desktop 下,出現了剛剛新增的檔案與資料夾。若讀者想要回去找找之前輸入過那些指令,亦可在提示字元$ 後,利用鍵盤上下鍵,來尋找先前所循序輸入的指令。那我們要如何去對檔案或資料夾作編輯、刪除、與改變屬性(如可以執行)呢?

就讓我們繼續看下去 ~



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

這個網誌中的熱門文章

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。因為設定檔參數很多,筆者為方便說明,將 /etc/sshd/sshd_conf 檔案內容分成兩張圖。 (圖4-3-1)

Linux 操作不求人系列 - 貳章之壹 - Shell Script 程式設計(I) - BASH

     本章開始進入Shell Scripts的程式設計,因為Linux Shell的種類相當多,故筆者僅挑選預設的Bash Shell 及 學術界常會使用的 C Shell (/bin/tcsh )來說明與對照,在此先說明。至於 Scripts 的概念,在前章就已經說明過,可視為前壹章的各項指令之組合,在令其在執行檔案裡,依序執行,如前章所看到的 /etc/profile 檔案,在其他軟體上,有點類似巨集(macro)的執行檔,或是MS Windows的批次檔(Batch)。先建立此概念後,我們可以先在Terminal的命令提示字元,使用 for 指令,如圖2-1,在 shell scripts 內為了重複做一件事,而僅修改某些變數值,我們會利用所謂的迴圈(loop)方式來完成,而 bash shell 內常用的是 for 或是 tcsh/csh shell 內的 foreach 。 (圖2-1)      圖 2-1第一個指令輸入 for 的宣告,後面接著 seq 為變數名稱,為了逐次接收  in 後面之陣列值(http://www.gnu.org/software/bash/manual/html_node/Arrays.html)(註:若加了  ; 則 do 便可寫在同一行),接著 > 的提示字元的等待輸入,便是還沒遇到 done 指令來結束 do 的動作,控制此提示字元的環境變數為 PS2 。,此例的 seq 值,依序為第一次讀入 first 字串並存入變數 seq 當其值,接著second、third,從 echo $seq 可以看出,接著設定一個變數 file 其值為 my開頭字串,緊接變數值 $seq(first、second、third),再接固定的 script.sh 字串,接著利用echo指令,印出變數值$file,檢查是不是我們預期的字串值(註:如果想要暫停,讓使用者可以看清楚再繼續,可以加上指令sleep 3,表示畫面停止三秒鐘),接著利用 touch 指令產生 $file 字串值的檔案,再將其利用 chmod 指令, u+x 參數為令僅創立此檔的使用者帳號可執行(若要改為同群組可執行,參數需改為 g+x )。故可看到第二個指令輸入 ls ,便列出自動批次

Linux操作不求人 - 伍章之陸 - Intel PXE 與利用 tftp + anaconda kickstart來自動部署系統

     現代的個人電腦與筆電爲了節能省碳,往往皆省略了光碟機的設置。雖然說 USB隨身碟亦可應用於安裝作業系統,但若遇到機房的大量機器需安裝之問題,亦不適合此種用光碟片或隨身碟逐臺安裝的方式,或是需準備多片光碟或隨身碟。故爲了大量安裝與部屬 Linux作業系統的機器,我們便可透過具有PXE功能之網路卡(https://en.wikipedia.org/wiki/Preboot_Execution_Environment),其所具備的網路開機的能力,來作透過網路方式來安裝與大量部署 CentOS Linux作業系統。其原理 wikipedia  的PXE說明,都解釋得很清楚,筆者不需要再 " 掉書包 ",在開發者大神面前班門弄斧,我們就直接來做做看。      首先,我們一樣透過 yum來安裝所需的 tftp伺服器軟體(http://www.jounin.net/tftpd32.html),利用PXE支援 tftp 透過 udp 埠號 69連線,來提供檔案的能力,給利用 PXE開機後安裝作業系統的機器,圖5-60   (圖5-60) 接著修改 tftp 設定檔 /etc/xinetd.d/tftp,如圖5-61,請記得 disable  要改為 no (圖5-61)      若要修改 server_args 參數為自訂的 tftp root 路徑,記得要變更 SELinux 的權限設定,如要改為/tftpboot,則使用指令 chcon  來調整,如以下: $ mkdir /tftpboot $ chcon  --reference /var/lib/tftpboot  /tftpboot 接著將 xinetd 與 tftp 加入開機啟動,並重啟動 xinetd,如下: $ chkconfig  --level  235  xinetd on $ chkconfig  --level  235  tftp  on $ service xinetd restart 開放防火牆通行 $ iptables -A INPUT -p udp --dport 69 -j ACCEPT $ service iptables re