- 编写k8s-mysql-endpoints.yaml,为外部Mysql创建Endpoints
apiVersion: v1 kind: Endpoints metadata: name: mysql namespace: default subsets: - addresses: - ip: 192.168.1.11 ports: - port: 20030
1、可以使用命令kubectl get endpoints查看是否创建完成
2、kubectl describe endpoints mysql 查看具体描述
- 编写k8s-mysql-service.yaml,为endpoints发布成内部pod可以调用的服务
注意metadata.name与k8s-mysql-endpoints.yaml中metadata.name保持一致,此处均为mysql
apiVersion: v1 kind: Service metadata: name: mysql spec: ports: - port: 20030
1、可以使用命令kubectl get svc查看是否服务创建完成
2、kubectl describe svc mysql 查看具体服务描述
- 为了方便测试endpoints是否生效,我们修改上述的k8s-mysql-service.yaml配置
1、我们将type类型改为NodePort,这样可以设定宿主机上的映射端口号nodePort:30030,这样直接通过宿主机IP:30030就可以调用到mysql服务。
2、注意删除了创建好的service,对应的endpoints也会删除掉,需要重新创建!测试的时候注意!
apiVersion: v1 kind: Service metadata: name: mysql spec: type: NodePort ports: - port: 20030 targetPort: 20030 protocol: TCP nodePort: 30030
- 使用Navicat测试,输入宿主机IP和端口30030(用户名密码还是外部数据库原本的用户名密码),测试连接!成功!证明了通过Endpoints机制可以将外部服务发布成k8s内部的服务!
发布外部的redis服务也是同理,只需要修改name、port、ip等参数即可!