摘要:是谷歌官方根據(jù)自己容器經(jīng)驗開源的產(chǎn)品。當(dāng)然,這不可能是,而且它的底層是替換成了,但是這不能掩蓋它解決的問題。因此筆者決定嘗試玩玩。不然啟動會報錯。
背景
容器技術(shù)在目前很火,而且確確實實的解決了很多的痛點,但是如果只使用目前 Docker 官方提供的 engine+compose+swarm 方案,是很難再實際生產(chǎn)中使用的。Kubernetes 是谷歌官方根據(jù)自己容器經(jīng)驗 Borg 開源的產(chǎn)品。當(dāng)然,這不可能是 Borg,而且它的底層是替換成了 Docker,但是這不能掩蓋它解決的問題。因此筆者決定嘗試玩玩。
架構(gòu)根據(jù)官方文檔的說明,Kubernetes 是使用 golang 寫成,并且依賴 coreos/etcd 和 docker/docker 產(chǎn)品,Kubernetes 實際上是個分布式的 master-slave 架構(gòu),主要有以下組件 api-server、controller-manager、scheduler、proxy、kubelet,前面三個分別是 API 接口服務(wù)器、管理控制器、調(diào)度器,而后面兩個則是網(wǎng)絡(luò)派發(fā)代理和實際和 Docker 溝通的 agent。
部署官方給出的下載安裝文檔簡直簡略的不能再簡略了,而使用 yum 等包管理工具安裝目前只能安裝 2.x 版本最新而沒有 3.x 的預(yù)編譯包,不過沒關(guān)系,我們可以直接下載預(yù)編譯安裝包。
etcdetcd 是 coreos 為了進行分布式部署所做的鍵值存儲服務(wù),Github release 上面可以直接下載到最新的預(yù)編譯包然后把其中的兩個二進制文件扔到 /usr/local/bin 目錄下就 ok 了。
至于配置文件和 systemd 單元文件也很簡單,官方 github 上面已經(jīng)提供了 systemd 啟動文件,首先是添加一個名為 etcd 的系統(tǒng)用戶(注意:是 daemon 用戶,別加上亂七八糟的東西)
[Unit] Description=etcd key-value store Documentation=https://github.com/coreos/etcd [Service] User=etcd Type=notify Environment=ETCD_DATA_DIR=/var/lib/etcd Environment=ETCD_NAME=%m ExecStart=/usr/bin/etcd Restart=always RestartSec=10s LimitNOFILE=40000 [Install] WantedBy=multi-user.target
而 etcd 實際上是使用環(huán)境變量作為配置的,具體可以參考 etcd 的 github 文檔,這里提供筆者的單元文件
[Unit] Description=etcd key-value store Documentation=https://github.com/coreos/etcd [Service] User=etcd Type=notify WorkingDirectory=/usr/local/var/lib/etcd ExecStart=/usr/local/bin/etcd Restart=on-failure RestartSec=10s LimitNOFILE=40000 [Install] WantedBy=multi-user.target
直接把工作目錄指定到 /usr/local/var/lib/etcd,這樣默認情況下所有的數(shù)據(jù)文件都會存放在 default.etcd 文件夾下,不過注意這個目錄需要手工創(chuàng)建并且制定合適的權(quán)限。不然 systemd 啟動會報錯。然后把啟動文件放到 /etc/systemd/system/etcd.service
如果說具體的配置需要配,則應(yīng)當(dāng)再指定 EnvironmentFile=/path/to 指定一個環(huán)境變量文件,所有的配置都通過環(huán)境變量配置。
基本思路跟上面一個樣,先下載二進制包,把二進制文件放到 /usr/local/bin 目錄下,然后就是 systemd 單元文件,官方也在 Github 上提供了單元文件,直接拿下來用
[Unit] Description=Docker Socket for the API PartOf=docker.service [Socket] ListenStream=/var/run/docker.sock SocketMode=0660 SocketUser=root SocketGroup=docker [Install] WantedBy=sockets.target [Unit] Description=Docker Application Container Engine Documentation=https://docs.docker.com After=network.target docker.socket firewalld.service Requires=docker.socket [Service] Type=notify # the default is not to use systemd for cgroups because the delegate issues still # exists and systemd currently does not support the cgroup feature set required # for containers run by docker ExecStart=/usr/bin/dockerd -H fd:// ExecReload=/bin/kill -s HUP $MAINPID LimitNOFILE=1048576 # Having non-zero Limit*s causes performance problems due to accounting overhead # in the kernel. We recommend using cgroups to do container-local accounting. LimitNPROC=infinity LimitCORE=infinity # Uncomment TasksMax if your systemd version supports it. # Only systemd 226 and above support this version. #TasksMax=infinity TimeoutStartSec=0 # set delegate yes so that systemd does not reset the cgroups of docker containers Delegate=yes # kill only the docker process, not all processes in the cgroup KillMode=process [Install] WantedBy=multi-user.target
需要注意的是上面有兩個 systemd 文件,一個是 socket 啟動文件,一個是正常的 docker 啟動文件,這個特性來自于 1.12 版本,具體請參考官方的 ReleaseNote。
還有一點就是記得添加一個 docker 用戶組
同樣是下載二進制包解壓開來,進入 server 目錄,解壓 kubernetes-server-linux-amd64.tar.gz 文件,把解壓文件里的 5 個組件放到 /usr/local/bin 目錄(注意:就放上面提到的 5 個組件就行,其他的不用),還有一個就是 client 命令行 kubectl 文件。
然后添加 kube 系統(tǒng)用戶。
useradd -c "kubernetes user" -d / -M -r -s /sbin/nologin kube
然后就是官方提供的 systemd 文件 https://github.com/kubernetes... 這里就不深入講解了,因為實際上跟 etcd 基本一致,只不過 kubernetes 并不使用環(huán)境變量作為配置方式,所以必須在 systemd 啟動文件中將環(huán)境變量轉(zhuǎn)換為命令行參數(shù)傳入。
未完待續(xù)文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/32496.html
摘要:發(fā)布不到兩天,上數(shù)已近,這個業(yè)界大熱的史上最輕量的開源發(fā)行版,你試過了沒資深架構(gòu)師來教你走出嘗鮮第一步使用教程在此前言昨天,正式發(fā)布了一款史上最輕量的開源發(fā)行版。大小只有,極簡,輕便,易于使用。 發(fā)布不到兩天,GitHub上Star數(shù)已近3000,這個業(yè)界大熱的、史上最輕量的開源Kubernetes發(fā)行版,你試過了沒? Rancher資深架構(gòu)師來教你走出嘗鮮第一步!使用教程在此! sh...
摘要:是谷歌官方根據(jù)自己容器經(jīng)驗開源的產(chǎn)品。當(dāng)然,這不可能是,而且它的底層是替換成了,但是這不能掩蓋它解決的問題。因此筆者決定嘗試玩玩。不然啟動會報錯。 背景 容器技術(shù)在目前很火,而且確確實實的解決了很多的痛點,但是如果只使用目前 Docker 官方提供的 engine+compose+swarm 方案,是很難再實際生產(chǎn)中使用的。Kubernetes 是谷歌官方根據(jù)自己容器經(jīng)驗 Borg 開...
摘要:早在年針對高科技行業(yè)和高科技企業(yè)生命周期的特點,提出了著名的鴻溝理論。今天我們嘗試以鴻溝理論為基礎(chǔ)來分析云原生領(lǐng)域顛覆性的創(chuàng)新技術(shù)。回過頭來看,靈雀云從早期全力投入技術(shù)棧,是最早進行產(chǎn)品化的廠商。 歷史進入2019年,放眼望去,今天的整個技術(shù)大環(huán)境和生態(tài)都發(fā)生了很大的變化。在己亥豬年春節(jié)剛剛過去的早春時節(jié),我們來梳理和展望一下整個云原生技術(shù)趨勢的發(fā)展,是一件很有意義的事情,這其中有些變...
摘要:而且作為一個版本,其中有一些,可能會導(dǎo)致一些配置和插件不工作。但這并無妨礙我們?nèi)ラ_始對上的新特性進行嘗鮮實戰(zhàn)。 作者:志佳老師 本文首發(fā)微信公眾號:jingchengyideng歡迎關(guān)注,每天都給你推送新鮮的前端技術(shù)文章 前言 在老袁寫這篇文章的時候,v5版本仍然處于早期階段,可能仍然有問題。而且作為一個major版本,其中有一些breaking changes,可能會導(dǎo)致一些配置...
摘要:嘗鮮箭頭函數(shù)問題描述驗證方式題目分析熟悉的新的函數(shù)構(gòu)造方式箭頭函數(shù)。箭頭函數(shù)總是匿名的。我的解法優(yōu)解和搭配構(gòu)造可構(gòu)造有名函數(shù)。單句聲命可省略??杀环顷P(guān)鍵字就不能用。 [7 kyu]Sort with Arrow Functions 嘗鮮箭頭函數(shù)??2016.03.08 問題描述: showImg(http://ww4.sinaimg.cn/large/006m2mhTgw1f1p5d9...
閱讀 3096·2023-04-25 20:43
閱讀 1729·2021-09-30 09:54
閱讀 1600·2021-09-24 09:47
閱讀 2890·2021-09-06 15:02
閱讀 3522·2021-02-22 17:09
閱讀 1245·2019-08-30 15:53
閱讀 1448·2019-08-29 17:04
閱讀 1970·2019-08-28 18:22