Kubernetes(二):Ubuntu上搭建k8s環境

前言

本文主要介紹在阿里云ecs實例上搭建自建Kubernetes環境的步驟,參照的是k8s官網上minikube的安裝教程。

安裝k8s

查閱網上資料得知,安裝k8s集群一般有幾種方式:

  • kubeadm(適用于生產環境)
  • Docker Desktop(如果是本地桌面系統推薦這種方式)
  • minikube(本地快速單機部署,體驗最簡版的k8s,不推薦在生產環境上使用)

本文選擇安裝minikube的方式搭建最簡k8s環境,官方教程:https://minikube.sigs.k8s.io/docs/start/

安裝前注意

通過閱讀官方教程得知,用minikube搭建k8s環境時,既支持通過虛擬化技術運行,也可以選擇不通過虛擬化技術直接運行在服務器上。所以對于一些不支持虛擬化技術的云服務器實例,只能通過后者安裝運行k8s,也無須安裝KVMVirtualBox等虛擬化工具,不過還是依賴于Docker環境,所以需要先安裝Docker,具體可參考Ubuntu上安裝Docker。

Note: Minikube also supports a --vm-driver=none option that runs the Kubernetes components on the host and not in a VM. Using this driver requires Docker and a Linux environment but not a hypervisor. It is recommended to use the apt installation of docker from Docker, when using the none driver. The snap installation of docker does not work with minikube.

MiniKube安裝步驟

https://kubernetes.io/docs/tasks/tools/install-minikube/

1. 安裝kubectl

kubectl是k8s的命令行工具,通過kubectl對k8s進行操作:
https://kubernetes.io/docs/tasks/tools/install-kubectl/#install-kubectl-on-linux

# 下載kubectl
$ curl -LO https://storage.googleapis.com/kubernetes-release/release/v1.17.0/bin/linux/amd64/kubectl
$ chmod +x ./kubectl
# 安裝到/usr/local/bin/目錄
$ sudo mv ./kubectl /usr/local/bin/kubectl

2. 安裝hypervisor(略)

阿里云ECS不支持虛擬化技術,略過

3. 安裝minikube

# 下載最新版本minikube并賦予執行權限
$ curl -Lo minikube https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64 \
  && chmod +x minikube
# 安裝到/usr/local/bin/目錄
$ sudo mkdir -p /usr/local/bin/
$ sudo install minikube /usr/local/bin/
# 確認安裝成功
$ kubectl version --client

4. 啟動k8s

$ minikube start --vm-driver=none

輸入命令minikube start --vm-driver=none啟動kubernetes,注意這里--vm-driver參數使用none,前提是要求本機有安裝docker,不然會報錯:

??  Unable to start VM. Please investigate and run 'minikube delete' if possible: create: precreate: exec: "docker": executable file not found in $PATH

初次執行大多數情況會報錯啟動失敗,原因是minikube啟動k8s環境時需要從k8s.gcr.io拉取kube-apiserverkube-controller-managerkube-scheduler等docker鏡像進行部署。而由于墻的問題從阿里云的云端機器上是無法訪問k8s.gcr.io的。

$ minikube start --help
...
--image-repository='': Alternative image repository to pull docker images from. This can be used when you have
limited access to gcr.io. Set it to "auto" to let minikube decide one for you. For Chinese mainland users, you may use
local gcr.io mirrors such as registry.cn-hangzhou.aliyuncs.com/google_containers
...

通過minikube的幫助文檔能看到,對于天朝的用戶可以直接用阿里云的鏡像地址registry.cn-hangzhou.aliyuncs.com/google_containers代替k8s.gcr.io

$ minikube start --vm-driver=none --image-repository=registry.cn-hangzhou.aliyuncs.com/google_containers
??  minikube v1.6.2 on Ubuntu 16.04
?  Selecting 'none' driver from user configuration (alternates: [])
?  Using image repository registry.cn-hangzhou.aliyuncs.com/google_containers
??  Running on localhost (CPUs=2, Memory=3951MB, Disk=40188MB) ...
??   OS release is Ubuntu 16.04.6 LTS
??  Preparing Kubernetes v1.17.0 on Docker '19.03.5' ...
??  Downloading kubeadm v1.17.0
??  Downloading kubelet v1.17.0
??  Pulling images ...
??  Launching Kubernetes ...
??  Configuring local host environment ...

??  The 'none' driver provides limited isolation and may reduce system security and reliability.
??  For more information, see:
??  https://minikube.sigs.k8s.io/docs/reference/drivers/none/

??  kubectl and minikube configuration will be stored in /root
??  To use kubectl or minikube commands as your own user, you may need to relocate them. For example, to overwrite your own settings, run:

    ? sudo mv /root/.kube /root/.minikube $HOME
    ? sudo chown -R $USER $HOME/.kube $HOME/.minikube

??  This can also be done automatically by setting the env var CHANGE_MINIKUBE_NONE_USER=true
?  Waiting for cluster to come online ...
??  Done! kubectl is now configured to use "minikube"

出現上面的日志表示minikube已經部署完畢,隨后查看k8s的運行狀態

# 可以看到minikube在docker中啟動了很多k8s相關的container
$ docker container ls
# 查看minikube的運行狀態
$ minikube status

后記

minikube提供了一種簡便快捷的方式在單機中完成k8s集群的部署,默認使用虛擬化技術(或者docker)模擬多節點部署,為學習研究k8s提供了巨大的方便。
另外使用docker運行minikube會存在一些安全性或兼容性問題,需要注意的地方:https://minikube.sigs.k8s.io/docs/reference/drivers/none/

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

推薦閱讀更多精彩內容