跳到主要內容

Linux 操作不求人系列 - 零章 - 書目說明

從2002接觸 Linux 的學習以來,也約有十幾年的時間,雖算不上是Linux操作高手,但應付一般工作,利用 Linux 做網路管理與伺服器的架設,並非困難之事。Linux的穩定性、擴充性與多樣化的 Open Source 工具軟體,都是操作者或管理者用於完成任務的好幫手。故希望能將自身的Linux學習經驗紀錄下來,也幫助更多人可以了解 Linux 的優點與應用。

Linux 操作不求人系列文章,目錄說明如下
零章之壹 - 講解簡易安裝
壹章之壹 - 簡易X Windows操作 - GNOME
壹章之貳 - 介紹Linux基本架構與檔案分層系統  - FHS
壹章之參 - Terminal下檔案基本文字編輯器操作 - vim
壹章之肆 - 修改個人環境變數 - .bash_profile
貳章之壹 - Shell Scripts 程式設計(I) - BASH
貳章之貳 - Shell Scripts 程式設計(II) - BASH 與 TCSH/CSH
參章之壹 - 系統管理(I) - 帳號與工作管理
參章之貳 - 系統管理(II) - 新增網路卡與顯示卡
參章之參 - 系統管理(III) - 新增磁碟機
參章之肆 - 系統管理(IV) - 新增不斷電裝置與印表機
參章之伍 - 系統管理(V) - 新增其他軟體
參章之陸 - 系統管理(VI) - 網路管理與防火牆
參章之柒 - 系統管理(VII) - 系統紀錄與自訂核心編譯
參章之捌 - 系統管理(VIII) - 系統備份與資料救援
肆章之壹 - 伺服器架設(I) - SSH(SFTP、SCP)、FTP伺服器與遠端連線
肆章之貳 - 伺服器架設(II) - 郵件伺服器 - postfix 與 dovecot
肆章之參 - 伺服器架設(III) - 網頁伺服器(I) - Apache 與 Nginx
肆章之肆 - 伺服器架設(IV) - 網頁伺服器(II) - PHP 與 MySQL/MariaDB
肆章之伍 - 伺服器架設(V) - 檔案服務伺服器 - NFS 與 SAMBA
肆章之陸 - 伺服器架設(VI) - 網路資訊伺服器 - NIS 與 RADIUS
肆章之柒 - 伺服器架設(VII) - 代理與動態主機設定伺服器 - Proxy 與 DHCP
肆章之捌 - 伺服器架設(VIII) - 虛擬私有網路伺服器 - VPN 與 PPPoE
肆章之玖 - 伺服器架設(IX) - 輕量目錄與網域名稱服務 - LDAP 與 DNS Server
伍章之壹 - Generic Mapping Tool (GMT) 繪圖於 Linux 環境下
伍章之貳 - 寫一些好用的Script
伍章之參 - SELinux 管理操作工具
伍章之肆 - 正規表示式(Regular Expression)
伍章之伍 - make 巨集式編譯器
伍章之陸 - Intel PXE 與利用tftp + Kickstart 來自動部署系統
 伍章之柒 - Intel PXE 與利用tftp + Kickstart 來自動部署系統
參考資料與文獻
內容索引
番外篇I - 核心參數逐條釋疑
番外篇II - 使用 LVM 與 SoftRAID(mdadm) 重新安裝系統

未完,待續...
To Be Continued...

這個網誌中的熱門文章

Linux操作不求人 - 伍章之伍 - make 巨集式編譯器

make是Linux下安裝軟體與程式一個相當重要的工具,如前章節所提的安裝軟體三劍客。 configure, make , make install。當我們完成自己所撰寫的C 或 fortran程式,通常會使用編譯器指令 gcc -cgfortran -c 來編譯成連結檔或物件檔函式庫(Library),如 .a (https://en.wikipedia.org/wiki/Static_library) .o .so等附檔名,而此函式庫又可以讓其他程式利用其中的函式與類別。何時要用到動態或靜態函式庫,stackoverflow有專業的回答(https://stackoverflow.com/questions/140061/when-to-use-dynamic-vs-static-libraries)。

假設我們要寫一個簡單的 C 程式,檔名為 hellomake.c,用 make 來編譯我們的程式,程式如下:
#include<stdio.h>
void main ( void )
{
   print ("This is my first c file."\n);
}

---------------------------------------------------
儲存離開後,利用autoscan 指令,便會產生如圖5-70的兩個檔 autoscan.log 與 configure.scan,而 configure.scan 便是需要產生標準的 GNU makefile 的關鍵檔。我們可以把他改成 configure.in 或 configure.ac,並利用 vim configure 來修改參數,如圖5-71,改為圖5-71右邊的參數











(圖5-70)





(圖5-71)


修改完 configure.in 內的參數後,再執行 aclocal 與 autoconf ,就會產生 autom4te.cache 的資料夾與 configure 的執行檔,此執行檔就是先前章節所要編譯原始碼前,會執行的 ./configure ,並會產生適合您的機器環境之 GNU Makefile,如圖5-72


(圖5-72)
接著編輯 Makefile.am 檔的內容,加入如下內容
AUTOMAKE_OPTION=foreign b…

Linux操作不求人 - 肆章之貳 - 伺服器架設(II) - 郵件伺服器 - postfix 與 dovecot

CentOS6_x64 在預設狀態下,通常已經有開啟發 email 的伺服器軟體 postfix,但僅限制在本機(localhost / 127.0.0.1 ) 使用,且僅是讓系統可以傳送錯誤訊息給 root。故我們要經由設定,讓電腦主機內的使用者帳號,皆可以收發 email,而我們用的送信軟體為 postfix,負責 smtp 的部分( https://en.wikipedia.org/wiki/Simple_Mail_Transfer_Protocol ) ,收信軟體則為 dovecot,負責 pop 或 imap ( https://en.wikipedia.org/wiki/Post_Office_Protocol,https://en.wikipedia.org/wiki/Internet_Message_Access_Protocol )的部分,收發信機制的運作機制,可參考wikipedia,https://en.wikipedia.org/wiki/Email,筆者不再贅述,直接說明架設伺服器軟體的操作。先利用 rpm -qa | grep postfix 與 rpm -qa | grep dovecot 來查詢是否已經有安裝,若無,則利用 yum install postfix 與 yum install dovecot 來安裝。除此之外,再利用 chkconfig | grep postfix 與  chkconfig | grep dovecot 來確認是否有在開機時啟動,若想自動化開機啟動,再請設定 chkconfig --level 235 postfix on 與  chkconfig  --level 235 dovecot on 來載入。 如圖4-10與圖4-11:
































(圖4-10)
















(圖4-11)

     接著我們利用 vim 來修改 postfix 設定檔  /etc/postfix/main.cf 。相同地,我們先閱讀設定檔內容前面的說明,postfix 的作者相當細心,每個設定前的說明很詳細,故設定檔很長,請讀者要有耐心閱讀,如圖4-12-1 至 圖4-12-7。往後篇章若設定檔內容太長,筆者便不再列出,會直接說明新增與修改處,在此先說明。




























































































(圖4-12-1)




























































































(圖4-12-2)





























































































(圖4-12-3)





























































































(圖4-12-4…

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)






































(圖4-3-2)
     首先,筆者強烈建議設定前,先閱讀 /etc/ssh/sshd_config 檔案內容前幾行的說明,如之前我們做任何的服務設定前,務必閱讀說明文字。說明告訴我們,若要更動預設參數設定,可以移除符號 # ,並更改後面的參數值。而我們要改動的參數主要為以下幾項: Port   22 /*  一般 ssh 預設的 port 為 22,所以〝你知道、我知道、獨眼龍也知道〞,故建議可以更換預設 p…