小编Bos*_*ker的帖子

使用 mongodb+srv 连接到部署为有状态集的 mongodb

我已经在 kubernetes 中部署了 3 pod mongodb statefulset,并且我正在尝试使用新的mongodb+srv连接字符串 (mongodb 3.6) 连接到具有集群成员的 SRV 记录的无头 k8s 服务。

但是,连接失败,如下所示(mongo 命令正在 satefulset 中的第一个 pod 上执行):

root@mongodb-0:/# mongo "mongodb+srv://mongodb-headless.mongo.svc.cluster.local"
FailedToParse: Hostname mongodb-0.mongodb-headless.mongo.svc.cluster.local. is not within the domain mongo.svc.cluster.local
try 'mongo --help' for more information
Run Code Online (Sandbox Code Playgroud)

这是无头服务配置:

kubectl describe svc/mongodb-headless -n mongo
Name:              mongodb-headless
Namespace:         mongo
Labels:            app=mongodb-headless
                   chart=mongodb-1.0.1
                   heritage=Tiller
                   release=mongo
Annotations:       service.alpha.kubernetes.io/tolerate-unready-endpoints=true
Selector:          app=mongodb,release=mongo
Type:              ClusterIP
IP:                None
Port:              mongodb  27017/TCP
TargetPort:        27017/TCP
Endpoints:         
192.168.16.8:27017,192.168.208.3:27017,192.168.64.9:27017
Session Affinity:  None
Events:            <none>
Run Code Online (Sandbox Code Playgroud)

mongodb 集群功能正常,我可以通过本地主机或使用单独的(非无头)服务(例如mongo "mongodb://mongodb.mongo.svc.cluster.local"。 …

mongodb kubernetes

8
推荐指数
1
解决办法
3211
查看次数

标签 统计

kubernetes ×1

mongodb ×1