Я пытаюсь развернуть 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 всегда присутствует?