如何为 mongo 配置 dns 解析以从 k8s 集群内部连接到 atlas

how to configure dns resolution for mongo to connect to atlas from inside a k8s cluster

我发现有几个 pages 有类似的问题,大多数答案告诉我们将 IP 列入白名单。但是我允许从图集中的任何地方 0.0.0.0/0 访问,并安装了最新版本的 mongoose(6.2.6 ; 它应该支持协议 (mongodb+srv ).

当我 运行 在本地使用 npm start 甚至从 dockerized 容器时,连接工作正常。但是,当我部署到 k8s 集群时,我收到一条错误消息:

querySrv ENOTFOUND _mongodb._tcp.mongodb-cluster0.zvnxj.mongodb.net

部署和服务文件如下:

deployment.yml

apiVersion: apps/v1
kind: Deployment
metadata:
  namespace: ns-my-workflow-api
  name: my-workflow-api
spec:
  replicas: 2
  selector:
    matchLabels:
      app: my-workflow-api
  template:
    metadata:
      labels: 
        app: my-workflow-api
    spec:
      containers:
        - name: my-workflow-api
          image: "myname/my-workflow-api:1.0.0"
          ports:
            - containerPort: 3000
          imagePullPolicy: IfNotPresent
          resources:
              limits:
                cpu: "256m"   

service.yaml 包含以下内容:

apiVersion: v1
kind: Service
metadata:
  namespace: ns-my-workflow-api
  name: my-workflow-api
spec:
  selector:
    app: my-workflow-api
  type: LoadBalancer
  ports:
    - name: http
      port: 8000
      targetPort: 3000
      protocol: TCP  

namespace.yaml的内容是:

apiVersion: v1
kind: Namespace
metadata:
  name: ns-my-workflow-api

我还尝试了 deployment.yamldns 规则:

apiVersion: apps/v1
kind: Deployment
metadata:
  namespace: ns-my-workflow-api
  name: my-workflow-api
spec:
  replicas: 2
  selector:
    matchLabels:
      app: my-workflow-api
  template:
    metadata:
      labels: 
        app: my-workflow-api
    spec:
      dnsPolicy: Default            # <------ this rule
      containers:
        - name: my-workflow-api
          image: "myname/my-workflow-api:1.0.0"
          ports:
            - containerPort: 3000
          imagePullPolicy: IfNotPresent
          resources:
              limits:
                cpu: "256m"

一旦我将连接 url 更改为使用 2.0.14 or earlier,我就能够连接了。连接字符串以 mongodb://....

开头

虽然我已经设法通过使用旧式连接字符串的解决方法使连接正常工作,而且这似乎是某种 dns 解析问题,但我如何使较新的协议能够连接到 atlas集群内?提前致谢

我可以用这个来解决它 minikube:

minikube start --driver=docker

底层 oracle 的 virtualbox 驱动程序似乎存在一些 dns 解析问题(可能还有一些配置和设置问题)