Tenho algumas instâncias c5.large com duas interfaces de rede cada, executando o Amazon Linux 2 AMI mais recente em 2018-03. Eles costumavam ter 8 endereços IP em cada interface, que agora foram alterados para 7. Ao adicionar endereços IP e interfaces, isso foi atualizado corretamente na reinicialização/reinicialização de serviços, conforme documentado nos documentos da Amazon. Agora, uma das instâncias, na interface de rede primária, ainda acredita ter 8 endereços IP – o removido ainda permanece.
Eu tentei reiniciar a rede do systemctl e reinicializar, sem sucesso.
Abaixo está a parte relevante da saída do journalctl. ondulaçãohttp://xxxx/latest/meta-data/network/interfaces/macs/MAC1/local-ipv4s(com o MAC relevante para eth0) retorna os 7 endereços IP corretos, sem o endereço IP obsoleto, que ainda está preso à interface de rede. Percebo que vemos apenas "Regras de reescrita" para eth1 e não para eth0. Ainda assim, uma instância está bem, enquanto a outra não.
network[1829]: Bringing up interface eth0:
dhclient[1982]: DHCPREQUEST on eth0 to x.x.x.x port 67 (xid=0x509915e5)
dhclient[1982]: DHCPACK from x.x.x.x (xid=0x509915e5)
NET[2026]: /usr/sbin/dhclient-script : updated /etc/resolv.conf
dhclient[1982]: bound to x.x.x.x -- renewal in 1364 seconds.
ec2net[2043]: [get_meta] Trying to get http://x.x.x.x/latest/meta-data/network/interfaces/macs/MAC1/local-ipv4s
network[1829]: Determining IP information for eth0... done.
ec2net[2061]: [rewrite_aliases] Rewriting aliases of eth0
systemd[1]: Started AWS CodeDeploy Host Agent.
bash[1826]: /opt/codedeploy-agent/vendor/gems/logging-1.8.2/lib/logging/appender.rb:139: warning: constant ::Fixnum is deprecated
bash[1826]: /opt/codedeploy-agent/vendor/gems/logging-1.8.2/lib/logging/logger.rb:295: warning: constant ::Fixnum is deprecated
network[1829]: Determining IPv6 information for eth0... done.
network[1829]: [ OK ]
network[1829]: Bringing up interface eth1:
dhclient[2217]: DHCPREQUEST on eth1 to x.x.x.x port 67 (xid=0xeeb9077)
dhclient[2217]: DHCPACK from x.x.x.x (xid=0xeeb9077)
ec2net[2262]: [get_meta] Trying to get http://x.x.x.x/latest/meta-data/network/interfaces/macs/MAC2/local-ipv4s
ec2net[2271]: [rewrite_rules] Rewriting rules for eth1
dhclient[2217]: bound to x.x.x.x -- renewal in 1727 seconds.
network[1829]: Determining IP information for eth1... done.
ec2net[2293]: [get_meta] Trying to get http://x.x.x.x/latest/meta-data/network/interfaces/macs/MAC2/local-ipv4s
ec2net[2300]: [rewrite_aliases] Rewriting aliases of eth1
dhclient[2166]: XMT: Solicit on eth0, interval 1060ms.
network[1829]: Determining IPv6 information for eth1... done.
network[1829]: [ OK ]
systemd[1]: Started LSB: Bring up/down networking.
systemd[1]: Starting Initial cloud-init job (metadata service crawler)...
systemd[1]: Reached target Network.
systemd[1]: Starting Network.
systemd[1]: Starting Postfix Mail Transport Agent...
dhclient[2166]: XMT: Solicit on eth0, interval 2050ms.
cloud-init[2477]: Cloud-init v. 0.7.9 running 'init' at Tue, 13 Feb 2018 13:28:18 +0000. Up 9.23 seconds.
dhclient[2431]: XMT: Solicit on eth1, interval 1040ms.
cloud-init[2477]: ci-info: +++++++++++++++++++++++++++Net device info++++++++++++++++++++++++++++
EDIT: O que espero é que a interface remova o endereço IP não atribuído da interface de rede primária na reinicialização da rede (ou pelo menos na reinicialização da instância). Como faço para que isso funcione?
EDIT 2: Excluir manualmente o IP da interface ip addr del x.x.x.x/20 dev eth0
remove-o por enquanto, mas ele volta quando eu executo o service network restart
. Talvez haja algum resultado em cache que permaneça...?