kubernetes集群发布外部服务【mysql、redis并测试】


有时候我们需要将k8s集群外的服务引入到集群内部来,便于集群内部服务调用,我可以使用Endpoints.

引入外部myql

编写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

编写k8s-mysql-service.yaml,为endpoints发布成内部pod可以调用的服务

注意metadata.namek8s-mysql-endpoints.yamlmetadata.name保持一致,此处均为mysql.

apiVersion: v1
kind: Service
metadata:
  name: mysql
spec:
  ports:
    - port: 20030
  1. 可以使用命令 kubectl get svc 查看是否服务创建完成
  2. kubectl describe svc mysql 查看具体服务描述

测试endpoints是否生效

为了方便测试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测试

使用Navicat测试,输入宿主机IP和端口30030(用户名密码还是外部数据库原本的用户名密码),测试连接!成功!证明了通过Endpoints机制可以将外部服务发布成k8s内部的服务!

发布外部的redis服务也是同理,只需要修改nameportip等参数即可!


文章作者: wuzhiyong
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 wuzhiyong !
评论
 上一篇
私有镜像仓库Harbor-v1.5.0搭建与使用 私有镜像仓库Harbor-v1.5.0搭建与使用
环境准备 安装docker-ce(过程省略) 安装docker-compose(过程省略) 安装harbor 下载Harbor离线安装包 下载地址:http://harbor.orientsoft.cn/,找个最新的,本文使用v1.5.0
2019-10-25
下一篇 
consul【在kubernetes集群中部署】 consul【在kubernetes集群中部署】
consul具体配置、ACL配置可以参考Consul系列文章 首先创建k8s-consul-config.json文件注意token需要自己创建一个,这里加密处理了 { "datacenter":"dc8", "prim
2019-10-18
  目录