apiVersion: v1
kind: Pod
metadata:
  annotations:
    kubectl.kubernetes.io/default-container: haproxy
    percona.com/configuration-hash: 96d48f90052f459e51a7d9c5ea2d2024
  creationTimestamp: "2026-04-20T05:53:46Z"
  generateName: percona-xtradb-haproxy-
  labels:
    app.kubernetes.io/component: haproxy
    app.kubernetes.io/instance: percona-xtradb
    app.kubernetes.io/managed-by: percona-xtradb-cluster-operator
    app.kubernetes.io/name: percona-xtradb-cluster
    app.kubernetes.io/part-of: percona-xtradb-cluster
    apps.kubernetes.io/pod-index: "0"
    controller-revision-hash: percona-xtradb-haproxy-bb6c9dfff
    statefulset.kubernetes.io/pod-name: percona-xtradb-haproxy-0
  name: percona-xtradb-haproxy-0
  namespace: openstack
  ownerReferences:
  - apiVersion: apps/v1
    blockOwnerDeletion: true
    controller: true
    kind: StatefulSet
    name: percona-xtradb-haproxy
    uid: 2fa28834-6ad6-4d1c-93e8-1b46e3e8352e
  resourceVersion: "2314"
  uid: c6452ca4-f1e6-467b-884a-794b73ae5045
spec:
  affinity:
    podAntiAffinity:
      requiredDuringSchedulingIgnoredDuringExecution:
      - labelSelector:
          matchLabels:
            app.kubernetes.io/component: haproxy
            app.kubernetes.io/instance: percona-xtradb
            app.kubernetes.io/managed-by: percona-xtradb-cluster-operator
            app.kubernetes.io/name: percona-xtradb-cluster
            app.kubernetes.io/part-of: percona-xtradb-cluster
        topologyKey: kubernetes.io/hostname
  containers:
  - args:
    - haproxy
    command:
    - /opt/percona/haproxy-entrypoint.sh
    env:
    - name: PXC_SERVICE
      value: percona-xtradb-pxc
    - name: LIVENESS_CHECK_TIMEOUT
      value: "5"
    - name: READINESS_CHECK_TIMEOUT
      value: "1"
    envFrom:
    - secretRef:
        name: percona-xtradb-env-vars-haproxy
        optional: true
    image: harbor.atmosphere.dev/docker.io/percona/haproxy:2.8.14
    imagePullPolicy: Always
    livenessProbe:
      exec:
        command:
        - /opt/percona/haproxy_liveness_check.sh
      failureThreshold: 4
      initialDelaySeconds: 60
      periodSeconds: 30
      successThreshold: 1
      timeoutSeconds: 5
    name: haproxy
    ports:
    - containerPort: 3306
      name: mysql
      protocol: TCP
    - containerPort: 3307
      name: mysql-replicas
      protocol: TCP
    - containerPort: 3309
      name: proxy-protocol
      protocol: TCP
    - containerPort: 33062
      name: mysql-admin
      protocol: TCP
    - containerPort: 33060
      name: mysqlx
      protocol: TCP
    - containerPort: 8404
      name: stats
      protocol: TCP
    readinessProbe:
      exec:
        command:
        - /opt/percona/haproxy_readiness_check.sh
      failureThreshold: 3
      initialDelaySeconds: 15
      periodSeconds: 5
      successThreshold: 1
      timeoutSeconds: 1
    resources: {}
    terminationMessagePath: /dev/termination-log
    terminationMessagePolicy: File
    volumeMounts:
    - mountPath: /etc/haproxy-custom/
      name: haproxy-custom
    - mountPath: /etc/haproxy/pxc
      name: haproxy-auto
    - mountPath: /opt/percona
      name: bin
    - mountPath: /etc/mysql/mysql-users-secret
      name: mysql-users-secret-file
    - mountPath: /etc/mysql/haproxy-env-secret
      name: percona-xtradb-env-vars-haproxy
    - mountPath: /var/run/secrets/kubernetes.io/serviceaccount
      name: kube-api-access-567kd
      readOnly: true
  - args:
    - /opt/percona/peer-list
    - -on-change=/opt/percona/haproxy_add_pxc_nodes.sh
    - -service=$(PXC_SERVICE)
    command:
    - /opt/percona/haproxy-entrypoint.sh
    env:
    - name: PXC_SERVICE
      value: percona-xtradb-pxc
    - name: REPLICAS_SVC_ONLY_READERS
      value: "false"
    envFrom:
    - secretRef:
        name: percona-xtradb-env-vars-haproxy
        optional: true
    image: harbor.atmosphere.dev/docker.io/percona/haproxy:2.8.14
    imagePullPolicy: Always
    name: pxc-monit
    resources: {}
    terminationMessagePath: /dev/termination-log
    terminationMessagePolicy: File
    volumeMounts:
    - mountPath: /etc/haproxy-custom/
      name: haproxy-custom
    - mountPath: /etc/haproxy/pxc
      name: haproxy-auto
    - mountPath: /etc/mysql/mysql-users-secret
      name: mysql-users-secret-file
    - mountPath: /etc/mysql/haproxy-env-secret
      name: percona-xtradb-env-vars-haproxy
    - mountPath: /opt/percona
      name: bin
    - mountPath: /var/run/secrets/kubernetes.io/serviceaccount
      name: kube-api-access-567kd
      readOnly: true
  dnsPolicy: ClusterFirst
  enableServiceLinks: true
  hostname: percona-xtradb-haproxy-0
  initContainers:
  - command:
    - /pxc-init-entrypoint.sh
    image: harbor.atmosphere.dev/docker.io/percona/percona-xtradb-cluster-operator:1.17.0
    imagePullPolicy: Always
    name: pxc-init
    resources:
      limits:
        cpu: 50m
        memory: 50M
      requests:
        cpu: 50m
        memory: 50M
    terminationMessagePath: /dev/termination-log
    terminationMessagePolicy: File
    volumeMounts:
    - mountPath: /var/lib/mysql
      name: bin
    - mountPath: /var/run/secrets/kubernetes.io/serviceaccount
      name: kube-api-access-567kd
      readOnly: true
  - command:
    - /haproxy-init-entrypoint.sh
    image: harbor.atmosphere.dev/docker.io/percona/percona-xtradb-cluster-operator:1.17.0
    imagePullPolicy: Always
    name: haproxy-init
    resources:
      limits:
        cpu: 50m
        memory: 50M
      requests:
        cpu: 50m
        memory: 50M
    terminationMessagePath: /dev/termination-log
    terminationMessagePolicy: File
    volumeMounts:
    - mountPath: /opt/percona
      name: bin
    - mountPath: /var/run/secrets/kubernetes.io/serviceaccount
      name: kube-api-access-567kd
      readOnly: true
  nodeName: instance
  nodeSelector:
    openstack-control-plane: enabled
  preemptionPolicy: PreemptLowerPriority
  priority: 0
  restartPolicy: Always
  schedulerName: default-scheduler
  securityContext: {}
  serviceAccount: default
  serviceAccountName: default
  subdomain: percona-xtradb-haproxy
  terminationGracePeriodSeconds: 30
  tolerations:
  - effect: NoExecute
    key: node.kubernetes.io/not-ready
    operator: Exists
    tolerationSeconds: 300
  - effect: NoExecute
    key: node.kubernetes.io/unreachable
    operator: Exists
    tolerationSeconds: 300
  volumes:
  - configMap:
      defaultMode: 420
      name: percona-xtradb-haproxy
      optional: true
    name: haproxy-custom
  - emptyDir: {}
    name: haproxy-auto
  - name: mysql-users-secret-file
    secret:
      defaultMode: 420
      optional: false
      secretName: internal-percona-xtradb
  - name: percona-xtradb-env-vars-haproxy
    secret:
      defaultMode: 420
      optional: true
      secretName: percona-xtradb-env-vars-haproxy
  - emptyDir: {}
    name: bin
  - name: kube-api-access-567kd
    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-04-20T05:53:56Z"
    status: "True"
    type: Initialized
  - lastProbeTime: null
    lastTransitionTime: "2026-04-20T05:55:12Z"
    status: "True"
    type: Ready
  - lastProbeTime: null
    lastTransitionTime: "2026-04-20T05:55:12Z"
    status: "True"
    type: ContainersReady
  - lastProbeTime: null
    lastTransitionTime: "2026-04-20T05:53:46Z"
    status: "True"
    type: PodScheduled
  containerStatuses:
  - containerID: containerd://4e81287a153f69a87a308f3c697b9d7c99b1766b5d2005286187c47a84eed8b4
    image: harbor.atmosphere.dev/docker.io/percona/haproxy:2.8.14
    imageID: harbor.atmosphere.dev/docker.io/percona/haproxy@sha256:6de8c402d83b88dae7403c05183fd75100774defa887c05a57ec04bc25be2305
    lastState: {}
    name: haproxy
    ready: true
    restartCount: 0
    started: true
    state:
      running:
        startedAt: "2026-04-20T05:54:01Z"
  - containerID: containerd://4fcb65894c3cfbdebcf20bd8a6a5029c603400863d43b454af8f34ee486b323e
    image: harbor.atmosphere.dev/docker.io/percona/haproxy:2.8.14
    imageID: harbor.atmosphere.dev/docker.io/percona/haproxy@sha256:6de8c402d83b88dae7403c05183fd75100774defa887c05a57ec04bc25be2305
    lastState: {}
    name: pxc-monit
    ready: true
    restartCount: 0
    started: true
    state:
      running:
        startedAt: "2026-04-20T05:54:08Z"
  hostIP: 199.204.45.132
  initContainerStatuses:
  - containerID: containerd://1289b41d27ca60c34b4d6d4dbbea8186fd4985ec6e05ff1baa98a33c8e2f4985
    image: harbor.atmosphere.dev/docker.io/percona/percona-xtradb-cluster-operator:1.17.0
    imageID: harbor.atmosphere.dev/docker.io/percona/percona-xtradb-cluster-operator@sha256:96a78ea3895b9d1ecab62ba64c4bb2c79b1582cde4f27ef8f0ec9def458eb2df
    lastState: {}
    name: pxc-init
    ready: true
    restartCount: 0
    started: false
    state:
      terminated:
        containerID: containerd://1289b41d27ca60c34b4d6d4dbbea8186fd4985ec6e05ff1baa98a33c8e2f4985
        exitCode: 0
        finishedAt: "2026-04-20T05:53:51Z"
        reason: Completed
        startedAt: "2026-04-20T05:53:49Z"
  - containerID: containerd://2b2e949c226d4f17bd952fa8f271bd111ce51a9652b64cdbe63c5accd8d74ded
    image: harbor.atmosphere.dev/docker.io/percona/percona-xtradb-cluster-operator:1.17.0
    imageID: harbor.atmosphere.dev/docker.io/percona/percona-xtradb-cluster-operator@sha256:96a78ea3895b9d1ecab62ba64c4bb2c79b1582cde4f27ef8f0ec9def458eb2df
    lastState: {}
    name: haproxy-init
    ready: true
    restartCount: 0
    started: false
    state:
      terminated:
        containerID: containerd://2b2e949c226d4f17bd952fa8f271bd111ce51a9652b64cdbe63c5accd8d74ded
        exitCode: 0
        finishedAt: "2026-04-20T05:53:55Z"
        reason: Completed
        startedAt: "2026-04-20T05:53:53Z"
  phase: Running
  podIP: 10.0.0.162
  podIPs:
  - ip: 10.0.0.162
  qosClass: Burstable
  startTime: "2026-04-20T05:53:46Z"
