《kubernetes 权威指南》第一章 demo 纠正

最近研究kubernete,以《kubernete 权威指南》入门。

第一章给了个以redis为后端php为前端的demo。试了半天才成功(因为版本更新原因吧)。

现在列出在centos7上做成demo步骤。


1.  内核及软件版本 

# cat /etc/redhat-release 
CentOS Linux release 7.2.1511 (Core) 

# rpm -qa |grep kubernete
kubernetes-client-1.2.0-0.12.gita4463d9.el7.x86_64
kubernetes-1.2.0-0.12.gita4463d9.el7.x86_64
kubernetes-master-1.2.0-0.12.gita4463d9.el7.x86_64
kubernetes-node-1.2.0-0.12.gita4463d9.el7.x86_64


2.  pull image

作者在hub.docker.com上挂出来镜像。因为你懂的原因,下载速度实在是非常蛋疼。

所以建议事先下载好。

然后其他环境需要的话,直接docker save/load 就可以了,不需要再次下载。

P.S.  但是启动pod时候,kubernetes默认会跳过我们环境中已经导入的镜像,而从网上重新pull。为了避免重复下载,只需要改个参数就行。后续会介绍。


3. 修改controller文件。

上面说到:kubernetes默认会跳过我们环境中已经导入的镜像,而从网上重新pull。所以我们只需要在controller文件中添加下列语句就好:

# cat redis-master-controller.yaml 
apiVersion: v1
kind: ReplicationController
  .....  (omit) .........
      - name: master
        image: kubeguide/redis-master
      imagePullPolicy: IfNotPresent          <--- 加上这个。每个controller文件都要加。这就代表如果环境中有image就不用重新下。
        ports:
        - containerPort: 6379


4. 先创建service,再创建RC

虽然书中说谁先谁后没关系,但是我亲自验证后发现,如果先创建RC,再创建service的话:启动的container里面,会丢失pod中通信用到的env:REDIS开头的一堆env都会丢失。

所以必须先创建service,再创建对应的RC


下图是无REDIS的container:



下图是有REDIS的container:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值