新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 詳細說明如何配置嵌入式linux 的nfs開發(fā)環(huán)境

詳細說明如何配置嵌入式linux 的nfs開發(fā)環(huán)境

作者: 時間:2016-09-12 來源:網(wǎng)絡 收藏

(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://www.butianyuan.cn/article/201609/303288.htm

nfs有很多實際應用。下面是比較常見的一些:

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)和硬件無關(guān),可以在不同的計算機或系統(tǒng)上運行。

linux 的開發(fā)過程中,開發(fā)者需要在linux 服務器上進行所有的軟件開發(fā),交叉編譯后,通用FTP 方式將可執(zhí)行文件下載到系統(tǒng)運行,但這種方式不但效率低下,且無法實現(xiàn)在線的調(diào)試。因此,可以通過建操作linux 服務器,同時可以在線對程序進行調(diào)試和修改,大大的方便了軟件的開發(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,指定共享目錄及權(quán)限等。

執(zhí)行如下命令編輯文件/etc/exports:

# vi /etc/exports

在該文件里添加如下內(nèi)容:

/home/work 192.168.0.*(rw,sync,no_root_squash)

然后保存退出。

添加的內(nèi)容表示:允許ip 地址范圍在192.168.0.*的計算機以讀寫的權(quán)限來訪問/home/work 目錄。

/home/work 也稱為服務器輸出共享目錄。

括號內(nèi)的參數(shù)意義描述如下:

rw:讀/寫權(quán)限,只讀權(quán)限的參數(shù)為ro;

sync:數(shù)據(jù)同步寫入內(nèi)存和硬盤,也可以使用async,此時數(shù)據(jù)會先暫存于內(nèi)存中,而不立即寫入硬盤。

no_root_squash:nfs服務器共享目錄用戶的屬性,如果用戶是 root,那么對于這個共享目錄來說就具有 root 的權(quán)限。

接著執(zhí)行如下命令,啟動端口映射:

# /etc/rc.d/init.d/portmap start

最后執(zhí)行如下命令啟動nfs服務,此時nfs會激活守護進程,然后就開始監(jiān)聽 Client 端的請求:

# /etc/rc.d/init.d/nfsstart

用戶也可以重新啟動linux 服務器,自動啟動nfs服務。

在nfs服務器啟動后,還需要檢查linux 服務器的防火墻等設置(一般需要關(guān)閉防火墻服務),確保沒有屏蔽掉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 服務器設置好后,還需要對客戶端進行相關(guān)配置。在配置內(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為嵌入式設備上的本地目錄。

1.jpg

在開發(fā)過程中,來回輸入命令非常煩人,我寫了兩個簡單的腳本來完成nfs的啟動,掛載。



關(guān)鍵詞: NFS Linux 嵌入式

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉