基于centos 7搭建kubernetes集群

轉(zhuǎn)自:http://blog.51cto.com/itdby/1980018

一、實(shí)驗(yàn)環(huán)境

3臺(tái)centos7的主機(jī):

master 192.168.111.131部署etcd,kube-apiserver,kube-controller-manager,kube-scheduler 4個(gè)應(yīng)用。

node01 192.168.111.130 部署docker,kubelet, kube-proxy 3個(gè)應(yīng)用

node02 192.168.111.129 部署docker,kubelet, kube-proxy 3個(gè)應(yīng)用


二、實(shí)驗(yàn)步驟

1. 修改主機(jī)名和ip,三個(gè)主機(jī)網(wǎng)卡均設(shè)置為橋接模式,能夠聯(lián)網(wǎng)。

修改主機(jī)名:
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. 三臺(tái)均設(shè)置防火墻的默認(rèn)區(qū)域?yàn)閠rusted。

4. 三臺(tái)均關(guān)閉selinux

vi /etc/selinux/config
將SELINUX=enforcing改為SELINUX=disabled
設(shè)置后需要重啟才能生效

5. 三臺(tái)均安裝docker,并啟動(dòng)。因?yàn)閙aster之后還需要做registry倉(cāng)庫(kù),所以也需要安裝docker.

#yum install -y docker

請(qǐng)參考centos7安裝docker;

6. 三臺(tái)均開啟路由轉(zhuǎn)發(fā)功能:

7、實(shí)現(xiàn)node01和node02之間容器互通。

1)node01和node02新建網(wǎng)橋,并固定網(wǎng)橋ip。

node01上操作:

刪除網(wǎng)橋docker0,新建網(wǎng)橋kbr0:

首先安裝網(wǎng)橋管理工具brctl:yum install bridge-utils

新建網(wǎng)橋的配置文件:

新建路由文件:route-eth0,eth0為node1上的網(wǎng)卡名。

修改docker配置文件,添加-b=kbr0參數(shù)

reboot重啟系統(tǒng)使網(wǎng)橋設(shè)置生效。

2)對(duì)node02做同樣的設(shè)置:

新建網(wǎng)橋:

新建網(wǎng)橋配置文件:

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

創(chuàng)建路由文件:

修改docker 配置文件:

#vim /etc/sysconfig/docker

重啟系統(tǒng)reboot.

3)系統(tǒng)啟動(dòng)之后,查看網(wǎng)卡信息和路由信息。

#ifconfig


4)驗(yàn)證兩個(gè)宿主機(jī)間容器的互通性:

  • node01上運(yùn)行一個(gè)容器:

  • node02上運(yùn)行一個(gè)容器:

  • 容器間互ping:

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

# yum install -y iputils 進(jìn)入容器安裝

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

master上部署應(yīng)用:

1、安裝etcd.

查看etcd配置文件:

2、修改配置文件:

3、啟動(dòng)etcd服務(wù):

查看服務(wù)端口號(hào):

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

安裝軟件:

#yum install -y kubernetes-master

查看配置文件:

5、修改配置文件:

#vim /etc/kubernetes/config

解釋:

KUBE_LOGTOSTDERR 日志設(shè)置

KUBE_LOG_KEVEL 日志級(jí)別設(shè)置

KUBE_ALLOW_PRIV 是否允許運(yùn)行特權(quán)容器

KUBE_MASTER 主節(jié)點(diǎn)的地址,主要為replication controller和scheduler及kubelet可以順利找到apiserver

#vim /etc/kubernetes/apiserver

KUBE_API_ADDRESS 監(jiān)聽的接口,如果配置為127.0.0.1則只監(jiān)聽localhost,配置為0.0.0.0會(huì)監(jiān)聽所有接口,這里配置為0.0.0.0。

KUBE_API_PORT="--port=8080" apiserver的監(jiān)聽端口,默認(rèn)8080,不用修改。

KUBELET_PORT="--kubelet_port=10250" kubelet監(jiān)聽的端口,默認(rèn)10250,無需修改

KUBE_ETCD_SERVERS //指定etcd節(jié)點(diǎn)的地址

KUBE_SERVICE_ADDRESSES 這個(gè)是設(shè)置今后運(yùn)行Service所在的ip網(wǎng)段

KUBE_API_ARGS=”--secure-port=0” 默認(rèn)是要求https安全通信,”--secure-port=0”則不要求https安全通信

注:這里需要注意原來KUBE_ADMISSION_CONTROL默認(rèn)包含的要?jiǎng)h掉,不然啟動(dòng)API server的時(shí)候會(huì)報(bào)錯(cuò)

6、啟動(dòng)服務(wù):

查看服務(wù)端口:

部署node主機(jī):

1、安裝kubernetes-node軟件:

#yum install -y kubernetes-node

2、修改配置文件:

#vim /etc/kubernetes/config

#vim /etc/kubernetes/kubelet

配置項(xiàng)KUBELET_POD_INFRA_CONTAINER="--pod-infra-container-image=registry.access.redhat.com/rhel7/pod-infrastructure:latest"作用k8s創(chuàng)建pod的時(shí)候需要起一個(gè)基本容器,所以node節(jié)點(diǎn)要能連網(wǎng)。也可以自己搭建一個(gè)私有倉(cāng)庫(kù),將pod-infrastructure:latest鏡像上傳到私有倉(cāng)庫(kù)中,修改此配置文件的地址就可以。

3、啟動(dòng)服務(wù):

4、在node02主機(jī)上重復(fù)上面的操作。

5、在master上檢查node 狀態(tài):

建私有倉(cāng)庫(kù):

Kubernetes管理容器如果是第一次操作,可能會(huì)有一定的等待時(shí)間,這是因?yàn)榈谝淮蜗螺dimages需要一段時(shí)間。如果本地沒有docker registry,要確保節(jié)點(diǎn)能訪問互聯(lián)網(wǎng),所以我們可以搭建一個(gè)私有倉(cāng)庫(kù),由私有倉(cāng)庫(kù)提供所需要的鏡像,

本實(shí)驗(yàn)環(huán)境中用kubernetes同時(shí)作為registry。

1、導(dǎo)入鏡像:

2、基于私有倉(cāng)庫(kù)鏡像運(yùn)行容器

3、本地訪問私有倉(cāng)庫(kù):

4、上傳鏡像到私有倉(cāng)庫(kù)。

  • 導(dǎo)入之后用到的鏡像到本地

  • 給基礎(chǔ)鏡像打個(gè)標(biāo)簽:

  • 在三臺(tái)主機(jī)上均修改docker 的配置文件,指定私有倉(cāng)庫(kù)的url.

  • 重啟docker服務(wù):

  • 上傳鏡像到私有倉(cāng)庫(kù)并查看:

  • 測(cè)試,下載剛才上傳的鏡像:

部署web應(yīng)用

1、為了部署pod的時(shí)候,下載鏡像速度快點(diǎn),把node節(jié)點(diǎn)主機(jī)配置文件中的pod鏡像下載地址修改為本地私有倉(cāng)庫(kù)地址:

#vim /etc/kubernetes/kubelet

#systemctl restart kubelet.service

2、創(chuàng)建apache-rc.yaml文件,根據(jù)文件內(nèi)容創(chuàng)建rc和pod。

注意:必須按照此格式編寫否則會(huì)報(bào)錯(cuò)

#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狀態(tài):

  • 查看pods詳細(xì)狀態(tài):

附:刪除pod

kubectl delete pod podName

由于設(shè)置了兩份副本,所以刪除pod的時(shí)候,k8s會(huì)迅速起另外一個(gè)一模一樣的pod以保持副本數(shù)量為2不變。

要徹底刪除pod,只能刪除創(chuàng)建它的replication controller

查看replication controller

kubectl get rc

刪除replication controller

kubectl delete rc rcName

刪除rc之后,其創(chuàng)建的pod會(huì)一并刪除

3、部署節(jié)點(diǎn)內(nèi)部可訪問的apache service

Server的type有ClusterIP和 NodePort之分,缺省是ClusterIp,這種類型的service只能在集群內(nèi)部訪問

  • 創(chuàng)建配置文件:

#vim apache-service-clusterip.yaml

  • 創(chuàng)建service:

  • 查看service狀態(tài):

  • 驗(yàn)證apache服務(wù):(在node節(jié)點(diǎn)執(zhí)行)

4、部署外部可訪問的apache service。

創(chuàng)建nodeport類型的service . 這種類型的Service在集群外部是可以訪問

#vim apache-nodeport-service.yaml

  • 創(chuàng)建service:

  • 查看service:

驗(yàn)證service的可訪問性:

外部訪問:

內(nèi)部訪問:


到此為止kubernetes 集群搭建完畢!!!

三、錯(cuò)誤總結(jié)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,619評(píng)論 6 539
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,155評(píng)論 3 425
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,635評(píng)論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,539評(píng)論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,255評(píng)論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,646評(píng)論 1 326
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,655評(píng)論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,838評(píng)論 0 289
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,399評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,146評(píng)論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,338評(píng)論 1 372
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,893評(píng)論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,565評(píng)論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,983評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,257評(píng)論 1 292
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,059評(píng)論 3 397
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,296評(píng)論 2 376

推薦閱讀更多精彩內(nèi)容