ループバックに追加のIPを割り当てる方法

ループバックに追加のIPを割り当てる方法

Gentoo ホスト上で実行されている共有 PostgreSQL にアクセスすることを想定した Docker コンテナがいくつかあります。Docker 化されたアプリがホストのパブリック IP を使用してデータベースに接続する場合、これはうまく機能します。

しかし、少し切り離して考えたい。ループバックで追加のプライベートIPを使用するパブリック IP の代わりに、10.172.17.1 とします。

/etc/conf.d/net に何を追加する必要があるのか​​よくわかりません。これは物理的にアクセスできないリモート ボックスなので、ただ試してみるのは少しためらわれます。誰か私にヒントをくれる人はいませんか?

どうもありがとう!

答え1

私は自分でそれを理解しました:

config_lo 10.172.17.1/32/etc/conf.d/net に追加し、net.lo サービスを で再起動してこの追加 IP を割り当てることは可能ですrc-service net.lo restart。ただし、これは次回の再起動後には無効になります。

現在、Gentoo はループバックを起動するために net.lo サービスを開始せず、別のスクリプト /etc/init.d/loopback を使用します。このスクリプトはifconfig、IP をハードコードして機能させます。スクリプト自体にパッチを当てるのは、間違いなく悪い考えです。

ただし、追加の IP は Docker コンテナの起動後にのみ必要となるため、ローカル サービスによって追加できます。

cat "ip addr add 10.172.17.1/32 dev lo scope host" >/etc/local.d/docker_loopback.start
cat "ip addr del 10.172.17.1/32 dev lo scope host" >/etc/local.d/docker_loopback.stop
chmod a+x /etc/local.d/docker_loopback.*

ここで、再起動するか、開始スクリプトを実行して結果を確認します。

/etc/local.d/docker_loopback.start
ip addr

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 brd 127.255.255.255 scope host lo
       valid_lft forever preferred_lft forever
    inet 10.172.17.1/32 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host
       valid_lft forever preferred_lft forever

関連情報