詳細說明如何配置嵌入式linux 的nfs開發(fā)環(huán)境
NFS(Network File System)即網(wǎng)絡文件系統(tǒng),是FreeBSD支持的文件系統(tǒng)中的一種,它允許網(wǎng)絡中的計算機之間通過TCP/IP網(wǎng)絡共享資源。在nfs的應用中,本地nfs的客戶端應用可以透明地讀寫位于遠端nfs服務器上的文件,就像訪問本地文件一樣。nfs作為一種將遠程主機上的分區(qū)(目錄)經(jīng)網(wǎng)絡掛載到本地系統(tǒng)的一種機制,嵌入式開發(fā)者經(jīng)常需要到。
本文引用地址:http://butianyuan.cn/article/201609/303288.htmnfs有很多實際應用。下面是比較常見的一些:
1. 多個機器共享一臺CDROM或者其他設備。這對于在多臺機器中安裝軟件來說更加便宜跟方便。
2. 在大型網(wǎng)絡中,配置一臺中心 nfs服務器用來放置所有用戶的home目錄可能會帶來便利。這些目錄能被輸出到網(wǎng)絡以便用戶不管在哪臺工作站上登錄,總能得到相同的home目錄。
3. 不同客戶端可在nfs上觀看影視文件,節(jié)省本地空間。
4. 在客戶端完成的工作數(shù)據(jù),可以備份保存到nfs服務器上用戶自己的路徑下。
nfs是運行在應用層的協(xié)議。隨著nfs多年的發(fā)展和改進,nfs既可以用于局域網(wǎng)也可以用于廣域網(wǎng),且與操作系統(tǒng)和硬件無關,可以在不同的計算機或系統(tǒng)上運行。
在嵌入式linux 的開發(fā)過程中,開發(fā)者需要在linux 服務器上進行所有的軟件開發(fā),交叉編譯后,通用FTP 方式將可執(zhí)行文件下載到嵌入式系統(tǒng)運行,但這種方式不但效率低下,且無法實現(xiàn)在線的調試。因此,可以通過建操作linux 服務器,同時可以在線對程序進行調試和修改,大大的方便了軟件的開發(fā)。因此,nfs的是嵌入式linux 開發(fā)的一個重要的組成部分,本部分內(nèi)容將詳細說明如何配置嵌入式linux 的nfs開發(fā)環(huán)境。
嵌入式linux 的nfs開發(fā)環(huán)境的實現(xiàn)包括兩個方面:一是linux 服務器端的nfs服務器支持;二是嵌入式目標系統(tǒng)的nfs客戶端的支持。因此,nfs開發(fā)環(huán)境的建立需要配置linux 服務器端和嵌入式目標系統(tǒng)端。
一、linux 服務器端nfs服務器的配置
以root 身份登陸linux 服務器,編輯/etc 目錄下的共享目錄配置文件exports,指定共享目錄及權限等。
執(zhí)行如下命令編輯文件/etc/exports:
# vi /etc/exports
在該文件里添加如下內(nèi)容:
/home/work 192.168.0.*(rw,sync,no_root_squash)
然后保存退出。
添加的內(nèi)容表示:允許ip 地址范圍在192.168.0.*的計算機以讀寫的權限來訪問/home/work 目錄。
/home/work 也稱為服務器輸出共享目錄。
括號內(nèi)的參數(shù)意義描述如下:
rw:讀/寫權限,只讀權限的參數(shù)為ro;
sync:數(shù)據(jù)同步寫入內(nèi)存和硬盤,也可以使用async,此時數(shù)據(jù)會先暫存于內(nèi)存中,而不立即寫入硬盤。
no_root_squash:nfs服務器共享目錄用戶的屬性,如果用戶是 root,那么對于這個共享目錄來說就具有 root 的權限。
接著執(zhí)行如下命令,啟動端口映射:
# /etc/rc.d/init.d/portmap start
最后執(zhí)行如下命令啟動nfs服務,此時nfs會激活守護進程,然后就開始監(jiān)聽 Client 端的請求:
# /etc/rc.d/init.d/nfsstart
用戶也可以重新啟動linux 服務器,自動啟動nfs服務。
在nfs服務器啟動后,還需要檢查linux 服務器的防火墻等設置(一般需要關閉防火墻服務),確保沒有屏蔽掉nfs使用的端口和允許通信的主機,主要是檢查linux 服務器iptables,ipchains 等選項的設置,以及/etc/hosts.deny,/etc/hosts.allow 文件。
我們首先在linux 服務器上進行nfs服務器的回環(huán)測試,驗證共享目錄是否能夠被訪問。在linux 服務器上運行如下命令:
# mount –t nfs192.168.0.20:/home/work /mnt
# ls /mnt
命令將linux 服務器的nfs輸出共享目錄掛載到/mnt 目錄下,因此,如果nfs正常工作,應該能夠在/mnt 目錄看到/home/work 共享目錄中的內(nèi)容。
二、嵌入式目標系統(tǒng)nfs客戶端的配置
在linux 服務器設置好后,還需要對客戶端進行相關配置。在配置內(nèi)核時選擇Load an Alternate Configuration File輸入配置文件的路徑和文件名添加內(nèi)核對nfs的支持:
選中networking options-》IP:kernel level auloconfiguralion項
選中file systems-》network file systems-》下的root file system on nfs
和nfsfile system support重新編譯內(nèi)核下載bootloader和kernel到開發(fā)板上
在嵌入式目標系統(tǒng)的linux Shell 下,執(zhí)行如下命令來進行nfs共享目錄掛載:
# mkdir /mnt/nfs//建立linux 服務器輸出共享目錄的掛載點;
# mount –t nfs192.168.0.20:/home/work /mnt/nfs–o nolock
# cd /mnt/nfs
# ls
此時,嵌入式目標系統(tǒng)端所顯示的內(nèi)容即為linux 服務器的輸出目錄的內(nèi)容,即linux 服務器的輸出目錄/home/work 通過nfs映射到了嵌入式目標系統(tǒng)的/mnt/nfs目錄。用戶可以用增/刪/修改文件的方式來驗證實際效果。mount 命令中的192.168.0.20 為linux 服務器的IP 地址,/home/work 為linux 服務器端所配置的共享輸出目錄,/mnt/nfs為嵌入式設備上的本地目錄。
在開發(fā)過程中,來回輸入命令非常煩人,我寫了兩個簡單的腳本來完成nfs的啟動,掛載。
評論