Powered by SmartDoc

情報通信ネットワーク論(2002/11/29)
Ver. 1.1

2002年11月29日
栗野 俊一
日本大学 理工学部 数学科
kurino@math.cst.nihon-u.ac.jp
http://edu-gw2.math.cst.nihon-u.ac.jp/~kurino/ccna/index.html
情報通信ネットワーク論2002/11/29 の資料

目次

目的

この演習の目的は通りです。

ftpの利用(新規)
必要なファイルをNetwork経由で取り寄せるためのftpコマンドの使用法を学びます。
LinuxのNetwork設定の保存(新規)
Network設定をviを利用して作成し、起動時に自動的に設定する方法を学びます。
viコマンド( Editor )の簡単な利用法(新規)
Unix系OS ( Linuxを含む)で利用されているviというeditorの基本的な利用法を学びます。
rpmの利用法(新規)
(RedHat系) LinuxでのSoftのInstall方法として、rpmの利用法について触れます。

Linux での設定方法の保存

これまでは、Linuxの設定を毎回、手動で新規に行なって来ましたが、これらの設定は、特定な設定ファイルに保存することによって、電源on時等に、自動的に行なうことができます。

今回の実習では、この様な設定ファイルの変更を行なうことにより、設定を保存することができることを学びます。

実験1: 設定ファイルの確認

まず、Linux PCの電源をいれましょう。そして、実験結果を明確にするために、まず、既存の設定ファイルの存在を確認します。

次のように、lsコマンドを実行しましょう。

Linux-X の Network 設定ファイルの存在確認
[root@Linux-X /root]# ls -al /etc/sysconfig/network-scripts/ifcfg-eth0
-rwxr-xr-x    1 root     root           38 Dec 27  2001 /etc/sysconfig/network-s
cripts/ifcfg-eth0
[root@Linux-X /root]# 

このような表示(1)がされる場合は、既に、設定ファイル( /etc/sysconfig/network-scripts/ifcfg-eth0 )が存在するので、次のようなcatコマンドで、この内容を確認してみましょう

Linux-X の Network 設定の内容の確認
[root@Linux-X /root]# cat /etc/sysconfig/network-scripts/ifcfg-eth0
DEVICE=eth0
IPADDR=192.168.99.1
NETMASK=255.255.255.0
NETWORK=192.168.99.0
BROADCAST=192.168.99.255
ONBOOT=yes
[root@Linux-X /root]# 

この例では、次のような設定になっていることを表しています。

IP Address
192.168.99.1
Netmask
255.255.255.0
Network
192.168.99.0
Broadcast address
192.168.99.25

内容を確認したら、思い切って、次のrmコマンドで、この設定ファイルを削除しましょう。

Linux-X の Network 設定ファイルの削除
[root@Linux-X /root]# rm /etc/sysconfig/network-scripts/ifcfg-eth0
[root@Linux-X /root]# 

削除が終ったら、lsコマンドを使って、本当になくなったかどうかを確認しましょう。

Linux-X の Network 設定ファイルの削除確認
[root@Linux-X /root]# ls -al /etc/sysconfig/network-scripts/ifcfg-eth0
ls: /etc/sysconfig/network-scripts/ifcfg-eth0: No such file or directory
[root@Linux-X /root]# 

もちろん、最初から設定ファイルが無かった場合も、この結果と同じになります。

次にNetwork CardをPCMCIA Slotに挿入し、ifconfigを利用して、Network interface eth0に何も設定されていないことを確認(2)してください。

Linux-X の eth0 の設定
[root@Linux-X /root]# ifconfig eth0
eth0      Link encap:Ethernet  HWaddr 00:D0:68:00:02:32  
          UP BROADCAST RUNNING  MTU:1500  Metric:1
          RX packets:137743 errors:0 dropped:0 overruns:0 frame:1
          TX packets:110621 errors:5 dropped:0 overruns:0 carrier:1
          collisions:19704 txqueuelen:100 
          Interrupt:5 Base address:0xd000 
[root@Linux-X /root]# 

そして、最後に、ケーブルを既存のNetworkに接続し、dhcpcd (または、dhcpclient )コマンドを実行し、DHCP経由で、IP Addressが取得されることを確認してください。

Linux-X の Network 接続
[root@Linux-X /root]# dhcpcd
[root@Linux-X /root]# ifconfig eth0
eth0      Link encap:Ethernet  HWaddr 00:D0:68:00:02:32  
          inet addr:168.254.1.43  Bcast:168.254.255.255  Mask:255.255.0.0
          UP BROADCAST RUNNING  MTU:1500  Metric:1
          RX packets:140922 errors:0 dropped:0 overruns:0 frame:1
          TX packets:112763 errors:5 dropped:0 overruns:0 carrier:1
          collisions:19836 txqueuelen:100 
          Interrupt:5 Base address:0xd000 
[root@Linux-X /root]# 

上記の例では、168.254.1.43というip addressが取得できています。

  1. もちろん、サイズや日時はこれとは異なるかもしれません。逆に、存在しない場合の表示は、この後に述べられます。
  2. Network Cardが認識されていなかった場合は、cardctl insertとしましょう。

実験2: anonymous ftp を利用する

次に、設定ファイルを利用して、Linux PCの設定を行ないますが、いきなり設定ファイルを作成するのは大変なので、既存の設定ファイルを転用します。

その設定ファイルをftpコマンドを利用して、取得します。

まず、ftpコマンドを利用して、ftpサーバと接続します。

するとNameとPasswordを要求されますので、Nameには、ftpを、Passwordは、礼儀のため(3)に、自分のe-mail addressを入力しましょう(4)

ftp 接続
[root@Linux-X /root]# ftp 192.168.3.15
Connected to 192.168.3.15 (192.168.3.15).
220 h31.private.media.cst.nihon-u.ac.jp FTP server (Version wu-2.6.1-18) ready.
Name (192.168.3.15:root): ftp
331 Guest login ok, send your complete e-mail address as password.
Password:
230 Guest login ok, access restrictions apply.
Remote system type is UNIX.
Using binary mode to transfer files.
ftp>

接続に失敗したら、一旦、quitコマンドで、ftpを終了し、もう一度、やり直して下さい。

ftp接続に成功したら、早速、設定ファイルを取り寄せましょう。

まず、おまじないのbinコマンドを実行します。そして、ファイルのある場所に移動するためにcdコマンドを実行します。次に、最初の設定ファイルであるifcfg-eth0.DHCPというファイルがあるかどうかlsコマンドで確認します。

設定ファイルの確認
ftp> bin
200 Type set to I.
ftp> cd pub
250 CWD command successful.
ftp> ls ifcfg*
227 Entering Passive Mode (127,0,0,1,52,113)
150 Opening ASCII mode data connection for directory listing.
-rwxr-xr-x   1 root     50             38 Nov 28 18:53 ifcfg-eth0
-rw-r--r--   1 root     50            111 Nov 28 18:57 ifcfg-eth0.192.168.99.1
-rwxr-xr-x   1 root     50             38 Nov 28 18:56 ifcfg-eth0.DHCP
226 Transfer complete.
ftp>

みつかったら、早速getコマンドを利用して取り寄せます。

設定ファイルの取り寄せ
ftp> get ifcfg-eth0.DHCP
local: ifcfg-eth0.DHCP remote: ifcfg-eth0.DHCP
227 Entering Passive Mode (127,0,0,1,182,28)
150 Opening BINARY mode data connection for ifcfg-eth0.DHCP (38 bytes).
226 Transfer complete.
38 bytes received in 0.00857 secs (4.3 Kbytes/sec)
ftp>

取り寄せに、成功したら、quitで、ftpを終了し、再度、本当にとれているかをlsコマンドで確認しましょう。

設定ファイルの取り寄せの確認
ftp> quit
221-You have transferred 38 bytes in 1 files.
221-Total traffic for this session was 1292 bytes in 1 transfers.
221 Thank you for using the FTP service on h31.private.media.cst.nihon-u.ac.jp.
[root@Linux-X /root]# ls -l ifcfg-eth0.DHCP
-rw-r--r--    1 root     root           38 11 29 05:15 ifcfg-eth0.DHCP
[root@Linux-X /root]# 

この設定ファイルは、DHCPを利用して、Network Cardを動的に自動設定を行ないます。一応、catコマンドで、内容を確認してみましょう。

DHCP での設定
[root@Linux-X /root]# cat ifcfg-eth0.DHCP
DEVICE=eth0
ONBOOT=yes
BOOTPROTO=dhcp
[root@Linux-X /root]# 

これで、内容は問題ないのですが、これがちゃんと設定ファイルとして、働くには、この内容が、実験1で触れたように/etc/sysconfig/network-scripts/ifcfg-eth0に入っていなければなりません。そこで、cpコマンドを利用して、このDHCPを利用する設定を、/etc/sysconfig/network-scripts/ifcfg-eth0に書き込みます。

設定ファイルのコピー
[root@Linux-X /root]# cp ifcfg-eth0.DHCP /etc/sysconfig/network-scripts/ifcfg-eth0
[root@Linux-X /root]# 

これで、DHCP Serverを利用して、自動的にIP Addressを取る設定が可能になったので、早速、rebootして、確認してみましょう。

reboot
[root@Linux-X /root]# shutdown -r now

Linux起動後loginしなおして、確かに、ip addressを取得していることを確認してみてください。

  1. 実は、ほとんどの場合、何をいれても構いません。稀に、ちゃんとe-mail addressのように見えるものをいれないと、弾かれることもありますが...。
  2. エコーバック(自分の入力されたものが、そのまま画面に表示されること.. )されないので、間違える可能性もありますが、全注で触れた通り、本来は何をいれてもかまわないので、あまり気にする必要はありません。

実験3: 別の設定ファイルを利用してみる

今度は、実験2と同様にして、ifcfg-eth0.192.168.99.1を入手し、それを設定ファイルとして設定してみましょう。

そして、rebootする(5)と、確かにeth0に192.168.99.1が設定されることも確認してください。

  1. DHCP経由でないことを確認するためにも、また、同じip addressを持つHostが同じNetwork内に存在して、Networkを混乱させないためにも、この設定でのreboot時は、ケーブルを抜いてから、試してみてください。

実験4: ifup/ifdown コマンドの利用

実験3では、設定が、電源off後も有効である( rebootしても設定が生き残る)ことを確認するためにrebootを繰り返しましたが、実際は、rebootしなくても、設定の内容を変更した後に、その変更を反映させることが可能です。

そのためのコマンドがifup/ifdownコマンドです。

再び、設定をDHCP経由で入手できるようにするために、次のようにコマンドを実行してみてください。

なお、ifdown後にケーブルをつなぎましょう。

設定変更の反映
[root@Linux-X /root]# cp ifcfg-eth0.DHCP /etc/sysconfig/network-scripts/ifcfg-eth0
[root@Linux-X /root]# ifdown eth0
[root@Linux-X /root]# ifup eth0

そして、確かに、設定が変更されていることを確認しましょう。

実験5: vi コマンド ( Editor ) の簡単な利用法

このままでは、あらかじめ決められた内容にしか変更できません。できれば、直接設定ファイルの内容が変更したいものです。

このために、利用するコマンドがファイル編集コマンドviです。

viコマンドは、起動時に、編集対象とするファイルの名前を指定します。すると、そのファイルの内容が表示されます。

この状態で、h [左], j [下], k [上], l [右]のキーを押すと、それぞれの方向にカーソルが移動します。

この状態で、x [文字削除]を押すと、カーソルのある場所の文字が消えます。

また、i [挿入]を押し、追加したい文字を入力後にESCキーを押すと、文字を追加することが可能です。

なお、最後にZZ [終了]を押せば(6)viを終了することができます。

また、同時変更内容を反映させることができます。

なお、編集内容をキャンセルして、終了するには、:q!の三文字を入力後[Enter]キーを入力します。

実際に、viを起動し、IP Addressの設定を変更し、更に、ifup/ifdownを利用して、その設定が、実際に反映されることを確認しましょう。

vi の起動
[root@Linux-X /root]# vi /etc/sysconfig/network-scripts/ifcfg-eth0
  1. これは、大文字のZを続けて二回押すってことです。

実験6: DHCP Server を作ろう

DHCP Serverは、DHCP ( Dynamic Host Configration Protocol :動的なホストの設定手順)を利用して、Client Hostに、Netowrk設定に必要な情報を提供するServiceを行なうServerです。

Network Server の構築手順

DHCP ServerのようなNetwork Serverを構築する手順は、既に、Network設定の終ったLinux PCがあれば、ほぼ、次のような感じになります。

入手

Serverは、特殊なProgram ( Server Program )が動いているHostというだけです。

これが、あらかじめHost上に用意されていれば、問題ありませんが、そうでなければ、ftp等を利用して、Network経由で、入手します。

Install

Serverは、Linux上のServer Program ( Server Software )として実現されています。したがって、そのProgram ( Soft )を、まず、Linux PCに、Installする必要があります。

RedHat系のLinuxでは、そのために、rpm形式のファイルが提供されており、rpmコマンドを実行することにより、簡単にinstallできます。

Configuration

Serverは、どれも同じ機能を持ちますが、どれも同じ振舞をさせるわけではありません。むしろ、そのServerが設置されているNetworkによって、異なる振舞が要求されるのが普通(7)です。

その振舞を変更するには、そのServer Programに対応した、設定ファイルを、望みの振舞になるように作成する必要があります。

この作業は、やはり、vi等を利用して、行ないますが、ほとんどの場合は、一から作成するのではなく、あらかじめ用意されている雛型ファイルに自分なりの変更を行なうことで、実現できます。

Statrup

InstallとConfigurationができたら、後は、Serviceを開始するだけです。

RedHat系では、開始や終了にも、一応の規則がありますので、その規則を学びましょう。

  1. その意味で、routedは特殊なServerと言えるでしょう。

DHCP Server Program の入手

まずは、DHCP Server Programを入手しましょう。方法は、ifcfg-eth0と全く同じです。

違いは、入手するファイルの名前でけで、その名前は、dhcp-2.0-4.i386.rpmです。

DHCP Server Program の Install

rpmファイルが入手できれば、それのInstallはrpmコマンドで簡単に実行できます。

rpm コマンドの実行
[root@Linux-X /root]# rpm -Uhv dhcp-2.0-4.i386.rpm
#############################################
[root@Linux-X /root]# 

なお、既に、install済の場合は、Errorになりますので、あらかじめ、installされているかどうかを確認することもでいます。

install 済の package 検索
[root@Linux-X /root]# rpm -qa | grep dhcp-
dhcp-2.0-4
[root@Linux-X /root]# 

また、古い版のものが入っている場合は、(自動的に上書き[update]されますが敢えて行なうなら.. )次のようにして、削除することも可能です。

package の uninstall
[root@Linux-X /root]# rpm -e dhcp-2.0-4
[root@Linux-X /root]# 

DHCP Server Configuration

このDHCP Server Program(8)の設定ファイルは、/etc/dhcpd.confであり、また、これとdhcpd.leasesの二つが必要です。

本来ならば、/etc/dhcpd.confの作成方法を説明するところですが、今回は、ftp server上にあるdhcpd.confをそのまま利用しましょう。

rpmファイルと同様ftpで入手し、cpコマンドで上書きします。

  1. つまり、DHCP Server Programにもいろいろあり、そのProgramによって、設定方法等も異なるということに注意しよう。

dhcpd.leases の作成

dhcpd.leasesは、DHCP Serverが、どのIP Addressを割り当てているかの記録を残すためのファイルです。DHCP Serverが何らかの理由で、再始動するときに、過去の履歴を、このdhcpd.leasesによって確認することができます。

始めて、dhcpdを起動する場合は、当然、過去の履歴はないので、このファイルは空っぽで構いません。

そこで、次のtouchコマンドで、空のdhcpd.leasesを作成します。

空の dhcpd.leases の作成
[root@Linux-X /root]# touch /var/state/dhcp/dhcpd.leases
[root@Linux-X /root]# 

DHCP Server の startup

dhcpのstartupは、/etc/rc.d/init.d/dhcpd startでおこないます。また、そのshutdownは、/etc/rc.d/init.d/dhcpd stopでおこないます。

dhcpd の開始
[root@Linux-X /root]#  /etc/rc.d/init.d/dhcpd start

DHCP Server の動作確認

DHCP ServerとDHCP ClinetからなるNetworkを一つ作り、DHCP Clinetが、DHCP Serverから確かに、IP Address等を得ることができることを確認しなさい。


	   DHCP	Server
		|
	>-------+---------------+------------------<
				|
			   DHCP	Client
			   (ie. Windows-PC)

また、dhcpd.leasesの内容を確認し、割り当てがうまくいっていることを確認しましょう。

dhcpd.leases の内容の確認
[root@Linux-X /root]# cat /var/state/dhcp/dhcpd.leases