• 编写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等参数即可!