enz*_*902 5 mongodb kubernetes rancher
在 Rancher 中使用 Amazon EKS 创建的集群。
MongoDB 副本集是作为 Rancher 中的目录应用程序创建的。
集群中的服务可以通过这个连接字符串成功连接数据库。
mongodb://mongodb-replicaset.mongodb-replicaset.svc.cluster.local:27017/tradeit_system?replicaSet=rs
我想查看和编辑数据库中的数据。在本地数据库中,您可以通过命令轻松完成mongo --port 27017
。
同样有一种方法可以连接到 kubernetes 上的那个。是从终端还是使用像 Robo 3t 这样的应用程序?
编辑
当我这样做时,副本集不显示。
kubectl get deployments --all-namespace
kubectl get pods --all-namespaces
显示它在 3 个 pod 中运行:mongodb-replicaset-0、mongodb-replicaset-1、mongodb-replicaset-2。
小智 5
kubectl get services -n <namespace>
。这将列出副本集服务kubectl port-forward svc/mongodb-replicaset -n mongoNamespace 27018:27017
在哪里
mongodb-replicaset = mongodb 服务名称
mongoNamespace = 命名空间
和27018 = 您的本地端口
作为最佳实践,您应该始终连接服务而不是 Pod。由于 Pod 会自动重新创建/重新启动,因此它会给您一个新的 Pod 名称。连接到服务可以避免重新连接和查找 mongodb 副本集的主 pod。
执行后kubectl get pods
,您将看到 Pod 的名称。
您可以使用以下命令连接到任何 pod:kubectl exec -it POD_NAME /bin/bash
。另请检查文档中的“在容器中执行命令”。
另外,连接到 后POD
,您可以使用 来检查 mongo 位于哪里whereis mongo
。
我认为默认安装位于/usr/bin/mongo
,因此在连接到集群时,您可以mongo
直接从您喜欢使用的任何 pod进行调用kubectl exec -it POD_NAME /usr/bin/mongo
。
归档时间: |
|
查看次数: |
4996 次 |
最近记录: |