Нет основного в MongoDB 4.2 - PullRequest
       0

Нет основного в MongoDB 4.2

0 голосов
/ 16 апреля 2020

Я пытаюсь развернуть MongoDB 4.2 в Kubernetes без использования их Enterprise Operator, используя https://medium.com/devgorilla/how-to-deploy-mongodb-on-google-kubernetes-engine-gke-b099862fadbd, и, похоже, работает нормально, за исключением того, что нет члена набора первичных реплик.

Я так думаю, потому что все 3 члена имеют тип REPLICA_SET_GHOST. Вот пример ошибки, когда я пытаюсь вставить что-то в db:

Timed out after 30000 ms while waiting to connect. Client view of cluster state is {type=UNKNOWN, servers=[
        {address=mongo-0.mongo: 27017, type=REPLICA_SET_GHOST, roundTripTime=0.8 ms, state=CONNECTED
        },
        {address=mongo-1.mongo: 27017, type=REPLICA_SET_GHOST, roundTripTime=0.9 ms, state=CONNECTED
        },
        {address=mongo-2.mongo: 27017, type=REPLICA_SET_GHOST, roundTripTime=0.9 ms, state=CONNECTED
        }
    ];
apiVersion: apps/v1beta1
kind: StatefulSet
metadata:
  name: mongo
spec:
  serviceName: "mongo"
  replicas: 3
  template:
    metadata:
      labels:
        role: mongo
        environment: test
    spec:
      terminationGracePeriodSeconds: 10
      containers:
        - name: mongo
          image: mongo
          command:
            - mongod
            - "--replSet"
            - rs0
            - "--bind_ip_all"
          ports:
            - containerPort: 27017
          volumeMounts:
            - name: mongo-persistent-storage
              mountPath: /data/db
        - name: mongo-sidecar
          image: cvallance/mongo-k8s-sidecar
          env:
            - name: MONGO_SIDECAR_POD_LABELS
              value: "role=mongo,environment=test"
  volumeClaimTemplates:
    - metadata:
        name: mongo-persistent-storage
        annotations:
          volume.beta.kubernetes.io/storage-class: "nfs-rw"
      spec:
        accessModes: [ "ReadWriteOnce" ]
        resources:
          requests:
            storage: 10Gi

Есть ли возможность настройки свойства для mongod, чтобы гарантировать, что Primary всегда присутствует?

1 Ответ

1 голос
/ 16 апреля 2020

Я никогда не использовал эту коляску - я вручную настраивал реплику, но, думаю, вам не хватает KUBERNETES_MONGO_SERVICE_NAME для использования стабильных сетевых идентификаторов, как указано в хранилище колясок

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...