kubernetes集群安裝(1)

1揽浙、集群搭建

  1. 環(huán)境準(zhǔn)備,hosts文件中的配置

     192.168.241.140  kubernetes-master
     192.168.241.141  kubernetes-node1
     192.168.241.142  kubernetes-node2
     192.168.241.143  kubernetes-node3
     192.168.241.140  k8s.apiserver.com
    
  2. 安裝初始化環(huán)境

    1. 執(zhí)行腳本

       # 在 master 節(jié)點和 worker 節(jié)點都要執(zhí)行
      
       curl -sSL https://kuboard.cn/install-script/v1.16.0/install-kubelet.sh | sh
      
    2. 腳本內(nèi)容如下湾盗,主要目的初始化環(huán)境安裝:docker伏蚊、kubelet kubeadm kubectl

       #!/bin/bash
      
       # 在 master 節(jié)點和 worker 節(jié)點都要執(zhí)行
       
       # 安裝 docker
       # 參考文檔如下
       # https://docs.docker.com/install/linux/docker-ce/centos/ 
       # https://docs.docker.com/install/linux/linux-postinstall/
       
       # 卸載舊版本
       yum remove -y docker \
       docker-client \
       docker-client-latest \
       docker-common \
       docker-latest \
       docker-latest-logrotate \
       docker-logrotate \
       docker-selinux \
       docker-engine-selinux \
       docker-engine
       
       # 設(shè)置 yum repository
       yum install -y yum-utils \
       device-mapper-persistent-data \
       lvm2
       yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
       
       # 安裝并啟動 docker
       yum install -y docker-ce-18.09.7 docker-ce-cli-18.09.7 containerd.io
       systemctl enable docker
       systemctl start docker
       
       # 安裝 nfs-utils
       # 必須先安裝 nfs-utils 才能掛載 nfs 網(wǎng)絡(luò)存儲
       yum install -y nfs-utils
       
       # 關(guān)閉 防火墻
       systemctl stop firewalld
       systemctl disable firewalld
       
       # 關(guān)閉 SeLinux
       setenforce 0
       sed -i "s/SELINUX=enforcing/SELINUX=disabled/g" /etc/selinux/config
       
       # 關(guān)閉 swap
       swapoff -a
       yes | cp /etc/fstab /etc/fstab_bak
       cat /etc/fstab_bak |grep -v swap > /etc/fstab
       
       # 修改 /etc/sysctl.conf
       # 如果有配置,則修改
       sed -i "s#^net.ipv4.ip_forward.*#net.ipv4.ip_forward=1#g"  /etc/sysctl.conf
       sed -i "s#^net.bridge.bridge-nf-call-ip6tables.*#net.bridge.bridge-nf-call-ip6tables=1#g"  /etc/sysctl.conf
       sed -i "s#^net.bridge.bridge-nf-call-iptables.*#net.bridge.bridge-nf-call-iptables=1#g"  /etc/sysctl.conf
       # 可能沒有淹仑,追加
       echo "net.ipv4.ip_forward = 1" >> /etc/sysctl.conf
       echo "net.bridge.bridge-nf-call-ip6tables = 1" >> /etc/sysctl.conf
       echo "net.bridge.bridge-nf-call-iptables = 1" >> /etc/sysctl.conf
       # 執(zhí)行命令以應(yīng)用
       sysctl -p
       
       # 配置K8S的yum源
       cat <<EOF > /etc/yum.repos.d/kubernetes.repo
       [kubernetes]
       name=Kubernetes
       baseurl=http://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
       enabled=1
       gpgcheck=0
       repo_gpgcheck=0
       gpgkey=http://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg
              http://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
       EOF
       
       # 卸載舊版本
       yum remove -y kubelet kubeadm kubectl
       
       # 安裝kubelet丙挽、kubeadm、kubectl
       yum install -y kubelet-1.16.0 kubeadm-1.16.0 kubectl-1.16.0
       
       # 修改docker Cgroup Driver為systemd
       # # 將/usr/lib/systemd/system/docker.service文件中的這一行 ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock
       # # 修改為 ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock --exec-opt native.cgroupdriver=systemd
       # 如果不修改匀借,在添加 worker 節(jié)點時可能會碰到如下錯誤
       # [WARNING IsDockerSystemdCheck]: detected "cgroupfs" as the Docker cgroup driver. The recommended driver is "systemd". 
       # Please follow the guide at https://kubernetes.io/docs/setup/cri/
       sed -i "s#^ExecStart=/usr/bin/dockerd.*#ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock --exec-opt native.cgroupdriver=systemd#g" /usr/lib/systemd/system/docker.service
       
       # 設(shè)置 docker 鏡像颜阐,提高 docker 鏡像下載速度和穩(wěn)定性
       # 如果您訪問 https://hub.docker.io 速度非常穩(wěn)定,亦可以跳過這個步驟
       curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s http://f1361db2.m.daocloud.io
       
       # 重啟 docker吓肋,并啟動 kubelet
       systemctl daemon-reload
       systemctl restart docker
       systemctl enable kubelet && systemctl start kubelet
       
       docker version
      
  3. 將安裝初始化環(huán)境的虛擬機克隆三臺凳怨,IP分布為以上的說明

     192.168.241.141  kubernetes-node1
     192.168.241.142  kubernetes-node2
     192.168.241.143  kubernetes-node3
    
  4. 初始化master

    1. 下載flannel配置文件

       curl -O  https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
      
    2. 編寫腳本文件,init-master.sh

       #!/bin/bash
      
       # 只在 master 節(jié)點執(zhí)行
       
       MASTER_IP=192.168.241.140
       # 替換 apiserver.demo 為 您想要的 dnsName (不建議使用 master 的 hostname 作為 APISERVER_NAME)
       APISERVER_NAME=k8s.apiserver.com
       
       # kubeadm init
       # 根據(jù)您服務(wù)器網(wǎng)速的情況,您需要等候 3 - 10 分鐘
       kubeadm init --pod-network-cidr=10.244.0.0/16 --control-plane-endpoint=${APISERVER_NAME}:6443 --image-repository=registry.cn-hangzhou.aliyuncs.com/google_containers --upload-certs
       
       # 配置 kubectl
       rm -rf /root/.kube/
       mkdir /root/.kube/
       cp -i /etc/kubernetes/admin.conf /root/.kube/config
       
       # 安裝 flannel 網(wǎng)絡(luò)插件
       kubectl apply -f kube-flannel.yml
      
    3. 執(zhí)行腳步完成集群的安裝

       sh init-master.sh
      
  5. 注冊worker

    1. 獲取token

       # 只在 master 節(jié)點執(zhí)行
       kubeadm token create --print-join-command
      
    2. 在worker節(jié)點執(zhí)行以上命令執(zhí)行之后的輸出

       kubeadm join k8s.apiserver.com:6443 --token edbh39.vk3gqwxbvmszruek     --discovery-token-ca-cert-hash sha256:2f9a195441cae739f5116019cdb6dc1d71c4614e2bc38851e5867160b6b93feb
      
  6. 查看集群中的節(jié)點

     kubectl get nodes
    

2肤舞、安裝metallb

Metallb是一個軟負(fù)載均衡的實現(xiàn)紫新,可以用于實現(xiàn)在私有云環(huán)境下對LoadBalancer類型的service分配IP地址。

  1. 下載配置

     curl -O https://raw.githubusercontent.com/google/metallb/v0.8.1/manifests/metallb.yaml
    
  2. 安裝

     kubectl apply -f metallb.yaml
    
  3. 創(chuàng)建configmap文件,設(shè)置IP分配區(qū)間李剖,configmap.yaml

     apiVersion: v1
     kind: ConfigMap
     metadata:
       namespace: metallb-system
       name: config
     data:
       config: |
         address-pools:
         - name: default
           protocol: layer2
           addresses:
           - 192.168.241.200-192.168.241.230  # 需要和集群是在一個網(wǎng)段
    
  4. 應(yīng)用

     kubectl apply -f configmap.yaml 
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末芒率,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子篙顺,更是在濱河造成了極大的恐慌偶芍,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,454評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件德玫,死亡現(xiàn)場離奇詭異匪蟀,居然都是意外死亡,警方通過查閱死者的電腦和手機宰僧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評論 3 385
  • 文/潘曉璐 我一進(jìn)店門材彪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人琴儿,你說我怎么就攤上這事段化。” “怎么了造成?”我有些...
    開封第一講書人閱讀 157,921評論 0 348
  • 文/不壞的土叔 我叫張陵穗泵,是天一觀的道長。 經(jīng)常有香客問我谜疤,道長,這世上最難降的妖魔是什么现诀? 我笑而不...
    開封第一講書人閱讀 56,648評論 1 284
  • 正文 為了忘掉前任夷磕,我火速辦了婚禮,結(jié)果婚禮上仔沿,老公的妹妹穿的比我還像新娘坐桩。我一直安慰自己,他們只是感情好封锉,可當(dāng)我...
    茶點故事閱讀 65,770評論 6 386
  • 文/花漫 我一把揭開白布绵跷。 她就那樣靜靜地躺著,像睡著了一般成福。 火紅的嫁衣襯著肌膚如雪碾局。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,950評論 1 291
  • 那天奴艾,我揣著相機與錄音净当,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛像啼,可吹牛的內(nèi)容都是我干的俘闯。 我是一名探鬼主播,決...
    沈念sama閱讀 39,090評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼忽冻,長吁一口氣:“原來是場噩夢啊……” “哼真朗!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起僧诚,我...
    開封第一講書人閱讀 37,817評論 0 268
  • 序言:老撾萬榮一對情侶失蹤遮婶,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后振诬,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蹭睡,經(jīng)...
    沈念sama閱讀 44,275評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,592評論 2 327
  • 正文 我和宋清朗相戀三年赶么,在試婚紗的時候發(fā)現(xiàn)自己被綠了肩豁。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,724評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡辫呻,死狀恐怖清钥,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情放闺,我是刑警寧澤祟昭,帶...
    沈念sama閱讀 34,409評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站怖侦,受9級特大地震影響篡悟,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜匾寝,卻給世界環(huán)境...
    茶點故事閱讀 40,052評論 3 316
  • 文/蒙蒙 一搬葬、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧艳悔,春花似錦急凰、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至乔外,卻和暖如春床三,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背杨幼。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評論 1 266
  • 我被黑心中介騙來泰國打工勿璃, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 46,503評論 2 361
  • 正文 我出身青樓补疑,卻偏偏與公主長得像歧沪,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子莲组,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,627評論 2 350

推薦閱讀更多精彩內(nèi)容