Подключите модуль Kubernetes Postgres к существующей базе данных, хранящейся на постоянном томе - PullRequest
0 голосов
/ 14 марта 2020

Я пытаюсь подключить новый экземпляр приложения Wiki. js, работающий в Kubernetes, с базой данных Postgres, созданной из экземпляра преобладающего приложения и сохраненной в постоянном томе. Я получаю CrashLoopBackOff попытку запустить модуль postgres, просматривая журналы, которые они показывают:

The files belonging to this database system will be owned by user "postgres".
This user must also own the server process.

The database cluster will be initialized with locale "en_US.utf8".
The default database encoding has accordingly been set to "UTF8".
The default text search configuration will be set to "english".

Data page checksums are disabled.

initdb: directory "/var/lib/postgresql/data" exists but is not empty
If you want to create a new database system, either remove or empty
the directory "/var/lib/postgresql/data" or run initdb
with an argument other than "/var/lib/postgresql/data".

Как вы можете видеть, он пытается вызвать initdb, что не удается, так как данные уже присутствуют ... мой главный вопрос: как я могу настроить использование существующих данных вместо попыток создать новую базу данных ???

Моя конфигурация развертывания kubernetes postgres:

Name:                   postgres
Namespace:              wiki
CreationTimestamp:      Fri, 23 Aug 2019 22:17:44 +0000
Labels:                 app=postgres
Annotations:            deployment.kubernetes.io/revision: 36
Selector:               app=postgres
Replicas:               1 desired | 1 updated | 1 total | 0 available | 1 unavailable
StrategyType:           RollingUpdate
MinReadySeconds:        0
RollingUpdateStrategy:  1 max unavailable, 1 max surge
Pod Template:
  Labels:  app=postgres
  Containers:
   postgres:
    Image:      postgres:11.5
    Port:       5432/TCP
    Host Port:  0/TCP
    Environment:
      POSTGRES_USER:      <redacted>
      POSTGRES_PASSWORD:  <redacted>
      POSTGRES_DB:        postgresdb
    Mounts:
      /var/lib/postgresql/data from postgresdb (rw)
  Volumes:
   postgresdb:
    Type:       PersistentVolumeClaim (a reference to a PersistentVolumeClaim in the same namespace)
    ClaimName:  postgres-persistant-storage-postgres-0
    ReadOnly:   false

Как уже упоминалось, мы просто пытаемся указать на существующую базу данных postgres вместо того, чтобы пытаться создать и инициализировать совершенно новую, любая помощь будет принята с благодарностью!


ОБНОВЛЕНИЕ

Когда я bash в модуле Postgres и изучаю каталог /var/lib/postgresql/data, я вижу файл PG_VERSION, а также куча других файлов БД (скриншот). Сам файл PG_VERSION содержит строку 11, которая имеет смысл, поскольку мы находимся на Postgres 11.5. К сожалению, он по-прежнему не распознает его по какой-то причине: (

enter image description here

Вот также мое развертывание. Yaml spe c:

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  annotations:
    deployment.kubernetes.io/revision: "60"
  creationTimestamp: "2019-08-23T22:17:44Z"
  generation: 184
  labels:
    app: postgres
  name: postgres
  namespace: wiki
  resourceVersion: "91329506"
  selfLink: /apis/extensions/v1beta1/namespaces/wiki/deployments/postgres
  uid: d441d0d8-c5f3-11e9-bc53-9676559ad387
spec:
  progressDeadlineSeconds: 2147483647
  replicas: 1
  revisionHistoryLimit: 10
  selector:
    matchLabels:
      app: postgres
  strategy:
    rollingUpdate:
      maxSurge: 1
      maxUnavailable: 1
    type: RollingUpdate
  template:
    metadata:
      creationTimestamp: null
      labels:
        app: postgres
    spec:
      containers:
      - env:
        - name: POSTGRES_USER
          value: postgresadmin
        - name: POSTGRES_PASSWORD
          value: <redacted>
        - name: POSTGRES_DB
          value: wiki
        image: postgres:11.5
        imagePullPolicy: IfNotPresent
        name: postgres
        ports:
        - containerPort: 5432
          protocol: TCP
        resources: {}
        terminationMessagePath: /dev/termination-log
        terminationMessagePolicy: File
        volumeMounts:
        - mountPath: /var/lib/postgresql/data
          name: postgresdb
      dnsPolicy: ClusterFirst
      hostname: postgrespod
      restartPolicy: Always
      schedulerName: default-scheduler
      securityContext: {}
      subdomain: postgres
      terminationGracePeriodSeconds: 30
      volumes:
      - name: postgresdb
        persistentVolumeClaim:
          claimName: wiki-data

1 Ответ

0 голосов
/ 14 марта 2020

Похоже, что изображение проверяется на соответствие файла с именем $PGDATA/PG_VERSION, чтобы решить, нужно ли его инициализировать или нет. См. https://github.com/docker-library/postgres/blob/04f28840134bdaf72e4cd6e4a5300e9ceb5ea013/docker-entrypoint.sh#L211 -L214

Вам нужно сделать так, чтобы этот файл существовал в вашем томе.

...