gpt4 book ai didi

sql-server - 无法从 Kubernetes 连接到本地主机上托管的 SQL Server 数据库,如何调试?

转载 作者:行者123 更新时间:2023-12-03 03:13:20 26 4
gpt4 key购买 nike

我正在尝试在 Kubernetes 中部署 ASP.NET Core 2.2 应用程序。该应用程序是一个简单的网页,需要访问 SQL Server 数据库才能显示一些信息。该数据库托管在我的本地开发计算机 (localhost) 上,Web 应用程序部署在 minikube 集群中,以模拟生产环境,在该环境中我的 Web 应用程序可以部署在云中并访问远程数据库。

我设法通过公开端口 80 来显示我的 Web 应用程序。但是,我不知道如何使我的 Web 应用程序从集群内部连接到本地计算机上托管的 SQL Server 数据库。

我假设我的连接字符串是正确的,因为当我将其部署在 IIS 本地服务器、docker 容器(docker run)或 docker 服务(docker create service)中时,我的 Web 应用程序可以连接到 SQL Server 数据库,但是部署在 Kubernetes 集群中时则不然。我知道集群位于不同的网络中,因此我尝试创建一个没有选择器的服务,如 this question 中所述。 ,但没有运气...我什至尝试更改连接字符串IP地址以匹配创建的服务之一,但它也失败了。

我的防火墙设置为接受 1433 端口的入站连接。

My SQL Server 数据库配置为允许远程访问。

这是我使用的连接字符串:

"Server=172.24.144.1\\MyServer,1433;Database=TestWebapp;User Id=user_name;Password=********;"

这是我用来部署 Web 应用程序的文件:

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: webapp
spec:
replicas: 1
template:
metadata:
labels:
app: webapp
spec:
containers:
- name: webapp
image: <private_repo_url>/webapp:db
imagePullPolicy: Always
ports:
- containerPort: 80
- containerPort: 443
- containerPort: 1433
imagePullSecrets:
- name: gitlab-auth
volumes:
- name: secrets
secret:
secretName: auth-secrets
---
apiVersion: v1
kind: Service
metadata:
name: webapp
labels:
app: webapp
spec:
type: NodePort
selector:
app: webapp
ports:
- name: port-80
port: 80
targetPort: 80
nodePort: 30080
- name: port-443
port: 443
targetPort: 443
nodePort: 30443
---
apiVersion: v1
kind: Service
metadata:
name: sql-server
labels:
app: webapp
spec:
ports:
- name: port-1433
port: 1433
targetPort: 1433
---
apiVersion: v1
kind: Endpoints
metadata:
name: sql-server
labels:
app: webapp
subsets:
- addresses:
- ip: 172.24.144.1 <-- IP of my local computer where SQL Server is running
ports:
- port: 1433

因此,我得到了一个名为“webapp”的部署,其中只有一个 pod、两个名为“webapp”和“sql-server”的服务以及两个也名为“webapp”和“sql-server”的端点。以下是他们的详细信息:

> kubectl describe svc webapp
Name: webapp
Namespace: default
Labels: app=webapp
Annotations: <none>
Selector: app=webapp
Type: NodePort
IP: 10.108.225.112
Port: port-80 80/TCP
TargetPort: 80/TCP
NodePort: port-80 30080/TCP
Endpoints: 172.17.0.4:80
Port: port-443 443/TCP
TargetPort: 443/TCP
NodePort: port-443 30443/TCP
Endpoints: 172.17.0.4:443
Session Affinity: None
External Traffic Policy: Cluster
Events: <none>

> kubectl describe svc sql-server
Name: sql-server
Namespace: default
Labels: app=webapp
Annotations: <none>
Selector: <none>
Type: ClusterIP
IP: 10.107.142.32
Port: port-1433 1433/TCP
TargetPort: 1433/TCP
Endpoints:
Session Affinity: None
Events: <none>

> kubectl describe endpoints webapp
Name: webapp
Namespace: default
Labels: app=webapp
Annotations: <none>
Subsets:
Addresses: 172.17.0.4
NotReadyAddresses: <none>
Ports:
Name Port Protocol
---- ---- --------
port-443 443 TCP
port-80 80 TCP

Events: <none>

> kubectl describe endpoints sql-server
Name: sql-server
Namespace: default
Labels: app=webapp
Annotations: <none>
Subsets:
Addresses: 172.24.144.1
NotReadyAddresses: <none>
Ports:
Name Port Protocol
---- ---- --------
<unset> 1433 TCP

Events: <none>

我期望连接到 SQL Server 数据库,但是当我的应用程序尝试打开连接时,我收到此错误:

SqlException: A network-related or instance-specific error occurred while establishing a connection to SQL Server. The server was not found or was not accessible. Verify that the instance name is correct and that SQL Server is configured to allow remote connections. (provider: TCP Provider, error: 40 - Could not open a connection to SQL Server)

我是 Kubernetes 新手,对网络不太熟悉,因此欢迎任何帮助。最好的帮助是给我一些建议/工具来调试这个问题,因为我什至不知道连接尝试何时何地被阻止......

谢谢!

最佳答案

您认为主机的 IP 地址是内部网络的私有(private) IP。该 IP 地址可能是您的计算机在您正在使用的“真实”网络上使用的 IP 地址。 kubernetes 虚拟网络位于不同的子网上,因此 - 您内部使用的 IP 无法访问。

subsets: 
- addresses:
- ip: 172.24.144.1 <-- IP of my local computer where SQL Server is running
ports:
- port: 1433

您可以通过 DNS 条目host.docker.internal进行连接 了解更多 herehere for windows

我不确定这在 minicube 中是否有效 - 主机的 linux/windows 实现曾经有一个不同的 DNS 名称。

如果您想使用该 IP(请记住它最终会改变),您可以追踪它并确保它是虚拟子网中“可见”的 IP。

PS:我现在使用的是 docker 上的 kubernetes,看起来更容易使用。

关于sql-server - 无法从 Kubernetes 连接到本地主机上托管的 SQL Server 数据库,如何调试?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53944826/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com