如何为 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.yaml
和 dns
规则:
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 解析问题(可能还有一些配置和设置问题)
我发现有几个 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.yaml
和 dns
规则:
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 解析问题(可能还有一些配置和设置问题)