kubernetes集群发布外部服务【mysql、redis并测试】
编写k8s-mysql-endpoints.yaml,为外部Mysql创建EndpointsapiVersion: v1kind: Endpointsmetadata:name: mysqlnamespace: defaultsubsets:- addresses:- ip: 192.168.1.11ports:- port: 20...
·
- 编写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等参数即可!
更多推荐
已为社区贡献17条内容
所有评论(0)