我在每个命名空间中创建了两个命名空间和服务:
- 命名空间:应用层
- 休息应用
- 数据库服务外部名称
- 命名空间:数据层
- 数据库服务
当我尝试从 连接到 DB Service 中的 MySQL 数据库时rest-app
,出现错误:
MySql.Data.MySqlClient.MySqlException (0x80004005):无法连接到任何指定的 MySQL 主机。---> System.AggregateException:发生一个或多个错误。(名称或服务未知)
我在日志中打印出来,它正确地具有db-service
服务名称,并且具有正确的用户/通行证。
这是我定义的:
数据库服务
apiVersion: v1
kind: Service
metadata:
name: db-service
namespace: data-layer
spec:
selector:
app: db-service
ports:
- port: 3306
clusterIP: None
数据库服务外部名称
apiVersion: v1
kind: Service
metadata:
name: db-service
namespace: app-layer
spec:
type: ExternalName
externalName: db-service.data-layer.service.cluster.local
ports:
- port: 3306
休息应用
apiVersion: apps/v1
kind: Deployment
metadata:
name: rest-app
namespace: app-layer
labels:
app: rest-app
spec:
replicas: 1
selector:
matchLabels:
app: rest-app
template:
metadata:
labels:
app: rest-app
spec:
containers:
- name: rest-app
image: restapp:latest
imagePullPolicy: Always
ports:
- containerPort: 5000
env:
# These are from a secret I defined, and the logs show
# the rest app gets them correctly
- name: MYSQL_ROOT_USERNAME
valueFrom:
secretKeyRef:
name: db-credentials
key: db-username
- name: MYSQL_ROOT_PASSWORD
valueFrom:
secretKeyRef:
name: db-credentials
key: db-password
# I hard-coded this to the externalName I created.
# Is that right?
- name: MYSQL_URL
value: db-service
问题:
- 在应用层命名空间中创建 externalName 是否正确?
- 我需要以不同的方式定义它吗?
- docker容器中的C#应用程序不能引用
db-service
externalName服务的名称吗?