1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

Raspberry Pi(Debian)でdhclientを使う

Last updated at Posted at 2021-02-18

概要

Raspberry Pi(DebianというかRaspbian/RaspberryPi OS)では、デフォルトだとdhcpcdが動いている。
普通に使うには問題ないのだが、DHCPオプションを取る方法が分からなかったので、dhclient(ISC DHCP)を使うことにした。
前回同様、技術的には難しいことが何もないのだが、後々書きたい投稿の周辺情報/下準備として必要なので書いておく。

ポイント/狙い

  • 今dhcpcdで問題ないのに、わざわざdhclientを動かす背景を共有(言い訳)する。
  • ついでにsystemdで動かす方法も残しておく。

背景

後々別の投稿で書くつもりだが、NTTのフレッツ網(NGN)からひかり電話の情報(SIPサーバのアドレスや電話番号)を取得するには、DHCPオプション(RFC3361で定義されているもの)を使わねばならないようだ。
なのでまずデフォルトで動いているdhcpcdでDHCPオプションを扱おうと思ったのだが、公式ページ曰く、

MAN PAGE IS CURRENTLY OFFLINE. AN AUTOMATED ONE IS BEING WORKED.

とのことで、コンソール上の簡素なman dhcpcdを見るしかない。が、一通り読んでみても、それらしい記述を見つけることが出来なかった。
ここでdhcpcdを諦め、他のDHCPクライアントを使おうと考えたとき、昨今の状況/トレンドを考えてNetworkManagerを使おうかと考えた。そして同じくDHCPオプションが扱えるかどうかを確認したところ、公式ページにて

dhcp

This key sets up what DHCP client NetworkManager will use. Allowed values are dhclient, dhcpcd, and internal. The dhclient and dhcpcd options require the indicated clients to be installed. The internal option uses a built-in DHCP client which is not currently as featureful as the external clients.

と書かれており、出だしからあまり期待できない....。
が、試しにaptでNetworkManagerを入れて動作(dhcp=internal)を確認してみたら、/etc/dhcp/dhclient.confで詳細設定することで各種DHCPオプションを扱うことが出来た。(/etc/dhcp/dhclient.confで設定すると、/etc/NetworkManager/conf.d/に設定が反映される)
ただしよく考えてみると、わざわざNetworkManagerを入れたのに、dhclient.confで設定するのであれば、最初から入っているdhclientを動かせば良い気がした。
以上の試行や判断により、dhcpcdの代わりにdhclientを使うこととなった。

作戦

  • デフォルトで動いているdhcpcdは止めて、dhclientが動くようにする。
  • dhclientをsystemdで動かすため、ユニット定義ファイルを作成する。

手順

dhcpcdを止める

普通にsystemctlで止めるだけ。

systemctl stop dhcpcd.service
systemctl disable dhcpcd.service

なお固定IPの設定を公式ドキュメントに従っている場合は、その設定を/etc/dhcpcd.confから/etc/network/interfaces.d/に転記してやる必要がある。

dhclientのユニット定義ファイルを作成する

DHCPクライアントはリース更新のために動かし続けないといけないので、systemdで動かすユニット定義ファイルを作成する。
これも技術的には何も難しい/工夫したところは何もなく、適当に検索して見つけた以下のサイト

を丸ごとコピペした。

/etc/systemd/system/dhclient.service
[Unit]
Description=DHCP Client
Documentation=man:dhclient(8)
Wants=network.target
Before=network.target
 
[Service]
Type=forking
PIDFile=/var/run/dhclient.pid
ExecStart=/sbin/dhclient
 
[Install]
WantedBy=multi-user.target

もしIFの関係でタイミング調整が必要な場合は、BeforeとかAfterで調整する。
私の環境ではその必要がなかったので、以下のように有効化してそのまま使っている。

systemctl daemon-reload
systemctl enable dhclient.service
systemctl start dhclient.service

これでDHCPの各種情報が取得できると、/var/lib/dhcp/dhclient.leasesに取得内容が書き出される。

/var/lib/dhcp/dhclient.leases
lease {
  interface "eth0";
  fixed-address xxx.xxx.xxx.xxx;
  option subnet-mask 255.255.255.xxx;
  option dhcp-lease-time 14400;
  option routers xxx.xxx.xxx.xxx;
  option dhcp-message-type 5;
  option dhcp-server-identifier xxx.xxx.xxx.xxx;
  option dhcp-renewal-time 7200;
  option dhcp-rebinding-time 10800;
  (略)
  renew 3 2021/02/17 05:11:02;
  rebind 3 2021/02/17 06:14:29;
  expire 3 2021/02/17 07:14:29;
}

その他

環境によるのかもしれないが、私はRaspberry Pi 2Bで上記作業を進めると、ログイン時に以下のメッセージが出るようになった。

rfkill: cannot open /dev/rfkill: 許可がありません
rfkill: cannot read /dev/rfkill: 不正なファイル記述子です

調べてみると、公式フォーラムでも同じような話が出ていた。
一通り調べた上で、私(2B)の場合はこの状態で実害がないし面倒なので、無理やりメッセージを押さえ込んで終わった。

mv /etc/profile.d/wifi-check.sh /etc/profile.d/wifi-check.sh.bak

あとがき

冒頭で書いたとおり、背景を共有して何かコメントをもらうことが目的なので、技術的なことが知りたい人は他の投稿を読む方がいいと思います。

1
1
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
1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?