Amazon EC2 上の Fedora 28 で IPv6 を有効にする方法

Amazon EC2 上の Fedora 28 で IPv6 を有効にする方法

Amazon EC2 の Fedora 28 で IPv6 を動作させることができないようです (そのため、cloud-init と DHCPv6 を使用しています)。

説明した設定でRHEL 7で動作しますここ/etc/sysconfig/network同じ設定をFedora 28に適用しても何も起こらないようです。特に、ないを含むように書き換えられNETWORKING_IPV6=yes/etc/sysconfig/network-scripts/ifcfg-eth0IPv6 関連のものも含まれません。

私の/etc/cloud/cloud.cfg.d/56-custom-networking.cfg内容:

network:
  version: 1
  config:
  - type: physical
    name: eth0
    subnets:
      - type: dhcp
      - type: dhcp6

生成されるのは/etc/sysconfig/network次の通りです:

NOZEROCONF=yes
DEVTIMEOUT=10

# Created by cloud-init on instance boot automatically, do not edit.
#
NETWORKING=yes

生成されるのは/etc/sysconfig/network-scripts/ifcfg-eth0次の通りです:

# Created by cloud-init on instance boot automatically, do not edit.
#
BOOTPROTO=dhcp
DEVICE=eth0
HWADDR=0e:79:0a:22:60:26
ONBOOT=yes
TYPE=Ethernet
USERCTL=no

私のifconfig -a

[aram@eden ~]$ ifconfig -a
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 9001
        inet 172.31.35.163  netmask 255.255.240.0  broadcast 172.31.47.255
        inet6 fe80::c79:aff:fe22:6026  prefixlen 64  scopeid 0x20<link>
        ether 0e:79:0a:22:60:26  txqueuelen 1000  (Ethernet)
        RX packets 498  bytes 45355 (44.2 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 332  bytes 38967 (38.0 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

OSバージョン:

[aram@eden ~]$ cat /etc/os-release 
NAME=Fedora
VERSION="28 (Cloud Edition)"
ID=fedora
VERSION_ID=28
PLATFORM_ID="platform:f28"
PRETTY_NAME="Fedora 28 (Cloud Edition)"
ANSI_COLOR="0;34"
CPE_NAME="cpe:/o:fedoraproject:fedora:28"
HOME_URL="https://fedoraproject.org/"
SUPPORT_URL="https://fedoraproject.org/wiki/Communicating_and_getting_help"
BUG_REPORT_URL="https://bugzilla.redhat.com/"
REDHAT_BUGZILLA_PRODUCT="Fedora"
REDHAT_BUGZILLA_PRODUCT_VERSION=28
REDHAT_SUPPORT_PRODUCT="Fedora"
REDHAT_SUPPORT_PRODUCT_VERSION=28
PRIVACY_POLICY_URL="https://fedoraproject.org/wiki/Legal:PrivacyPolicy"
VARIANT="Cloud Edition"
VARIANT_ID=cloud
[aram@eden ~]$ 

答え1

これは、現在のcloud-initバージョン(17.1でテストしました)がない起動のたびにネットワーク設定を再生成します。ネットワーク設定は最初のインスタンスの起動時にのみ生成されます。cloud-init のログ ファイルに記録することでこれを確認できます。

$ grep 'network config' /var/log/cloud-init.log

2018-09-18 22:13:26,089 - stages.py[INFO]: Applying network configuration from ds bringup=False: {'version': 1, 'config': [{'type': 'physical', 'name': 'eth0', 'subnets': [{'type': 'dhcp4'}], 'mac_address': '12:64:78:dd:c8:62'}]}
2018-09-18 22:13:29,211 - stages.py[DEBUG]: not a new instance. network config is not applied.
2018-09-26 10:08:08,367 - stages.py[DEBUG]: not a new instance. network config is not applied.
2018-09-26 10:08:11,458 - stages.py[DEBUG]: not a new instance. network config is not applied.
2018-09-26 11:01:12,917 - stages.py[DEBUG]: not a new instance. network config is not applied.
2018-09-26 11:01:16,011 - stages.py[DEBUG]: not a new instance. network config is not applied.
2018-09-26 11:10:38,782 - stages.py[DEBUG]: not a new instance. network config is not applied.
2018-09-26 11:10:41,871 - stages.py[DEBUG]: not a new instance. network config is not applied.
2018-09-26 11:12:10,407 - stages.py[DEBUG]: not a new instance. network config is not applied.
2018-09-26 11:12:13,475 - stages.py[DEBUG]: not a new instance. network config is not applied.

ご覧のとおり、ネットワーク構成は最初の起動時にのみ適用されました (その時点では、インスタンスにはまだ IPV6 がありませんでした)。

この動作を構成可能にすることを求める問題があります:https://bugs.launchpad.net/cloud-init/+bug/1765801


Fedora 28 (クラウド エディション) の Amazon EC2 上の既存のインスタンス上で IPV6 を有効にするために実行した手順は次のとおりです。

  1. NETWORKING_IPV6=yesに追加/etc/sysconfig/network
  2. DHCPV6C=yesに追加/etc/sysconfig/network-scripts/ifcfg-eth0
  3. 走るsudo systemctl restart network

これらの手順を実行すると、IPV6 が有効になり、再起動後も維持されます。ただし、何らかの理由でインスタンスが再作成され、cloud-init がそれを最初の起動と見なした場合、変更は失われます。ただし、cloud-init は既に IPV6 ネット構成をすぐに生成するため、問題はありません。

関連情報