Linux無盤工作站的做法

來源:互聯網
上載者:User


一、遠程啟動原理

用戶端在啟動前,既無作業系統,又無啟動的磁碟片或者硬碟,它只有電腦的基本組件: CPU, 記憶體,主板等。但最重要的必須有網卡和啟動的BootRom。客戶機只能通過網路獲得作業系統。Linux的無盤遠程啟動與Novell、WinNT下的無盤啟動技術不一樣,不是採用RPL( Remote Initial Program Loader),而是基於標準的BootP/DHCP和TFTP協議,並通過NFS檔案系統建立檔案系統。相對前兩種,更具有其通用性和適應性。可以基於Linux系統遠程啟動Dos,Win95,WinNT和Linux客戶。

由於自己的網卡(3c905b-tpo100,有BUG,按照etherboot的說明沒修正成功,現在是用磁碟片代替網卡的EPROM,不好多說,還請自己直接到http://sourceforge.net/下載所需要源碼等或者編譯自己所需要源碼.

下面簡單介紹Linux啟動原理:
1.用戶端個人電腦開機後, 在 TCP/IP Bootrom 獲得控制權之前先做自我測試.
2.Bootprom 送出 BOOTP/DHCP 要求而取得 IP.
3.如果伺服器收到個人電腦所送出的要求, 就會送回 BOOTP/DHCP 回應,內容包括用戶端的 IP 位址, 預設網關及開機影像檔案.否則, 伺服器會忽略這個要求.
4.Bootprom 由 TFTP 通訊協議從伺服器下載開機影像檔案。
5.個人電腦通過這個開機影像檔案開機, 這個開機檔案可以只是單純的開機程式也可以是作業系統.
6.開機影像檔案將包含 kernel loader 及壓縮過的 kernel, 此 kernel 將支援NFS root系統。
7.遠程用戶端根據下載的檔案啟動機器.

一切OK!!! 簡單吧!好用吧!下面具體介紹如何建立Linux遠程啟動.

二、遠程啟動執行個體
作為例子定義以下:
Linux 伺服器: server(IP:192.168.0.254)
第一個客戶機:pc01(IP:192.168.0.1)
第二個客戶機:pc02(IP:192.168.0.2)
所有遠程啟動客戶目錄:/client
第一個遠程啟動客戶機目錄:/client/pc01
第二個遠程啟動客戶機目錄:/client/pc02
支援rsh

首先重新編譯Linux核心。
make menuconfig
注意網路的支援,NFS-Root 支援,BootP(DHCP) 的支援必須包括在內。
make clean
make dep
make bzImage
make modules
make modules_install
以上命令之後,你會發現用戶端啟動的影像檔案在 /usr/src/linux/i386/boot 目錄中,編譯出新核心之後,用 mknbi-linux(mknbi-linux bzImage vmlinuz.nb)處理,將vmlinuz.nb 放在/tftpboot下即可。
然後執行以下命令:mknod /dev/nfsroot b 0 255 修改啟動裝置,讓其指向NFSRoot.

下面為遠程客戶機修改伺服器,用於建立遠程客戶機的檔案系統。

在伺服器/etc/exports 中加入:
/client/pc01 192.168.0.1(rw, no_root_squash)
/client/pc02 192.168.0.2(rw, no_root_squash)
/home 192.168.0.1/255.255.255.0(rw,no_root_squash)

使用DHCP,在/etc/dhcpd.conf 加入對遠程客戶的支援,其中server地址是192.168.0.254:
# dhcpd.conf

# Global options
option domain-name "server.ustc.edu.cn";
option domain-name-servers 202.38.64.1;

# Intranet
subnet 192.168.0.0 netmask 255.255.255.0 {
range 192.168.0.1 192.168.0.250;
default-lease-time -1;

# option root-path "/client/pc01";
option dhcp-server-identifier 192.168.0.254;
option broadcast-address 192.168.0.255;
# option routers 198.168.0.254;

server-name "server";
next-server 192.168.0.254;
filename "/boot/vmlinuz";
host pc01{
option root-path "/client/pc01";
hardware ethernet 00:01:02:96:65:92;
fixed-address 192.168.0.1;
}
host pc02{
option root-path "/client/pc02";
hardware ethernet 00:01:02:98:92:55;
fixed-address 192.168.0.2;
}
}
subnet 202.38.64.0 netmask 255.255.255.0 {
}
請參閱:DHCP-Howto

在伺服器上建立遠程客戶機目錄:
/client
/client/pc01
/client/pc02

下面說一下pc01的做法.

pc01目錄下包括:bin,dev,etc,home,lib,mnt,proc,root,sbin,tmp,usr,var目錄。
我們是把bin,dev,etc,lib,sbin,usr,var直接完全複製過來,home,mnt,proc,root,tmp是建立的空目錄,(當時是重新安裝了一個包括DHCP,NFS,RSH等支援的盡量小、盡量乾淨的Linux,然後完全將它們完全複製過來,這樣一來必然有很多不必要的東西可以刪除,可惜現在水平不照,按參考文獻做不成功,只好用了這種省事的法子:(,等以後慢慢刪除不必要的檔案)
注意必須修改/client/pc01/etc/rc.d 開機檔案:改 mount -avt nonfs 為 mount -av.允許使用NFS Root檔案系統。(我們的是Debian Woody,這個檔案變為了/client/pc01/etc/init.d/mountall.sh,並且我們的是mount -a -t noproc,nosmbfs )

以如下格式修改/client/pc01/etc/fstab檔案:
192.168.0.254:/client/pc01 / nfs defaults,rw 0 0
192.168.0.254:/home /home nfs rw,bg 0 0
proc /proc proc defaults 0 0

修改client/pc01/etc/hostname:
pc01

修改client/pc01/etc/hosts:
127.0.0.1 localhost
192.168.0.254 pc00
192.168.0.1 pc01
192.168.0.2 pc02

修改client/pc01/etc/hosts.equiv:
+
server
pc01
pc02

修改client/pc01/etc/mtab:
192.168.0.254:/client/pc01 / nfs rw 0 0
proc /proc proc rw 0 0
devpts /dev/pts devpts rw,gid=5,mode=620 0 0
192.168.0.254:/home /home nfs rw,bg,addr=192.168.0.254 0 0

修改client/pc01/etc/network/interfaces
face eth0 inet static
address 192.168.0.1
netmask 255.255.255.0
network 192.168.0.0
broadcast 192.168.0.255
gateway 192.168.0.254

接下來必須建立一個鏈,將遠程客戶機的IP地址連結到/client/pc01目錄。
$:ln -s pc01 192.168.0.1

做pc02則可以複製pc01過來,並將上述幾個檔案修改一下.

下面在個人目錄下設定rsh支援:
home/username/.rhosts

192.168.0.254 username
192.168.0.1 username
192.168.0.2 username

最後請確認伺服器上的nfsd,tftpd 和 bootpd daemons是否啟動。
一切完事!遠程啟動很快十秒鐘左右就可享用Linux.
關於NFS,TFTP,BOOTP(DHCP)的設定請參閱How-to.

一點經驗之談, 最好把client的所有檔案放在一個獨立分區裡面,這樣就可以在這給分區裡裝上一個基本的系統(就像普通的安裝一樣).然後作為修改的基礎(建議使用Debian,比較易於裁剪). 如果以後需要在用戶端安裝什麼軟體的話,可以這樣做:
chroot /client/pc01
dselect或者apt -get

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.