摘要:里面有個工具,叫,可以比較方便的調試應用。項目的目錄下有個好用的腳本,它是通過在容器里啟動各服務的。考慮可以在本地進程啟動服務,這樣便可以當作一個應用去調試了。本文寫作時分支最新為。
openstack 搞了2年,對動態語言的 debug 和 pdb念念不忘,總尋思著看 kubernetes代碼能不能和 openstack 一樣 pdb 一步步看下去。golang 里面有個debug 工具,叫 dlv,可以比較方便的調試 go 應用。
kubernetes 項目的 hack 目錄下有個好用的 shell 腳本local-up-cluster.sh,它是通過_output/local/bin/linux/amd64/hyperkube在容器里啟動k8s各服務的。考慮可以在本地進程啟動 kubernetes 服務,這樣便可以當作一個 go 應用去調試了。本文寫作時kubernetes master 分支最新 commit id 為9884215f7976e8cc294fdbb62f8c2a6af9bca728。
linux 環境信息這里不再贅述,我用的是 centos 7.4 虛擬機,配置是4C/16G/100G
$ cat /etc/redhat-release CentOS Linux release 7.5.1804 (Core)go 環境安裝
Kubernetes requires go1.10.2 or greater. Please install go1.10.2 or later.
go版本要求大于1.10.2
# 具體參見 https://golang.org/doc/install wget https://dl.google.com/go/go1.10.3.linux-amd64.tar.gz (具體參見) tar -C /usr/local/ -xzf go1.10.3.linux-amd64.tar.gz # 測試是否安裝成功 $ go version go version go1.10.3 linux/amd64 # 配置 go 環境 (建議直接將 export 內容寫入到/etc/profile下) mkdir /go export GOPATH=/go export PATH=$PATH:/usr/local/go/bin export PATH=$PATH:/go/bin # 安裝 dlv go get -u github.com/derekparker/delve/cmd/dlv export PATH=$PATH:$GOPATH/bin # 下載 kubernetes 代碼放到 $GOPATH/src/k8s.io目錄下 (代碼較大,如果只要最新一次提交的代碼來加速下載,指定--depth=1) git clone https://github.com/kubernetes/kubernetes # 提供一個習慣訪問的 shell 腳本,可以不操作(因為后面啟動的local-up-cluster 使用的是cluster 目錄下的kubectl.sh 來操作k8s 環境) cat<etcd 安裝/usr/local/bin/kubectl #!/bin/bash /go/src/k8s.io/kubernetes/cluster/kubectl.sh $@ EOF chmod +x /usr/local/bin/kubectl
etcd version 3.2.18 or greater required.
etcd 版本要求大于3.2.18
# 具體參見 https://github.com/coreos/etcd/releases wget https://github.com/coreos/etcd/releases/download/v3.3.9/etcd-v3.3.9-linux-amd64.tar.gz tar xzvf etcd-v3.3.9-linux-amd64.tar.gz -C /usr/local/ # 拷貝 bin 文件到/usr/local/bin下 cp /usr/local/etcd-v3.3.9-linux-amd64/etcd /usr/local/etcd-v3.3.9-linux-amd64/etcdctl /usr/local/bin # 測試是否安裝成功 etcd —versiondocker 安裝
# 安裝 docker repo(配了中科大源) sudo yum install -y yum-utils device-mapper-persistent-data lvm2 sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sed -i "s/download.docker.com/mirrors.ustc.edu.cn/docker-ce/g" /etc/yum.repos.d/docker-ce.repo yum makecache # 安裝 docker-ce sudo yum install -y docker-ce # 啟動 docker systemctl start docker systemctl enable dockerdocker 鏡像
由于安裝鏡像存在墻,提前準備好 (感謝 anjia0532 提供的同步鏡像倉庫)
docker pull anjia0532/pause-amd64:3.1 docker tag anjia0532/pause-amd64:3.1 k8s.gcr.io/pause:3.1 docker pull anjia0532/k8s-dns-kube-dns-amd64:1.14.10 docker tag anjia0532/k8s-dns-kube-dns-amd64:1.14.10 k8s.gcr.io/k8s-dns-kube-dns-amd64:1.14.10 docker pull anjia0532/k8s-dns-dnsmasq-nanny-amd64:1.14.10 docker tag anjia0532/k8s-dns-dnsmasq-nanny-amd64:1.14.10 k8s.gcr.io/k8s-dns-dnsmasq-nanny-amd64:1.14.10 docker pull anjia0532/k8s-dns-sidecar-amd64:1.14.10 docker tag anjia0532/k8s-dns-sidecar-amd64:1.14.10 k8s.gcr.io/k8s-dns-sidecar-amd64:1.14.10修改 kubernetes 代碼
由于 local-up-cluster.sh 默認使用的是 hyperkube 鏡像在容器中啟動 kuebrnetes 服務,但是這樣不能使用 dlv 去調試代碼,那么需要在 host 進程啟動,有兩種方案都可以試試,由于local-up-cluster.sh 會在本地編譯好代碼并放入到 _output/bin 中,那么可以直接通過寫 systemd 配置文件的方式在本地啟動服務; 還有一種是我選擇的,修改local-up-cluster.sh代碼,如下:
注意: 這個只在commit id: 30b89d830b7fd0827576853d6a0db44b66a90d3d 以后可用。之前的會編譯不成功,是因為cmd下沒有 kube-schduler 包,該目錄在plugins/cmd/kube-sheduler下,需要重寫規則。
啟動集群通過執行local-up-cluster.sh腳本啟動集群
# 切換到 kubernetes 根目錄 $ pwd /go/src/k8s.io/kubernetes · $ ./hack/local-up-cluster.sh Kubelet cgroup driver defaulted to use: cgroupfs API SERVER insecure port is free, proceeding... API SERVER secure port is free, proceeding… ... ... Alternatively, you can write to the default kubeconfig: export KUBERNETES_PROVIDER=local cluster/kubectl.sh config set-cluster local --server=https://localhost:6443 --certificate-authority=/var/run/kubernetes/server-ca.crt cluster/kubectl.sh config set-credentials myself --client-key=/var/run/kubernetes/client-admin.key --client-certificate=/var/run/kubernetes/client-admin.crt cluster/kubectl.sh config set-context local --cluster=local --user=myself cluster/kubectl.sh config use-context local cluster/kubectl.sh # 驗證集群是否成功 $ kubectl get componentstatus NAME STATUS MESSAGE ERROR controller-manager Healthy ok scheduler Healthy ok etcd-0 Healthy {"health":"true"}
這里有個 tip, 在代碼中有個判斷 [ "x$GO_OUT" == "x” ], 也就是說如果第一次編譯生成 bin 包后,往后只要指定 GO_OUT 再次執行就可以不再編譯。
我這里是: export GO_OUT=/go/src/k8s.io/kubernetes/_output/bin
調試舉例# 查找 并 kill 相關進程 $ ps -ef | grep kubelet root 538 26665 0 17:14 pts/1 00:00:00 grep --color=auto --exclude-dir=.bzr --exclude-dir=CVS --exclude-dir=.git --exclude-dir=.hg --exclude-dir=.svn kubelet root 31690 30984 0 17:14 pts/0 00:00:00 sudo -E /go/src/k8s.io/kubernetes/_output/bin/kubelet --v=3 --vmodule= --chaos-chance=0.0 --container-runtime=docker --hostname-override=127.0.0.1 --cloud-provider= --cloud-config= --address=127.0.0.1 --kubeconfig /var/run/kubernetes/kubelet.kubeconfig --feature-gates=AllAlpha=false --cpu-cfs-quota=true --enable-controller-attach-detach=true --cgroups-per-qos=true --cgroup-driver=cgroupfs --eviction-hard=memory.available<100Mi,nodefs.available<10%,nodefs.inodesFree<5% --eviction-soft= --eviction-pressure-transition-period=1m --pod-manifest-path=/var/run/kubernetes/static-pods --fail-swap-on=false --cluster-dns=10.0.0.10 --cluster-domain=cluster.local --port=10250 root 31693 31690 3 17:14 pts/0 00:00:01 /go/src/k8s.io/kubernetes/_output/bin/kubelet --v=3 --vmodule= --chaos-chance=0.0 --container-runtime=docker --hostname-override=127.0.0.1 --cloud-provider= --cloud-config= --address=127.0.0.1 --kubeconfig /var/run/kubernetes/kubelet.kubeconfig --feature-gates=AllAlpha=false --cpu-cfs-quota=true --enable-controller-attach-detach=true --cgroups-per-qos=true --cgroup-driver=cgroupfs --eviction-hard=memory.available<100Mi,nodefs.available<10%,nodefs.inodesFree<5% --eviction-soft= --eviction-pressure-transition-period=1m --pod-manifest-path=/var/run/kubernetes/static-pods --fail-swap-on=false --cluster-dns=10.0.0.10 --cluster-domain=cluster.local --port=10250 $ kill -9 31690 $ kill -9 31693 # 我移除了部分配置項,否則報錯 $ dlv --headless -l 127.0.0.1:1234 exec /go/src/k8s.io/kubernetes/_output/bin/kubelet -- --v=3 --vmodule= --chaos-chance=0.0 --container-runtime=docker --hostname-override=127.0.0.1 --cloud-provider= --cloud-config= --address=127.0.0.1 --kubeconfig /var/run/kubernetes/kubelet.kubeconfig --feature-gates=AllAlpha=false --cpu-cfs-quota=true --enable-controller-attach-detach=true --cgroups-per-qos=true --cgroup-driver=cgroupfs --eviction-soft= --eviction-pressure-transition-period=1m --pod-manifest-path=/var/run/kubernetes/static-pods --fail-swap-on=false --cluster-dns=10.0.0.10 --cluster-domain=cluster.local --port=10250 # 開始調試 dlv connect 127.0.0.1:1234 (dlv) b main.main (dlv) c (dlv) args (dlv) p
備注:
這只是我初步實現的一個方案,并沒有結合它深度使用,后續有新技能再更新上來
如果照著我的步驟卡住了,考慮下是不是配個梯子( https://www.zfl9.com/ss-local... )
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/32683.html
摘要:參考官方文檔進行操作本文假設環境正常運行,并且已經安裝。只能以單副本運行部署運行命令來安裝等待一段時間執行完成后,通過如下命令確定集群是否成功運行檢查的狀態檢查集群狀態至此,集群部署完成。 參考 ceph 官方文檔進行操作: http://docs.ceph.com/docs/mas... 本文假設kubernetes 環境正常運行,并且 host 已經安裝 helm client。 ...
摘要:節點對不會有影響,查詢處于狀態并一直保持。根據上一節描述,此時已經有正確的在其他節點,此時故障節點恢復后,執行優雅刪除,刪除舊的。會從狀態變為狀態,執行優雅刪除,,然后執行重新調度與重建操作。會從狀態直接變成狀態,不涉及重建。 節點離線后的 pod 狀態 在 kubernetes 使用過程中,根據集群的配置不同,往往會因為如下情況的一種或幾種導致節點 NotReady: kubele...
摘要:全球范圍內的部署節點已超過個,付費客戶超過個。因此,我們決定重新設計,將過去大受用戶歡迎的用戶體驗即架構于之上,從而充分利用的強大力量。因此,很快成為啟動集群的最受歡迎的方式之一。年,的流行度在持續上升,且這一勢頭從未放緩。 經過數月的努力,我們終于發布了Rancher 2.0 Technology Preview,這對Rancher Labs而言也是歷史性的、值得銘記的一刻。 Ran...
摘要:全球范圍內的部署節點已超過個,付費客戶超過個。因此,我們決定重新設計,將過去大受用戶歡迎的用戶體驗即架構于之上,從而充分利用的強大力量。因此,很快成為啟動集群的最受歡迎的方式之一。年,的流行度在持續上升,且這一勢頭從未放緩。 經過數月的努力,我們終于發布了Rancher 2.0 Technology Preview,這對Rancher Labs而言也是歷史性的、值得銘記的一刻。 Ran...
摘要:渲染節點并指明它們的總體狀態。為節點和提供工具提示信息。作為一個日志查看器,允許你使用選擇器從匹配的流式的查看日志。日志查看器你可以基于標準的標簽選擇器匹配,通過名字,通過服務,通過部署,等等。使得和團隊在容器排錯和安全調查方面很方便。 如果你正在 Kubernetes 上工作,你的 SRE 和 Ops 團隊需要正確的工具來確保Kubernetes集群的高可用和在其中運行的工作負載。這...
閱讀 2097·2023-04-26 02:41
閱讀 2152·2021-09-24 09:47
閱讀 1553·2019-08-30 15:53
閱讀 1211·2019-08-30 13:01
閱讀 1892·2019-08-29 11:27
閱讀 2867·2019-08-28 17:55
閱讀 1764·2019-08-26 14:00
閱讀 3392·2019-08-26 10:18