k8s 安裝與基本使用


k8s的主要組件:

   etcd:一款開源軟件。提供可靠的分布式數據存儲服務,用於持久化存儲K8s集群的配置和狀態
   apiservice:用戶程序(如kubectl)、K8s其它組件之間通信的接口。K8s其它組件之間不直接通信,而是通過API server通信的。
   Scheduler:排程組件,為用戶應用的每一可部署組件分配工作結點。
   controller-manager:執行集群級別的功能,如復制組件、追蹤工作結點狀態、處理結點失敗等。
   kube-proxy:在應用組件間負載均衡網絡流量。
   kubelet:管理工作結點上的容器。

地址規划:
192.168.1.20 master 192.168.1.21 node

master 安裝

2.1、使用yum安裝etcd、kubernetes-master

yum -y install etcd kubernetes-master

2.2、編輯:vi /etc/etcd/etcd.conf文件,修改如下:

[root@localhost ~]# vim /etc/etcd/etcd.conf

  3 ETCD_DATA_DIR="/var/lib/etcd/default.etcd"
  6 ETCD_LISTEN_CLIENT_URLS="http://0.0.0.0:2379"
  9 ETCD_NAME="default"
 21 ETCD_ADVERTISE_CLIENT_URLS="http://localhost:2379"

2.3、配置:vi /etc/kubernetes/apiserver文件,配置結果如下:

[root@localhost ~]# vim /etc/kubernetes/apiserver

  8 KUBE_API_ADDRESS="--insecure-bind-address=0.0.0.0"
 11 KUBE_API_PORT="--port=8080"
 14 KUBELET_PORT="--kubelet-port=10250"
 17 KUBE_ETCD_SERVERS="--etcd-servers=http://127.0.0.1:2379"
 20 KUBE_SERVICE_ADDRESSES="--service-cluster-ip-range=10.254.0.0/16"
 23 KUBE_ADMISSION_CONTROL="--admission-control=NamespaceLifecycle,NamespaceExists,LimitRanger,SecurityContextDeny,ResourceQuota"
 26 KUBE_API_ARGS=""

2.4、啟動etcd、kube-apiserver、kube-controller-manager、kube-scheduler等服務,並設置開機啟動

for SERVICES in etcd kube-apiserver kube-controller-manager kube-scheduler; do systemctl restart $SERVICES;systemctl enable $SERVICES;systemctl status $SERVICES ; done

2.5、在etcd中定義flannel網絡

etcdctl mk /atomic.io/network/config '{"Network":"172.17.0.0/16"}'

node 安裝

3.1、在node機上192.168.1.21安裝kubernetes Node和flannel組件應用

yum -y install flannel kubernetes-node docker

3.2、為flannel網絡指定etcd服務,修改/etc/sysconfig/flanneld文件,配置結果如下圖:

# Flanneld configuration options  
FLANNEL_ETCD_ENDPOINTS="http://192.168.1.20:2379"        # master IP
FLANNEL_ETCD_PREFIX="/atomic.io/network"

3.3、修改:vi /etc/kubernetes/config文件,配置結果如下圖:

KUBE_LOGTOSTDERR="--logtostderr=true"
KUBE_LOG_LEVEL="--v=0"
KUBE_ALLOW_PRIV="--allow-privileged=false"
KUBE_MASTER="--master=http://192.168.1.20:8080"        # master IP

3.4、修改node機的kubelet配置文件/etc/kubernetes/kubelet

KUBELET_ADDRESS="--address=0.0.0.0"
KUBELET_PORT="--port=10250"
KUBELET_HOSTNAME="--hostname-override=192.168.1.21"
KUBELET_API_SERVER="--api-servers=http://192.168.1.20:8080"
KUBELET_POD_INFRA_CONTAINER="--pod-infra-container-image=registry.access.redhat.com/rhel7/pod-infrastructure:latest"
KUBELET_ARGS=""

3.5、node節點機上啟動kube-proxy,kubelet,docker,flanneld等服務,並設置開機啟動。

for SERVICES in kube-proxy kubelet docker flanneld;do systemctl restart $SERVICES;systemctl enable $SERVICES;systemctl status $SERVICES; done

在master主機上192.168.1.20執行如下命令,查看運行的node節點機器:

kubectl get nodes

參考博客:https://www.cnblogs.com/spll/p/10033316.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM