0
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?

BIND9.20.xをインストールする(ソースからビルド) for RockyLinux 9.x

Last updated at Posted at 2024-12-21

DNSサーバーの代表格BIND。最近は脆弱性問題がしばしば出ることから常に最新版での運用が推奨される製品。この記事では、BINDをソースからコンパイルしてインストールする方法を記載しています。
(ソースからのビルドのため、常に最新版での運用が可能となります)
2024年12月現在のBINDは、「9-20-4」がStable版の最新版です。
RockyLinuxでの手順を書いていますが、RHEL互換OSであればどれも同じ方法で作業が可能です。

ダウンロード先

検証環境バージョン

ソフトウェア バージョン
BIND 9-20-4
OS RockyLinux 9.3

事前インストール

OpenSSLが事前に必要です。以下を参考に事前にインストールをしておきます。
RockyLinux 9.xにOpenSSL 3.0.xをインストールする(ソースからビルド)
Python 3.x系をインストールします
(https://qiita.com/shadowhat/items/025c49df5e45d6c1b665)

PowerToolsの有効化

以下のライブライをdnfでインストールするためには、PowerToolsのインストール必要
(参考)[https://qiita.com/koizumistr/items/f8e2eece3a4b5fb2fa03](Rocky Linux 9でPowerToolsリポジトリを使いたい)

sudo dnf config-manager --set-enabled crb

libpcap-develとlibuvをインストールする

dnf install libcap-devel libuv-devel
dnf install g++

※RockyLinux9では、autoconfとaclocalのバージョンが異なっており。libuvは、ビルドが出来ない

nghttp2をインストール

※RockyLinuxのPythonが3.6のためそちらにパスがあるとconfigureでこける
(configure: error: Python interpreter is too old と言われる)
その場合、一時的に、「mv /usr/bin/python3 /usr/bin/python3.def」と変更してconfigureを実行する

もしくは「dnf install python3-devel」でインストールする

cd /usr/local/src
wget https://github.com/nghttp2/nghttp2/releases/download/v1.64.0/nghttp2-1.64.0.tar.gz
tar xvzf nghttp2-1.64.0.tar.gz
cd nghttp2-1.64.0/
./configure
make -j 8
make install

Python3のインストール

#インストールはこちらを参照する
Python3.xをインストール(ソースからビルド)for RockyLinux 9.x
https://qiita.com/shadowhat/items/025c49df5e45d6c1b665

/usr/local/python-3.12.8/bin/pip3 install ply
/usr/local/python-3.12.8/bin/python3.11 -m pip install --upgrade pip

Userspace-RCUインストール

cd /usr/local/src
wget https://lttng.org/files/urcu/userspace-rcu-latest-0.15.tar.bz2
tar xvjf userspace-rcu-latest-0.15.tar.bz2
cd userspace-rcu-0.15.0
./configure
make
make install

BINDインストール

cd /usr/local/src
wget https://downloads.isc.org/isc/bind9/9.20.4/bind-9.20.4.tar.xz
tar xvJf bind-9.20.4.tar.xz
cd bind-9.20.4/
export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig:/usr/local/python-3.12.8/lib/pkgconfig:/usr/local/ssl/lib/pkgconfig
export LD_RUN_PATH=/usr/local/lib:/usr/local/python-3.12.8/lib:/usr/local/ssl/lib
./configure

make
# makeは-j Xで複数スレッド走らせずシングルスレッドでビルドしないとInternal Errorでこける。
# makeでinternal errorが出るときは、一度OS再起動で再実行する
make install

初期設定

事前準備

bind起動用のユーザーを作成します。

useradd named
mkdir -p /var/named
chown named:named -R /var/named/
mkdir -p /run/named
chown named:named -R /run/named
#PIDファイル置き場所指定
mkdir -p /usr/local/var/run/named
chown named:named /usr/local/var/run/named

キーの生成を行う

#/etc/rndc.keyのファイルを作成
#/usr/local/sbin/rndc-confgen -a
/usr/local/sbin/rndc-confgen -a -b 512 -k rndckey

#rndc.confを作成
ln -s /usr/local/lib/libuv.so.1 /usr/lib64/libuv.so.1
/usr/local/sbin/rndc-confgen > /etc/rndc.conf

cat /usr/local/etc/rndc.key | grep secret
#key項目の中身を控える
mv /usr/local/etc/rndc.key /usr/local/etc/rndc.key.def

vi /etc/rndc.conf
- key "rndc-key"以下を先ほど控えたもの置き換え -
touch /etc/named.conf
ln -s /etc/named.conf /usr/local/etc/named.conf

ヒントファイルを取得する

mkdir -p /var/named
cd /var/named
wget https://www.internic.net/domain/named.root

##named.confを配置する

cat > /etc/named.conf << EOF
options {
    directory "/var/named";
    recursion yes;
    allow-recursion{ 192.168.0.0/16; localhost; };
    version "unknow";
#    listen-on { WW.XX.YY.ZZ; 127.0.0.1;}; #公開するインターフェースのIP
    listen-on { any;}; #すべてのインターフェースの場合
#    dnssec-enable yes; 
};

key "rndc-key" {
      algorithm hmac-sha256;
      //rdnc.keyのキーをここに入れる
      secret "XXXXXXXXXXXXXXXXXXXXXX==";
};

controls {
      inet 127.0.0.1 port 953
              allow { 127.0.0.1; } keys { "rndc-key"; };
};

zone "." IN {
    type hint;
    file "named.root";
};

zone "localhost" IN {
    type master;
    file "named.localhost";
};

zone "0.0.127.in-addr.arpa" IN {
    type master;
    file "named.loopback";
};


EOF

Zoneファイルを用意する

### localhost正引き
cat >  /var/named/named.localhost << EOF
\$TTL 1D
@	IN SOA	@ rname.invalid. (
					0	; serial
					1D	; refresh
					1H	; retry
					1W	; expire
					3H )	; minimum
	NS	@
	A	127.0.0.1
	AAAA	::1

EOF
### localhost逆引き
cat > /var/named/named.loopback << EOF
\$TTL 1D
@	IN SOA	@ rname.invalid. (
					0	; serial
					1D	; refresh
					1H	; retry
					1W	; expire
					3H )	; minimum
	NS	@
	A	127.0.0.1
	AAAA	::1
	PTR	localhost.

EOF

起動スクリプトを配置

cat > /usr/lib/systemd/system/named.service << EOF
[Unit]
Description=Berkeley Internet Name Domain (DNS)
After=network-online.target

[Service]
Type=forking
PIDFile=/usr/local/var/run/named/named.pid

ExecStartPre=/bin/bash -c 'if [ ! "\$DISABLE_ZONE_CHECKING" == "yes" ]; then /usr/local/bin/named-checkconf -z /etc/named.conf; else echo "Checking of zone files is disabled"; fi'
ExecStart=/usr/local/sbin/named -u named \$OPTIONS

ExecReload=/bin/sh -c '/usr/local/sbin/rndc reload > /dev/null 2>&1 || /bin/kill -HUP \$MAINPID'

ExecStop=/bin/sh -c '/usr/local/sbin/rndc stop > /dev/null 2>&1 || /bin/kill -TERM \$MAINPID'
Environment="LD_LIBRARY_PATH=/usr/local/lib:/usr/local/lib64:/usr/local/ssl/lib:/usr/lib64:/usr/lib"

PrivateTmp=true

[Install]
WantedBy=multi-user.target

EOF

サービスを起動し、自動起動を設定

mkdir -p /usr/local/var/run/named/
ln -s /etc/named.conf /usr/local/etc/named.conf
ln -s /etc/rndc.conf /usr/local/etc/rndc.conf
chown -R named:named /usr/local/var/run/named
chown -R named:named /var/named
systemctl start named
systemctl enable named

正しく動作しないとき

  • SELinuxは、Offで試してみる
  • /var/namedの権限は、660 /varにも権限付与を確認(namedユーザーにsuして、ファイルが見れるかを確認する)
  • /run/namedが、namedユーザーが所持しているか?
0
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
0
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?