Docker Kubernetes快速上手

2020-07-10 09:41 更新

目前,Kubernetes 支持在多種環(huán)境下的安裝,包括本地主機(Fedora)、云服務(Google GAE、AWS 等)。然而最快速體驗 Kubernetes 的方式顯然是本地通過 Docker 的方式來啟動相關進程。

下圖展示了在單節(jié)點使用 Docker 快速部署一套 Kubernetes 的拓撲。


在 Docker 中啟動 Kubernetes

Kubernetes 依賴 Etcd 服務來維護所有主節(jié)點的狀態(tài)。

啟動 Etcd 服務

  1. docker run --net=host -d gcr.io/google_containers/etcd:2.0.9 /usr/local/bin/etcd --addr=127.0.0.1:4001 --bind-addr=0.0.0.0:4001 --data-dir=/var/etcd/data


啟動主節(jié)點

啟動 kubelet。

  1. docker run --net=host -d -v /var/run/docker.sock:/var/run/docker.sock gcr.io/google_containers/hyperkube:v0.17.0 /hyperkube kubelet --api_servers=http://localhost:8080 --v=2 --address=0.0.0.0 --enable_server --hostname_override=127.0.0.1 --config=/etc/kubernetes/manifests

啟動服務代理

  1. docker run -d --net=host --privileged gcr.io/google_containers/hyperkube:v0.17.0 /hyperkube proxy --master=http://127.0.0.1:8080 --v=2

測試狀態(tài)

在本地訪問 8080 端口,可以獲取到如下的結果:

  1. $ curl 127.0.0.1:8080
  2. {
  3. "paths": [
  4. "/api",
  5. "/api/v1beta1",
  6. "/api/v1beta2",
  7. "/api/v1beta3",
  8. "/healthz",
  9. "/healthz/ping",
  10. "/logs/",
  11. "/metrics",
  12. "/static/",
  13. "/swagger-ui/",
  14. "/swaggerapi/",
  15. "/validate",
  16. "/version"
  17. ]
  18. }

查看服務

所有服務啟動后,查看本地實際運行的 Docker 容器,有如下幾個。

  1. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  2. ee054db2516c gcr.io/google_containers/hyperkube:v0.17.0 "/hyperkube schedule 2 days ago Up 1 days k8s_scheduler.509f29c9_k8s-master-127.0.0.1_default_9941e5170b4365bd4aa91f122ba0c061_e97037f5
  3. 3b0f28de07a2 gcr.io/google_containers/hyperkube:v0.17.0 "/hyperkube apiserve 2 days ago Up 1 days k8s_apiserver.245e44fa_k8s-master-127.0.0.1_default_9941e5170b4365bd4aa91f122ba0c061_6ab5c23d
  4. 2eaa44ecdd8e gcr.io/google_containers/hyperkube:v0.17.0 "/hyperkube controll 2 days ago Up 1 days k8s_controller-manager.33f83d43_k8s-master-127.0.0.1_default_9941e5170b4365bd4aa91f122ba0c061_1a60106f
  5. 30aa7163cbef gcr.io/google_containers/hyperkube:v0.17.0 "/hyperkube proxy -- 2 days ago Up 1 days jolly_davinci
  6. a2f282976d91 gcr.io/google_containers/pause:0.8.0 "/pause" 2 days ago Up 2 days k8s_POD.e4cc795_k8s-master-127.0.0.1_default_9941e5170b4365bd4aa91f122ba0c061_e8085b1f
  7. c060c52acc36 gcr.io/google_containers/hyperkube:v0.17.0 "/hyperkube kubelet 2 days ago Up 1 days serene_nobel
  8. cc3cd263c581 gcr.io/google_containers/etcd:2.0.9 "/usr/local/bin/etcd 2 days ago Up 1 days happy_turing

這些服務大概分為三類:主節(jié)點服務、工作節(jié)點服務和其它服務。

主節(jié)點服務

  • apiserver 是整個系統(tǒng)的對外接口,提供 RESTful 方式供客戶端和其它組件調(diào)用;
  • scheduler 負責對資源進行調(diào)度,分配某個 pod 到某個節(jié)點上;
  • controller-manager 負責管理控制器,包括 endpoint-controller(刷新服務和 pod 的關聯(lián)信息)和 replication-controller(維護某個 pod 的復制為配置的數(shù)值)。

工作節(jié)點服務

  • kubelet 是工作節(jié)點執(zhí)行操作的 agent,負責具體的容器生命周期管理,根據(jù)從數(shù)據(jù)庫中獲取的信息來管理容器,并上報 pod 運行狀態(tài)等;
  • proxy 為 pod 上的服務提供訪問的代理。

其它服務

  • Etcd 是所有狀態(tài)的存儲數(shù)據(jù)庫;
  • gcr.io/google_containers/pause:0.8.0 是 Kubernetes 啟動后自動 pull 下來的測試鏡像。


以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號