HostAlias ​​sendo ignorado em PODs do operador AWX

HostAlias ​​sendo ignorado em PODs do operador AWX

Recentemente tive que mover meu cluster K3 executando o operador AWX. Os endereços IP dos meus nós tiveram que mudar de 10.0.3.51, 10.0.3.52, 10.0.3.53 para 10.6.3.44, 10.6.3.45, 10.6.3.71. Atualizei hostAlias ​​em minha implantação do awx-demo:

271       dnsPolicy: ClusterFirst
272       hostAliases:
273       - hostnames:
274         - awx.example.com
275         ip: 10.6.3.44
276       initContainers:
277       - command:
278         - /bin/sh
279         - -c
280         - |
281           hostname=$MY_POD_NAME
282           receptor --cert-makereq bits=2048 commonname=$hostname dnsname=$hostname nodeid=$hostname outreq=/etc/receptor/tls/receptor.req outkey=/etc/receptor/tls/receptor.key
283           receptor --cert-signreq req=/etc/receptor/tls/receptor.req cacert=/etc/receptor/tls/ca/receptor-ca.crt cakey=/etc/receptor/tls/ca/receptor-ca.key outcert=/etc/receptor/tls/    receptor.crt verify=yes

Mas ainda em meus pods de trabalho de automação, o arquivo /etc/hosts possui o endereço IP antigo. O que posso fazer para corrigir o /etc/hosts quando meus pods de trabalho de automação forem criados?

Posso entrar no pod de automação assim e mostrar o /etc/hosts

$ kubectl -n awx exec -it automation-job-19120-2npln -- bash
bash-4.4$ cat /etc/hosts
# Kubernetes-managed hosts file.
127.0.0.1   localhost
::1 localhost ip6-localhost ip6-loopback
fe00::0 ip6-localnet
fe00::0 ip6-mcastprefix
fe00::1 ip6-allnodes
fe00::2 ip6-allrouters
10.42.1.31  automation-job-19120-2npln

# Entries added by HostAliases.
10.0.3.51   awx.example.com
bash-4.4$

Se eu editar o pod, vejo isso ...

apiVersion: v1
kind: Pod
metadata:
  ... omitted ...
spec:
  automountServiceAccountToken: false
  containers:
  - args:
    - ansible-runner
    - worker
    - --private-data-dir=/runner
    image: quay.io/ansible/awx-ee:latest
    imagePullPolicy: Always
    name: worker
    resources:
      requests:
        cpu: 250m
        memory: 100Mi
    stdin: true
    stdinOnce: true
    terminationMessagePath: /dev/termination-log
    terminationMessagePolicy: File
  dnsPolicy: ClusterFirst
  enableServiceLinks: true
  hostAliases:
  - hostnames:
    - awx.example.com
    ip: 10.0.3.51
  nodeName: rocky-k3-3
  ... omitted ...

De onde diabos vem esse 10.0.3.51?

Responder1

Alguém na lista de discussão do AWX me lembrou que preciso usar o console AWX Web UI para atualizar Admininstation >> Group Instance >> 'default' e atualizar o hostAliasesdefinido lá. Dos documentos:https://docs.ansible.com/automation-controller/latest/html/administration/containers_instance_groups.html#customize-the-pod-spec

informação relacionada