2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

GUI操作による仮想ネットワークの構築③ DNSサーバ・DHCPサーバ編

Last updated at Posted at 2024-08-06

1.概要説明

DNSサーバ・DHCPサーバを立てます。

Virtual Boxのような仮想化ソフトウェアを使ってネットワークの仕組みの理解に役立てようというコンセプトで説明していきます。応用情報技術者試験のために学習したことを実装しながら復習していく感覚で、いろいろ調べながら記事を作成してみました。

仕組みを理解するという趣旨であり、本格的なものではございません。

目標(ゴール)は内部的にだけ名前解決ができる事、DHCPサーバを立ててIPアドレスが自動割り振りされる事です。

2.ネットワークの構成

下記のような構成とします。
image.png

3.VMの構築

アダプター1にNAT(ネット接続用)、アダプター2に内部ネットワーク(ここでは名前を"intranet01"とする)に設定します。インターネットに接続しない場合は、Ubuntu側で適宜接続を切ります。
image.png

image.png

4.DNSの構築

このあたりを参考にさせて頂きました。

bind9というツールを使ってDNSの設定を行っていきます。
bind9-utilsも同時にインストールしていきます。

bash
sudo apt update && sudo apt install bind9 bind9-utils

bindに関する設定は etc/bindにあります。
ここでもまた、一般的にはviやvimを使うと思うのですが私は苦手なので、GUI中心に操作していきます。私と同じような環境を構築したければ、以下が参考になるかと思います(話の脱線)。

設定ファイルの編集

ファイルアプリ→+他の場所→このコンピュータ→etc/bind/

bindはnamedという名前で動作します。

namedが起動するとまずnamed.confを読みにいき、そこに記載されているパスの設定ファイルを見にいきます。
要は、基本となる設定ファイルから、追加の設定ファイルを読み込みにいっているということです。
includeするパスに設定ファイルのパスを追記することで、設定ファイルを見にいくことができるようになります。

named.conf
include "/etc/bind/named.conf.options";
include "/etc/bind/named.conf.local";
include "/etc/bind/named.conf.default-zones";
// 追記
include "/etc/bind/named.conf.internal-zones";

いま追記したパスには設定ファイルがありません。
named.conf.default-zonesを参考にして、named.conf.internal-zonesを新規作成します。
ここでfileに指定したものがDNSゾーンファイルになります。

named.conf.internal-zones
zone "mydnstest.home" IN {
	type	master;
	file	"/etc/bind/mydnstest.home.lan";
};
zone "1.16.172.in-addr.arpa" IN {
	type	master;
	file	"/etc/bind/db.1.16.172";
};

こちらはBINDのオプションファイルになります。ACL(アクセス制御リスト)の定義や、DNSのオプション設定から様々なDNSの挙動について設定することができます。

ACLに設定したネットワークのクエリを許可し、それ以外のネットワークのクエリには対応しないようになります。DNSサーバーが特定のネットワーク(例えば社内ネットワークや特定のデータセンター)からのクエリのみを受け入れるように制御するという意図ですね。

named.conf.options
acl internal-network {
	172.16.1.0/24;
};
options {
	directory "/var/cache/bind";
	// 問い合わせを受け付けるネットワーク
	allow-query{
		localhost; internal-network;
	};	
	// 再帰問い合わせ
	recursion no;
 
	dnssec-validation auto;
	listen-on-v6 { any; };
};

正引き用ゾーンファイル

mydnstest.home.lan
$TTL 86400
@   IN  SOA ns1.mydnstest.home. root.mydnstest.home. (
            2024080501 ; Serial
            3600       ; Refresh
            1800       ; Retry
            604800     ; Expire
            86400      ; Minimum TTL
)
    IN  NS  ns1.mydnstest.home.
ns1 IN  A   172.16.1.3
www IN  A   172.16.1.10

逆引きゾーンファイル

db.1.16.172
$TTL 86400
@   IN  SOA ns1.mydnstest.home. root.mydnstest.home. (
            2024080501 ; Serial
            3600       ; Refresh
            1800       ; Retry
            604800     ; Expire
            86400      ; Minimum TTL
)
    IN  NS  ns1.mydnstest.home.

; PTR records for reverse lookup
3   IN  PTR ns1.mydnstest.home.
10  IN  PTR www.mydnstest.home.

インストールするものがなくなった段階でNATアダプターから接続を切ります。
※必要に応じて接続すると思うので、設定自体を削除する必要はないと思います。

DNSサーバー自身のDNSのIPアドレスを自身のものに設定します。

ファイアーウォールの設定を変更します。
ポート53をTCPとUDPの両方で開ける理由は、DNS(Domain Name System)が異なるプロトコルを使用するためです。

sudo ufw allow 53/tcp
sudo ufw allow 53/udp

5.DHCPサーバを立てる

こちらを参考にしました。

DHCPサーバー(isc-dhcp-server)のインストール

bash
sudo apt install isc-dhcp-server

etc/dhcp を見にいき、dhcpd.confを管理者権限で開く。

image.png

dhcp.conf
subnet 172.16.1.0 netmask 255.255.255.0{
	range 172.16.1.5 172.16.1.30;
	option routers 172.16.1.1;
	option domain-name-servers 172.16.1.3;
}

このDHCP設定は、以下のように機能します。
特に意味はないですが、ipアドレスの割りあて範囲を狭く設定してみました。

サブネットマスク: 172.16.1.0/24(ネットマスク255.255.255.0)
IPアドレスの割り当て範囲: 172.16.1.5から172.16.1.30
デフォルトゲートウェイ: 172.16.1.1
DNSサーバー: 172.16.1.3
この設定により、DHCPサーバーは172.16.1.5から172.16.1.30までのIPアドレスをクライアントに割り当て、デフォルトゲートウェイとして172.16.1.1を指定し、DNSサーバーとして172.16.1.3を使用するように設定します。

DHCPサーバーの確認

新たに作成したVMで自動設定にし、指定した範囲のipアドレスが振られていることがわかります。

bash
ip a

image.png

クライアント側からDHCPサーバー側の情報を取得します。

bash
sudo dhclient -v

6.DNSサーバーの確認

hostコマンド等を使って、正引き・逆引きでそれぞれ名前解決を行っています。
image.png

image.png

まとめ

ひとまずは仮想サーバーを立てることには成功しました。実際にやってみると、「コマンドを打つだけの簡単なお仕事」とはいかず、いろいろな面で理解不足な部分も出てきました。それはまた今後の課題としていきたいと思います。

最初の図ではファイルサーバーがありましたが、本稿にまぜるとさらに複雑になりそうなので、ファイルサーバーについては次回以降取り扱いたいと思います。

何かの足しになれば幸いです。

2
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?