基于Kubernetes集群部署完整示例——Guestbook

640?wx_fmt=gif


本文依赖环境:Centos7部署Kubernetes集群、基于Kubernetes集群部署skyDNS服务

  该示例中,我们将创建一个redis-master、两个redis-slave、三个frontend。其中,slave会实时备份master中数据,frontend会向master中写数据,之后会从slave中读取数据。所有系统间的调用(例如slave找master同步数据;frontend找master写数据;frontend找slave读数据等),采用的是dns方式实现。

1、准备工作

1.1镜像准备

  本示例中依赖以下几个镜像,请提前准备好:

640?wx_fmt=png

  需要一套kubernetes运行环境,及Cluster DNS,如下:1.2环境准备

640?wx_fmt=png

2、运行redis-master

2.1yaml文件

  1)redis-master-controller.yaml

640?wx_fmt=png

  2)redis-master-service.yaml

640?wx_fmt=png

2.2创建rc及service

  Master上执行:

640?wx_fmt=png

3、运行redis-slave

3.1yaml文件

  1)redis-slave-controller.yaml

640?wx_fmt=png

  2)redis-slave-service.yaml

640?wx_fmt=png

3.2创建rc及service

  Master上执行:

640?wx_fmt=png

4、运行frontend

4.1yaml文件

  1)frontend-controller.yaml

640?wx_fmt=png

  2)frontend-service.yaml

640?wx_fmt=png

4.2创建rc及service

  Master上执行:

640?wx_fmt=png

4.3页面验证

  至此,Guestbook已经运行在了kubernetes中了,但是外部是无法通过通过frontend-service的IP10.0.93.91这个IP来进行访问的。Service的虚拟IP是kubernetes虚拟出来的内部网络,在外部网络中是无法寻址到的,这时候就需要增加一层外网到内网的网络转发。我们的示例中采用的是NodePort的方式实现的,之前在创建frontend-service时设置了nodePort: 30001,即kubernetes将会在每个Node上设置端口,成为NodePort,通过NodePort端口可以访问到真正的服务。

640?wx_fmt=png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值