このトピックでは、RDS Custom インスタンスのデフォルトのネットワーク設定について説明します。また、カスタムイメージのネットワーク環境を初期化する方法についても説明します。
RDS Custom インスタンスのデフォルトネットワーク設定
デフォルトでは、RDS Custom インスタンスにはデュアル NIC モードで 2 つのネットワークインターフェイスコントローラー (NIC) が設定されています。プライマリ NIC と Elastic Network Interface (ENI) です。ほとんどの場合、プライマリ NIC は eth0、ENI は eth1 という名前です。
eth0:管理用の Virtual Private Cloud (VPC) 内に作成されます。セキュリティグループの制限により、eth0 を経由できるのは Elastic Compute Service (ECS) インスタンスの管理 CIDR ブロックである 100.100.0.0/16 からのトラフィックのみです。
説明IP アドレス 100.100.2.136 と 100.100.2.138 は、Private DNS サービスの IP アドレスです。これらの IP アドレスからのトラフィックは eth1 を経由します。
eth1:ユーザーの VPC 内に作成されます。ほとんどの場合、ECS インスタンスの管理 CIDR ブロックからのトラフィックを除き、すべてのトラフィックは eth1 を経由します。セキュリティグループは、インバウンドトラフィックとアウトバウンドトラフィックを管理するために使用されます。
以下の図は、インスタンスに接続した後の RDS Custom インスタンスの NIC、ルートテーブル、iptables ファイアウォールルールに関する情報を示しています。詳細については、「RDS Custom インスタンスへの接続」をご参照ください。
-
ip address showコマンドを実行して、インスタンス上の NIC のステータスを確認します。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 scope host lo valid_lft forever preferred_lft forever inet6 ::1/128 scope host valid_lft forever preferred_lft forever 2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000 link/ether 00:16:3e:10:32:d8 brd ff:ff:ff:ff:ff:ff inet 20.xxx.xxx.xxx/16 brd 20.xxx.xxx.xxx scope global dynamic eth0 valid_lft 315357595sec preferred_lft 315357595sec inet6 fe80::xxx:xxx:xxx:xxx/64 scope link valid_lft forever preferred_lft forever 3: eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000 link/ether 00:16:3e:48:f2:e7 brd ff:ff:ff:ff:ff:ff inet 172.xxx.xxx.xxx/20 brd 172.xxx.xxx.xxx scope global dynamic eth1 valid_lft 315357597sec preferred_lft 315357597sec inet6 fe80::xxx:xxx:xxx:xxx/64 scope link valid_lft forever preferred_lft forever -
route -nコマンドを実行して、インスタンスのルートテーブルを表示します。以下の出力は、デフォルトルートが eth1 に向けられ、管理 CIDR ブロック (100.100.0.0/16) へのトラフィックが eth0 に向けられていることを示しています。
Kernel IP routing table Destination Gateway Genmask Flags Metric Ref Use Iface 0.0.0.0 172.xxx.xxx.xxx 0.0.0.0 UG 0 0 0 eth1 100.100.0.0 20.xxx.xxx.xxx 255.255.0.0 UG 0 0 0 eth0 100.100.2.136 172.xxx.xxx.xxx 255.255.255.255 UGH 0 0 0 eth1 100.100.2.138 172.xxx.xxx.xxx 255.255.255.255 UGH 0 0 0 eth1 169.xxx.xxx.xxx 0.0.0.0 255.255.0.0 U 1003 0 0 eth1 172.xxx.xxx.xxx 0.0.0.0 255.255.240.0 U 0 0 0 eth1 -
iptables -L -nコマンドを実行して、インスタンスのデフォルトの iptables 設定を表示します。Chain INPUT (policy ACCEPT) target prot opt source destination Chain FORWARD (policy ACCEPT) target prot opt source destination Chain OUTPUT (policy ACCEPT) target prot opt source destination
ルートテーブル、iptables ファイアウォールルール、eth0 の再起動を含む NIC 設定を管理した後に RDS Custom インスタンスへの接続に失敗した場合は、インスタンスを再起動してインスタンスのネットワーク環境を初期化できます。詳細については、「RDS Custom インスタンスの再起動」をご参照ください。
RDS Custom インスタンスは、/etc/rds_custom_init.sh スクリプトを使用してネットワークの初期化を実行します。このスクリプトを削除しないでください。削除すると、ネットワークの初期化に失敗します。
カスタムイメージのネットワーク環境の初期化
カスタムイメージから RDS Custom インスタンスを作成すると、RDS Custom はほとんどのパブリックイメージに対して /etc/rds_custom_init.sh ネットワーク初期化スクリプトを自動的に設定します。サポートされているイメージには、Alibaba Cloud Linux 3、Alibaba Cloud Linux 2、CentOS 8、CentOS 7、Debian 11、Debian 10.5、AlmaLinux 9.2、Ubuntu 22、Ubuntu 20、Ubuntu 16 が含まれます。他のカスタムイメージを使用するには、カスタムイメージを作成する前に、ソースインスタンスに rds_custom_init.sh スクリプトを手動で作成する必要があります。
rds_custom_init.sh スクリプトには、次の主要な機能があります:
ENI を自動的にアクティブ化できないシステムの場合、eth1 のネットワーク設定を使用し、関連サービスを開始します。
デフォルトルートを eth1 に、ECS インスタンスの管理 CIDR ブロック 100.100.0.0/16 を eth0 に向けるようにルート設定を変更します。
Private DNS サービスの IP アドレス 100.100.2.136 と 100.100.2.138 を eth1 に向けるようにルート設定を変更します。
RDS Custom インスタンスが起動すると、システムは eth0 のゲートウェイを /etc/eth0_gateway ファイルに記録し、ほとんどのパブリックイメージに対して /etc/rds_custom_init.sh スクリプトを自動的に設定します。インスタンスでネットワーク関連の初期化を実行する場合は、初期化が完了した後に /etc/rds_custom_init.sh スクリプトを手動で実行してください。eth1 インターフェイスが利用できなくなった場合 (たとえば、その IP アドレスが認識されない場合) 、お問い合わせいただくか、ネットワークを再設定して eth1 の機能を復元してください。
スクリプトの手動作成と起動時実行設定
-
/etc ディレクトリに、次の内容で
rds_custom_init.shスクリプトを作成します。 -
chmod a+x /etc/rds_custom_init.shコマンドを実行して、スクリプトに実行権限を付与します。 -
/etc/rc.localファイルを編集して、rds_custom_init.shスクリプトが起動時に実行されるように設定します。-
Ubuntu 以外のオペレーティングシステムの場合は、
/etc/rds_custom_init.shを/etc/rc.localファイルに追加し、/etc/rc.localに必要な権限を付与します。chmod 777 /etc/rc.local -
Ubuntu オペレーティングシステムの場合は、
rc-local.serviceを設定して有効化します。-
/lib/systemd/system/rc-local.serviceファイルを編集し、次の内容を追加します。[Install] WantedBy=multi-user.target -
rc-local.serviceが起動時に開始されるように設定します。# サービスが起動時に実行されるように設定します。 systemctl enable rc-local.service # サービスが起動時に実行されるように設定されているか確認します。 systemctl is-enabled rc-local.service -
rc-local.serviceを開始します。# サービスを開始します。 systemctl start rc-local.service # サービスを確認します。 systemctl status rc-local.service
説明デフォルトでは、Ubuntu 20.04、Ubuntu 22.04、Ubuntu 24.04 は、自動設定でバインドされたセカンダリ ENI をサポートします。自動設定に失敗した場合は、次の操作を実行してください。
-
-