はじめに
前回に引き続き、1台のMacのPC上でLinux(Ubuntu)の仮想環境を構築し、Ubuntuを使ってネットワークのルーティングについて学んでいきます。WindowsのPC上でLinux(Ubuntu)の仮想環境を構築してもOKです。
今回は、ルータ2台を介した別セグメント間(ネットワークが違うホスト機器同士)の通信について、ルーティング設定を行いつつ動作確認していきたいと思います。
今回も、こちらの本を読んで勉強した内容を紹介しています。
Ubuntuの環境構築
前回と同様に、Ubuntuの環境を用意しましょう。MacでのUbuntuの環境構築についてはこちらの記事に書きましたので、参照してみてください。
動作環境
- M1 Mac Book Pro
- MultipassというツールでUbuntu仮想環境構築
- Ubuntu 20.04
実験ネットワークの構成
以下のネットワーク構成で、computer1からcomputer2にpingを送り疎通を取れるようにします。
ホスト機器の間にルータを2台介したネットワーク構成になっています。この場合、ホスト機器だけでなく、ルータにもルーティング設定が必要となります。
実験準備
- ターミナルを5つ開き、それぞれでUbuntu仮想環境にログインしておく
- それぞれ、terminal-computer1, tarminal-router1, terminal-router2, terminal-computer2, terminal-ubuntuと呼ぶ事にする
Network Namespaceについて
前回と同様、1つのUbuntu仮想環境を用意し、その仮想環境の中にネットワークを作って実験を行います。
Linuxの中に壊しても大丈夫なネットワークが簡単に作れる環境を、Dockerなどで利用されている技術である、Network Namespaceによって実現します。
Network Namespaceは、複数の機器やネットワークをコンピュータの中に仮想的に用意し、ネットワークのシミュレーションを行う事ができるもの、とここでは考えておきましょう。
Network Namespaceの作成
まず、Network Namespaceを作成します。上で説明したネットワーク構成図の通りに機器を準備します。以下のコマンドを実行してください。
# terminal-ubuntuで実行
sudo ip netns add computer1
sudo ip netns add router1
sudo ip netns add router2
sudo ip netns add computer2
Network Namespaceのシェルを起動
作成したそれぞれの機器を操作するために、シェルを起動しましょう。
残り4つのターミナルを使い、以下のコマンドでNetwork Namespaceのシェルを起動します。
# terminal-computer1で実行
sudo ip netns exec computer1 bash
# terminal-router1で実行
sudo ip netns exec router1 bash
# terminal-router2で実行
sudo ip netns exec router2 bash
# terminal-computer2で実行
sudo ip netns exec computer2 bash
ここまでで、上で説明したネットワーク構成図の通りに機器を準備しました。
Network Namespace同士を繋ぐIFを作成
Network Namespace同士をつなぐvethインターフェイス(≒仮想LANケーブル)を作成します。以下のコマンドにより、上で説明した図に記載された6つのネットワークインタフェースを作成する事ができます。
# terminal-ubuntuで実行
sudo ip link add com1-veth0 type veth peer name gw1-veth0
sudo ip link add gw1-veth1 type veth peer name gw2-veth1
sudo ip link add com2-veth0 type veth peer name gw2-veth0
IFをそれぞれの機器に登録する
作成したvethインターフェイスは、それぞれの機器(Network Namespace)に登録する必要があります。以下の通り、機器とIFを対応づけてコマンドを実行します。
# terminal-ubuntuで実行
sudo ip link set com1-veth0 netns computer1
sudo ip link set gw1-veth0 netns router1
sudo ip link set gw1-veth1 netns router1
sudo ip link set gw2-veth0 netns router2
sudo ip link set gw2-veth1 netns router2
sudo ip link set com2-veth0 netns computer2
vethインタフェースをUPの状態に設定する
登録したvethインターフェイスはDOWNの状態になっているため、使えるようにするにはUPの状態に設定する必要があります。以下のコマンドで、6つのネットワークインタフェースをUPに設定します。
# terminal-computer1で実行
ip link set com1-veth0 up
# terminal-router1で実行
ip link set gw1-veth0 up
ip link set gw1-veth1 up
# terminal-router2で実行
ip link set gw2-veth0 up
ip link set gw2-veth1 up
# terminal-computer2で実行
ip link set com2-veth0 up
IPアドレスの登録
上で作成した6つのネットワークインタフェースに、上で説明した図の通りにIPアドレスを付与します。
# terminal-computer1で実行
ip address add 192.168.0.2/24 dev com1-veth0
# terminal-router1で実行
ip address add 192.168.0.254/24 dev gw1-veth0
ip address add 203.103.0.2/24 dev gw1-veth1
# terminal-router2で実行
ip address add 192.168.100.254/24 dev gw2-veth0
ip address add 203.103.0.3/24 dev gw2-veth1
# terminal-computer2で実行
ip address add 192.168.100.2/24 dev com2-veth0
同じセグメント内でのPing疎通確認
ここまでで、同じセグメント内の機器間での通信が可能になっているはずです。
以下のコマンドで、computer1からrouter1へのPingの疎通を確認します。
# terminal-computer1で実行
ping -c 3 192.168.0.254
以下のコマンドで、computer2からrouter2へのPingの疎通を確認します。
# terminal-computer2で実行
ping -c 3 192.168.100.254
ホスト機器のルーティング設定
まずは、computer1にデフォルトルートとなるルーティングエントリを追加します。
# terminal-computer1で実行
ip route add default via 192.168.0.254
次に、computer2にデフォルトルートとなるルーティングエントリを追加します。
# terminal-computer2で実行
ip route add default via 192.168.100.254
ルータとしての動作設定
router1, router2をIPv4のルータとして動作させるため、以下のコマンドを実行します。
# terminal-router1で実行
sysctl net.ipv4.ip_forward=1
# terminal-router2で実行
sysctl net.ipv4.ip_forward=1
ルータ機器のルーティング設定
今回のネットワーク構成では、router1, router2が直接つながっていないセグメントがあります。
router1は198.168.100.0/24のセグメント宛のパケットを受け取っても、次に渡す相手がわかりません。
また、router2は192.168.0.0/24のセグメント宛のパケットを受けとっても、次に渡す相手がわかりません。
この問題を解決するには、ルータにもルーティングエントリを追加する必要があります。自分自身が直接つながっていないセグメント宛のパケットを、どう扱えば良いのかを設定します。
まず、router1には、192.168.100.0/24宛のパケットは203.103.0.3に送るように設定をします。
# terminal-router1で実行
ip route add 192.168.100.0/24 via 203.103.0.3
# もしくは、以下のようにデフォルトルートとして設定する
ip route add default via 203.103.0.3
次に、router2には、192.168.0.0/24宛のパケットは203.103.0.2に送るように設定をします。
# terminal-router2で実行
ip route add 192.168.0.0/24 via 203.103.0.2
# もしくは、以下のようにデフォルトルートとして設定する
ip route add default via 203.103.0.2
これで一通りの設定が完了しました。最後に、computer1からcomputer2にpingの疎通が通る事を確認しておきましょう。
ping -c 3 192.168.100.2
おわりに
前回に引き続き、別セグメント間の通信を行うためのルーティングについてUbuntuの仮想環境を使って動作確認をしつつ説明をしました。
今回は、前回のルータ1台を介した別セグメント間の通信の応用として、ルータ2台を介した別セグメント間の通信を扱いました。
このようなケースで、ルーティング設定が必要な際のマニュアルとして使っていただけると幸いです。
最後に、この記事が少しでも多くの方にとって有益になれば幸いです。