本文依赖环境:Centos7部署Kubernetes集群、基于Kubernetes集群部署skyDNS服务
该示例中,我们将创建一个redis-master、两个redis-slave、三个frontend。其中,slave会实时备份master中数据,frontend会向master中写数据,之后会从slave中读取数据。所有系统间的调用(例如slave找master同步数据;frontend找master写数据;frontend找slave读数据等),采用的是dns方式实现。
本示例中依赖以下几个镜像,请提前准备好:
1)redis-master-controller.yaml
2)redis-master-service.yaml
Master上执行:
1)redis-slave-controller.yaml
2)redis-slave-service.yaml
Master上执行:
1)frontend-controller.yaml
2)frontend-service.yaml
Master上执行:
至此,Guestbook已经运行在了kubernetes中了,但是外部是无法通过通过frontend-service的IP10.0.93.91这个IP来进行访问的。Service的虚拟IP是kubernetes虚拟出来的内部网络,在外部网络中是无法寻址到的,这时候就需要增加一层外网到内网的网络转发。我们的示例中采用的是NodePort的方式实现的,之前在创建frontend-service时设置了nodePort: 30001,即kubernetes将会在每个Node上设置端口,成为NodePort,通过NodePort端口可以访问到真正的服务。