apiVersion: v1
kind: Pod
metadata:
  creationTimestamp: "2026-06-10T01:25:34Z"
  generateName: keepalived-
  labels:
    application: keepalived
    controller-revision-hash: 6d74695f88
    pod-template-generation: "1"
  name: keepalived-kw2pd
  namespace: openstack
  ownerReferences:
  - apiVersion: apps/v1
    blockOwnerDeletion: true
    controller: true
    kind: DaemonSet
    name: keepalived
    uid: a5b1fd8b-0d3e-40f3-bcff-c37e4d106ae9
  resourceVersion: "29355"
  uid: dc9c29a4-3f73-43dc-8e4d-c4e1121bf491
spec:
  affinity:
    nodeAffinity:
      requiredDuringSchedulingIgnoredDuringExecution:
        nodeSelectorTerms:
        - matchFields:
          - key: metadata.name
            operator: In
            values:
            - instance
  automountServiceAccountToken: true
  containers:
  - command:
    - keepalived
    - -f
    - /etc/keepalived/keepalived.conf
    - --dont-fork
    - --log-console
    - --log-detail
    - --dump-conf
    image: harbor.atmosphere.dev/ghcr.io/vexxhost/keepalived:latest@sha256:dcc9375277f7cf2d66a3d7f978a9302dc60b9b1335f39e4930e029aed11dce64
    imagePullPolicy: Always
    name: keepalived
    resources: {}
    securityContext:
      allowPrivilegeEscalation: true
      capabilities:
        add:
        - NET_ADMIN
        - NET_BROADCAST
        - NET_RAW
    terminationMessagePath: /dev/termination-log
    terminationMessagePolicy: File
    volumeMounts:
    - mountPath: /etc/keepalived
      mountPropagation: None
      name: keepalived-etc
      readOnly: true
    - mountPath: /var/run/secrets/kubernetes.io/serviceaccount
      name: kube-api-access-4qpvz
      readOnly: true
  dnsPolicy: ClusterFirst
  enableServiceLinks: true
  hostNetwork: true
  initContainers:
  - env:
    - name: NAMESPACE
      valueFrom:
        fieldRef:
          apiVersion: v1
          fieldPath: metadata.namespace
    - name: POD_NAME
      valueFrom:
        fieldRef:
          apiVersion: v1
          fieldPath: metadata.name
    - name: DEPENDENCY_POD_JSON
      value: '[{"requireSameNode": true, "labels": {"application": "neutron", "component":
        "neutron-ovs-agent"}}]'
    image: harbor.atmosphere.dev/ghcr.io/vexxhost/kubernetes-entrypoint:edge@sha256:8921b64b87af184a1421dd856b2703bcf3cff9f50863cd0d18371cf964a87bd3
    imagePullPolicy: IfNotPresent
    name: init
    resources: {}
    terminationMessagePath: /dev/termination-log
    terminationMessagePolicy: File
    volumeMounts:
    - mountPath: /var/run/secrets/kubernetes.io/serviceaccount
      name: kube-api-access-4qpvz
      readOnly: true
  - command:
    - /bin/wait-for-ip.sh
    image: harbor.atmosphere.dev/ghcr.io/vexxhost/keepalived:latest@sha256:dcc9375277f7cf2d66a3d7f978a9302dc60b9b1335f39e4930e029aed11dce64
    imagePullPolicy: Always
    name: wait-for-ip
    resources: {}
    terminationMessagePath: /dev/termination-log
    terminationMessagePolicy: File
    volumeMounts:
    - mountPath: /bin/wait-for-ip.sh
      mountPropagation: None
      name: keepalived-bin
      readOnly: true
      subPath: wait-for-ip.sh
    - mountPath: /var/run/secrets/kubernetes.io/serviceaccount
      name: kube-api-access-4qpvz
      readOnly: true
  nodeName: instance
  nodeSelector:
    openstack-control-plane: enabled
  preemptionPolicy: PreemptLowerPriority
  priority: 0
  restartPolicy: Always
  schedulerName: default-scheduler
  securityContext: {}
  serviceAccount: keepalived
  serviceAccountName: keepalived
  terminationGracePeriodSeconds: 30
  tolerations:
  - effect: NoExecute
    key: node.kubernetes.io/not-ready
    operator: Exists
  - effect: NoExecute
    key: node.kubernetes.io/unreachable
    operator: Exists
  - effect: NoSchedule
    key: node.kubernetes.io/disk-pressure
    operator: Exists
  - effect: NoSchedule
    key: node.kubernetes.io/memory-pressure
    operator: Exists
  - effect: NoSchedule
    key: node.kubernetes.io/pid-pressure
    operator: Exists
  - effect: NoSchedule
    key: node.kubernetes.io/unschedulable
    operator: Exists
  - effect: NoSchedule
    key: node.kubernetes.io/network-unavailable
    operator: Exists
  volumes:
  - name: keepalived-etc
    secret:
      defaultMode: 420
      optional: false
      secretName: keepalived-etc
  - configMap:
      defaultMode: 493
      name: keepalived-bin
      optional: false
    name: keepalived-bin
  - name: kube-api-access-4qpvz
    projected:
      defaultMode: 420
      sources:
      - serviceAccountToken:
          expirationSeconds: 3607
          path: token
      - configMap:
          items:
          - key: ca.crt
            path: ca.crt
          name: kube-root-ca.crt
      - downwardAPI:
          items:
          - fieldRef:
              apiVersion: v1
              fieldPath: metadata.namespace
            path: namespace
status:
  conditions:
  - lastProbeTime: null
    lastTransitionTime: "2026-06-10T02:18:16Z"
    status: "True"
    type: Initialized
  - lastProbeTime: null
    lastTransitionTime: "2026-06-10T02:18:17Z"
    status: "True"
    type: Ready
  - lastProbeTime: null
    lastTransitionTime: "2026-06-10T02:18:17Z"
    status: "True"
    type: ContainersReady
  - lastProbeTime: null
    lastTransitionTime: "2026-06-10T01:25:34Z"
    status: "True"
    type: PodScheduled
  containerStatuses:
  - containerID: containerd://31d2e0d555f62f02936f07faba6afec8dbd2cb31f8d9a2a2699dd296cff667be
    image: sha256:4b75c9e614327300dc5a4cdd8796d28c58c4ec519221fd763007249e98ac4a87
    imageID: harbor.atmosphere.dev/ghcr.io/vexxhost/keepalived@sha256:dcc9375277f7cf2d66a3d7f978a9302dc60b9b1335f39e4930e029aed11dce64
    lastState: {}
    name: keepalived
    ready: true
    restartCount: 0
    started: true
    state:
      running:
        startedAt: "2026-06-10T02:18:16Z"
  hostIP: 199.204.45.65
  initContainerStatuses:
  - containerID: containerd://8ae12e6b40eaf0ec6ae540869a4b6fe7c7b93837b7882c96f6d162f1fb8b688d
    image: sha256:d656bd5737950b86b0ecff4b0206024769c78ea55e2f9f4c840c3cc2a10caaf8
    imageID: harbor.atmosphere.dev/ghcr.io/vexxhost/kubernetes-entrypoint@sha256:8921b64b87af184a1421dd856b2703bcf3cff9f50863cd0d18371cf964a87bd3
    lastState: {}
    name: init
    ready: true
    restartCount: 0
    started: false
    state:
      terminated:
        containerID: containerd://8ae12e6b40eaf0ec6ae540869a4b6fe7c7b93837b7882c96f6d162f1fb8b688d
        exitCode: 0
        finishedAt: "2026-06-10T01:55:28Z"
        reason: Completed
        startedAt: "2026-06-10T01:25:37Z"
  - containerID: containerd://bcfdefd5456026f86cf6a9ab6b7e9e123e8e69cb55410cf72fa792e6f36544c1
    image: sha256:4b75c9e614327300dc5a4cdd8796d28c58c4ec519221fd763007249e98ac4a87
    imageID: harbor.atmosphere.dev/ghcr.io/vexxhost/keepalived@sha256:dcc9375277f7cf2d66a3d7f978a9302dc60b9b1335f39e4930e029aed11dce64
    lastState: {}
    name: wait-for-ip
    ready: true
    restartCount: 0
    started: false
    state:
      terminated:
        containerID: containerd://bcfdefd5456026f86cf6a9ab6b7e9e123e8e69cb55410cf72fa792e6f36544c1
        exitCode: 0
        finishedAt: "2026-06-10T02:18:15Z"
        reason: Completed
        startedAt: "2026-06-10T01:55:41Z"
  phase: Running
  podIP: 199.204.45.65
  podIPs:
  - ip: 199.204.45.65
  qosClass: BestEffort
  startTime: "2026-06-10T01:25:34Z"
