新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 嵌入式Linux開發(fā)環(huán)境的搭建之:嵌入式開發(fā)環(huán)境的搭建

嵌入式Linux開發(fā)環(huán)境的搭建之:嵌入式開發(fā)環(huán)境的搭建

作者: 時(shí)間:2013-09-13 來源:網(wǎng)絡(luò) 收藏


本文引用地址:http://butianyuan.cn/article/257141.htm

接下來,需要?jiǎng)?chuàng)建一些重要文件。首先要?jiǎng)?chuàng)建/etc/inittab和/etc/fstab文件。inittab是Linux啟動(dòng)之后第一個(gè)被訪問的腳本文件,而fstab文件是定義了文件系統(tǒng)的各個(gè)“掛接點(diǎn)”,需要與實(shí)際的系統(tǒng)相配合。接下來要?jiǎng)?chuàng)建用戶和用戶組文件。


以上用busybox構(gòu)造了文件系統(tǒng)的內(nèi)容,下面要?jiǎng)?chuàng)建cramfs文件系統(tǒng)映像文件。制作cramfs映像文件需要用到的工具是mkcramfs。此時(shí)可以采用兩種方法,一種方法是使用我們所構(gòu)建的文件系統(tǒng)(在目錄“/home/david/fs2410/cramfs”中),另一種方法是在已經(jīng)做好的cramfs映像文件的基礎(chǔ)上進(jìn)行適當(dāng)?shù)母膭?dòng)。下面的示例使用第二種方法,因?yàn)檫@個(gè)方法包含了第一種方法的所有步驟(假設(shè)已經(jīng)做好的映像文件名為“fs2410.cramfs”)。


首先用mount命令將映像文件掛載到一個(gè)目錄下,打開該目錄并查看其內(nèi)容。


[root@localhostfs2410]#mkdircramfs

[root@localhostfs2410]#mountfs2410.cramgscramfs–oloop

[root@localhostfs2410]#lscramfs

bindevetchomeliblinuxrcprocQtopiaramdisksbintestshelltmpusrvar


因?yàn)閏ramfs文件系統(tǒng)是只讀的,所以不能在這個(gè)掛載目錄下直接進(jìn)行修改,因此需要將文件系統(tǒng)中的內(nèi)容復(fù)制到另一個(gè)目錄中,具體操作如下所示:


[root@localhostfs2410]#mkdirbackup_cramfs

[root@localhostfs2410]#tarcvfbackup.cramfs.tarcramfs/

[root@localhostfs2410]#mvbackup.cramfs.tarbackup_cramfs/

[root@localhostfs2410]#umountcramfs

[root@localhostfs2410]#cdbackup_cramfs

[root@localhostbackup_cramfs]#tarzvfbackup.cramfs.tar

[root@localhostbackup_cramfs]#rmbackup.cramfs.tar


此時(shí)我們就像用busybox所構(gòu)建的文件系統(tǒng)一樣,可以在backup_cramfs的cramfs子目錄中任意進(jìn)行修改。例如可以添加用戶自己的程序:


[root@localhostfs2410]#cp~/hellobackup_cramfs/cramfs/


在用戶的修改工作結(jié)束之后,用下面的命令可以創(chuàng)建cramfs映像文件:


[root@localhostfs2410]#mkcramfsbackup_cramfs/cramfs/new.cramfs


接下來,就可以將新創(chuàng)建的new.cramfs映像文件燒入到開發(fā)板的相應(yīng)位置了。


2.NFS文件系統(tǒng)

NFS為NetworkFileSystem的簡稱,最早是由Sun公司提出發(fā)展起來的,其目的就是讓不同的機(jī)器、不同的操作系統(tǒng)之間通過網(wǎng)絡(luò)可以彼此共享文件。NFS可以讓不同的主機(jī)通過網(wǎng)絡(luò)將遠(yuǎn)端的NFS服務(wù)器共享出來的文件安裝到自己的系統(tǒng)中,從客戶端看來,使用NFS的遠(yuǎn)端文件就像是使用本地文件一樣。在嵌入式中使用NFS會(huì)使應(yīng)用程序的開發(fā)變得十分方便,并且不用反復(fù)地?zé)龑懹诚裎募?/p>


NFS的使用分為服務(wù)端和客戶端,其中服務(wù)端是提供要共享的文件,而客戶端則通過掛載(“mount”)這一動(dòng)作來實(shí)現(xiàn)對(duì)共享文件的訪問操作。下面主要介紹NFS服務(wù)端的使用。在嵌入式開發(fā)中,通常NFS服務(wù)端在宿主機(jī)上運(yùn)行,而客戶端在目標(biāo)板上運(yùn)行。


NFS服務(wù)端是通過讀入它的配置文件“/etc/exports”來決定所共享的文件目錄的。下面首先講解這個(gè)配置文件的書寫規(guī)范。


在這個(gè)配置文件中,每一行都代表一項(xiàng)要共享的文件目錄以及所指定的客戶端對(duì)它的操作權(quán)限??蛻舳丝梢愿鶕?jù)相應(yīng)的權(quán)限,對(duì)該目錄下的所有目錄文件進(jìn)行訪問。配置文件中每一行的格式如下:


[共享的目錄][客戶端主機(jī)名稱或IP][參數(shù)1,參數(shù)2…]


在這里,主機(jī)名或IP是可供共享的客戶端主機(jī)名或IP,若對(duì)所有的IP都可以訪問,則可用“*”表示。這里的參數(shù)有很多種組合方式,常見的參數(shù)如表5.1所示。


表5.1 常見參數(shù)

選項(xiàng)

參數(shù)含義

rw

可讀寫的權(quán)限

ro

只讀的權(quán)限

no_root_squash

NFS客戶端分享目錄使用者的權(quán)限,即如果客戶端使用的是root用戶,那么對(duì)于這個(gè)共享的目錄而言,該客戶端就具有root的權(quán)限

sync

資料同步寫入到內(nèi)存與硬盤當(dāng)中

async

資料會(huì)先暫存于內(nèi)存當(dāng)中,而非直接寫入硬盤


如在本例中,配置文件“/etc/exports”的代碼如下:


[root@localhostfs]#cat/etc/exports

/root/workplace192.168.1.*(rw,no_root_squash)


在設(shè)定完配置文件之后,需要啟動(dòng)nfs服務(wù)和portmap服務(wù),這里的portmap服務(wù)是允許NFS客戶端查看NFS服務(wù)在用的端口,在它被激活之后,就會(huì)出現(xiàn)一個(gè)端口號(hào)為111的sunRPC(遠(yuǎn)端過程調(diào)用)的服務(wù)。這是NFS服務(wù)中必須實(shí)現(xiàn)的一項(xiàng),因此,也必須把它開啟。如下所示:


[root@localhostfs]#serviceportmapstart

啟動(dòng)portmap:[確定]

[root@localhostfs]#servicenfsstart

啟動(dòng)NFS服務(wù):[確定]

關(guān)掉NFS配額:[確定]

啟動(dòng)NFS守護(hù)進(jìn)程:[確定]

啟動(dòng)NFSmountd:[確定]


可以看到,在啟動(dòng)NFS服務(wù)的時(shí)候啟動(dòng)了mountd進(jìn)程。這是NFS掛載服務(wù),用于處理NFS遞交過來的客戶端請求。另外還會(huì)激活至少兩個(gè)以上的系統(tǒng)守護(hù)進(jìn)程,然后就開始監(jiān)聽客戶端的請求,用“cat/var/log/messages”命令可以查看操作是否成功。這樣,就啟動(dòng)了NFS的服務(wù),另外還有兩個(gè)命令,可以便于使用NFS。


其中一個(gè)是exportfs,它可以重新掃描“/etc/exports”,使用戶在修改了“/etc/exports”配置文件之后不需要每次重啟NFS服務(wù)。其格式為:

linux相關(guān)文章:linux教程




評(píng)論


相關(guān)推薦

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

關(guān)閉