基于centos 7搭建kubernetes集群

转自:http://blog.51cto.com/itdby/1980018

一、实验环境

3台centos7的主机:

master 192.168.111.131部署etcd,kube-apiserver,kube-controller-manager,kube-scheduler 4个应用。

node01 192.168.111.130 部署docker,kubelet, kube-proxy 3个应用

node02 192.168.111.129 部署docker,kubelet, kube-proxy 3个应用


二、实验步骤

1. 修改主机名和ip,三个主机网卡均设置为桥接模式,能够联网。

修改主机名:
hostnamectl set-hostname master
hostnamectl set-hostname node1
hostnamectl set-hostname node2
查看:
vi /etc/hostname
重启:
reboot

2. 分别修改/etc/hosts文件:
  • Master配置

#vim /etc/hosts

Node01
#scp root@192.168.111.128:/etc/hosts /etc/

Node02
#scp root@192.168.111.128:/etc/hosts /etc/

3. 三台均设置防火墙的默认区域为trusted。

4. 三台均关闭selinux

vi /etc/selinux/config
将SELINUX=enforcing改为SELINUX=disabled
设置后需要重启才能生效

5. 三台均安装docker,并启动。因为master之后还需要做registry仓库,所以也需要安装docker.

#yum install -y docker

请参考centos7安装docker;

6. 三台均开启路由转发功能:

7、实现node01和node02之间容器互通。

1)node01和node02新建网桥,并固定网桥ip。

node01上操作:

删除网桥docker0,新建网桥kbr0:

首先安装网桥管理工具brctl:yum install bridge-utils

新建网桥的配置文件:

新建路由文件:route-eth0,eth0为node1上的网卡名。

修改docker配置文件,添加-b=kbr0参数

reboot重启系统使网桥设置生效。

2)对node02做同样的设置:

新建网桥:

新建网桥配置文件:

· #scp root@192.168.111.129:/etc/sysconfig/network-scripts/ifcfg-kbr0 /etc/sysconfig/network-scripts/

创建路由文件:

修改docker 配置文件:

#vim /etc/sysconfig/docker

重启系统reboot.

3)系统启动之后,查看网卡信息和路由信息。

#ifconfig


4)验证两个宿主机间容器的互通性:

  • node01上运行一个容器:

  • node02上运行一个容器:

  • 容器间互ping:

#docker run -it docker.io/centos:centos6

# yum install -y iputils 进入容器安装

#dcoker run -it docker.io/centos:centos6

master上部署应用:

1、安装etcd.

查看etcd配置文件:

2、修改配置文件:

3、启动etcd服务:

查看服务端口号:

4、部署k8s-master组件(apiserver+controller-manager+scheduler)

安装软件:

#yum install -y kubernetes-master

查看配置文件:

5、修改配置文件:

#vim /etc/kubernetes/config

解释:

KUBE_LOGTOSTDERR 日志设置

KUBE_LOG_KEVEL 日志级别设置

KUBE_ALLOW_PRIV 是否允许运行特权容器

KUBE_MASTER 主节点的地址,主要为replication controller和scheduler及kubelet可以顺利找到apiserver

#vim /etc/kubernetes/apiserver

KUBE_API_ADDRESS 监听的接口,如果配置为127.0.0.1则只监听localhost,配置为0.0.0.0会监听所有接口,这里配置为0.0.0.0。

KUBE_API_PORT="--port=8080" apiserver的监听端口,默认8080,不用修改。

KUBELET_PORT="--kubelet_port=10250" kubelet监听的端口,默认10250,无需修改

KUBE_ETCD_SERVERS //指定etcd节点的地址

KUBE_SERVICE_ADDRESSES 这个是设置今后运行Service所在的ip网段

KUBE_API_ARGS=”--secure-port=0” 默认是要求https安全通信,”--secure-port=0”则不要求https安全通信

注:这里需要注意原来KUBE_ADMISSION_CONTROL默认包含的要删掉,不然启动API server的时候会报错

6、启动服务:

查看服务端口:

部署node主机:

1、安装kubernetes-node软件:

#yum install -y kubernetes-node

2、修改配置文件:

#vim /etc/kubernetes/config

#vim /etc/kubernetes/kubelet

配置项KUBELET_POD_INFRA_CONTAINER="--pod-infra-container-image=registry.access.redhat.com/rhel7/pod-infrastructure:latest"作用k8s创建pod的时候需要起一个基本容器,所以node节点要能连网。也可以自己搭建一个私有仓库,将pod-infrastructure:latest镜像上传到私有仓库中,修改此配置文件的地址就可以。

3、启动服务:

4、在node02主机上重复上面的操作。

5、在master上检查node 状态:

建私有仓库:

Kubernetes管理容器如果是第一次操作,可能会有一定的等待时间,这是因为第一次下载images需要一段时间。如果本地没有docker registry,要确保节点能访问互联网,所以我们可以搭建一个私有仓库,由私有仓库提供所需要的镜像,

本实验环境中用kubernetes同时作为registry。

1、导入镜像:

2、基于私有仓库镜像运行容器

3、本地访问私有仓库:

4、上传镜像到私有仓库。

  • 导入之后用到的镜像到本地

  • 给基础镜像打个标签:

  • 在三台主机上均修改docker 的配置文件,指定私有仓库的url.

  • 重启docker服务:

  • 上传镜像到私有仓库并查看:

  • 测试,下载刚才上传的镜像:

部署web应用

1、为了部署pod的时候,下载镜像速度快点,把node节点主机配置文件中的pod镜像下载地址修改为本地私有仓库地址:

#vim /etc/kubernetes/kubelet

#systemctl restart kubelet.service

2、创建apache-rc.yaml文件,根据文件内容创建rc和pod。

注意:必须按照此格式编写否则会报错

#kubectl create -f apache-rc.yaml

error: error validating "apache-rc.yaml": error validating data: found invalid field spec for v1.ReplicationControllerSpec; if you choose to ignore these errors, turn validation off with --validate=false

  • 查看pods状态:

  • 查看pods详细状态:

附:删除pod

kubectl delete pod podName

由于设置了两份副本,所以删除pod的时候,k8s会迅速起另外一个一模一样的pod以保持副本数量为2不变。

要彻底删除pod,只能删除创建它的replication controller

查看replication controller

kubectl get rc

删除replication controller

kubectl delete rc rcName

删除rc之后,其创建的pod会一并删除

3、部署节点内部可访问的apache service

Server的type有ClusterIP和 NodePort之分,缺省是ClusterIp,这种类型的service只能在集群内部访问

  • 创建配置文件:

#vim apache-service-clusterip.yaml

  • 创建service:

  • 查看service状态:

  • 验证apache服务:(在node节点执行)

4、部署外部可访问的apache service。

创建nodeport类型的service . 这种类型的Service在集群外部是可以访问

#vim apache-nodeport-service.yaml

  • 创建service:

  • 查看service:

验证service的可访问性:

外部访问:

内部访问:


到此为止kubernetes 集群搭建完毕!!!

三、错误总结

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,367评论 6 512
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,959评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,750评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,226评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,252评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,975评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,592评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,497评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,027评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,147评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,274评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,953评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,623评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,143评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,260评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,607评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,271评论 2 358

推荐阅读更多精彩内容