Eu tenho um par de instâncias c5.large com duas interfaces de rede cada, executando o mais recente Amazon Linux 2 AMI a partir de 2018-03. Eles costumavam ter 8 endereços IP em cada interface, que agora é alterada para 7. Ao adicionar endereços IP e interfaces, isso foi atualizado corretamente na reinicialização de serviços / reinicialização, conforme documentado nos documentos da Amazon. Agora, uma das instâncias, na interface de rede primária, ainda acredita que tem 8 endereços IP - o que foi removido ainda está por aí.
Eu tentei reiniciar a rede systemctl e reiniciar, sem sucesso.
Abaixo está a parte relevante da saída do journalctl. link (com o MAC relevante para eth0) retorna os 7 endereços IP corretos , sem o endereço IP antigo, que ainda está preso à interface de rede. Percebo que só vemos "regras de reescrita" para eth1 e não eth0. Ainda assim, uma instância é boa 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 eu 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 por ip addr del x.x.x.x/20 dev eth0
o remove por enquanto, mas volta quando executo service network restart
. Talvez haja algum resultado em cache que fique ...?