K8S搭建過程隨筆

来源:https://www.cnblogs.com/bbicdi/archive/2019/09/19/11549968.html
-Advertisement-
Play Games

組件 Kubernetes 1.14.2 Docker 18.09.6-ce Etcd 3.3.13 Flanneld 0.11.0 基礎環境設置 192.168.11.188 k8s-master 192.168.11.189 k8s-node1192.168.11.190 k8s-node2 設 ...


  組件

Kubernetes 1.14.2

Docker 18.09.6-ce

Etcd 3.3.13

Flanneld 0.11.0

  基礎環境設置

192.168.11.188 k8s-master

192.168.11.189 k8s-node1
192.168.11.190 k8s-node2

  設置主機名:

hostnamectl set-hostname k8s-master

hostnamectl set-hostname k8s-node1

hostnamectl set-hostname k8s-node2

  在master主機添加host

cat >> /etc/hosts <<EOF

192.168.11.188 k8s-master
192.168.11.189 k8s-node1
192.168.11.190 k8s-node2
EOF

  免密登錄

ssh-keygen -t rsa

ssh-copy-id root@k8s-node1

ssh-copy-id root@k8s-node2

  在所有環境中安裝依賴包

yum install -y epel-release conntrack ntpdate ntp ipvsadm ipset jq iptables curl sysstat libseccomp wget unzip net-tools

  ## epel-release 自動配置yum的軟體倉庫

  ## conntrack 允許系統管理員從用戶空間與內核中的連接跟蹤系統進行交互,該系統是為iptables啟用狀態包檢測的模塊。

  ## ntpdate 同步更新時間

  ## ntp 網路時間協議

  ## ipvsadm 工作在用戶空間,負責為ipvs內核框架編寫規則,定義誰是集群服務

  ## ipset ipset是iptables的擴展,它允許你創建 匹配整個地址集合的規則。

  ## jq 直接在命令行下對JSON進行操作,包括分片、過濾、轉換等

  ## iptables 管理防火牆安全框架的命令行工具

  ##curl 利用URL語法在命令行下工作的文件傳輸工具

  ## sysstat 提供Linux性能監控的工具集,包括sar、sadf、mpstat、iostat、pidstat等,監控系統性能和使用情況。

  ## libseccomp ibseccomp庫為Linux內核的系統調用過濾機制提供了一個易於使用,獨立於平臺的介面:seccomp。

  ## wget 下載工具

  ## unzip 解壓工具

  ## net-tools  netstat命令不可用時,安裝net-tools

  關閉防火牆

systemctl stop firewalld #臨時關閉
systemctl disable firewalld #永久關閉
iptables -F && iptables -X && iptables -F -t nat && iptables -X -t nat
iptables -P FORWARD ACCEPT

  關閉swap分區  

swapoff -a
sed -i '/ swap / s/^\(.*\)$/#\1/g' /etc/fstab

  關閉SElinux

setenforce 0

sed -i 's/^SELINUX=.*/SELINUX=disabled/' /etc/selinux/config

  載入內核並優化

modprobe ip_vs_rr
modprobe br_netfilter
cat > kubernetes.conf <<EOF
net.bridge.bridge-nf-call-iptables=1
net.bridge.bridge-nf-call-ip6tables=1
net.ipv4.ip_forward=1
net.ipv4.tcp_tw_recycle=0
vm.swappiness=0 # 禁止使用 swap 空間,只有當系統 OOM 時才允許使用它
vm.overcommit_memory=1 # 不檢查物理記憶體是否夠用
vm.panic_on_oom=0 # 開啟 OOM
fs.inotify.max_user_instances=8192
fs.inotify.max_user_watches=1048576
fs.file-max=52706963
fs.nr_open=52706963
net.ipv6.conf.all.disable_ipv6=1
net.netfilter.nf_conntrack_max=2310720
EOF
cp kubernetes.conf /etc/sysctl.d/kubernetes.conf
sysctl -p /etc/sysctl.d/kubernetes.conf

  ntp

ntpdate ntp1.aliyun.com #同步阿裡雲時間

  創建相關目錄

mkdir -p /opt/k8s/{bin,work} /etc/{kubernetes,etcd}/cert

  升級內核

rpm -Uvh http://www.elrepo.org/elrepo-release-7.0-3.el7.elrepo.noarch.rpm
# 安裝完成後檢查 /boot/grub2/grub.cfg 中對應內核 menuentry 中是否包含 initrd16 配置,如果沒有,再安裝一次!
yum --enablerepo=elrepo-kernel install -y kernel-lt
# 設置開機從新內核啟動
grub2-set-default 0

  設置配置參數腳本

這裡的腳本為了之後配置文件、簽key使用

#!/usr/bin/bash

# 生成 EncryptionConfig 所需的加密 key
export ENCRYPTION_KEY=$(head -c 32 /dev/urandom | base64)

# 集群各機器 IP 數組
export NODE_IPS=(192.168.11.188 192.168.11.189 192.168.11.190)

# 集群各 IP 對應的主機名數組
export NODE_NAMES=(k8s-master k8s-node1 k8s-node2)

# etcd 集群服務地址列表
export ETCD_ENDPOINTS="https://192.168.11.188:2379"

# etcd 集群間通信的 IP 和埠
export ETCD_NODES="k8s-master=https://192.168.11.188:2380"

# kube-apiserver 的反向代理(kube-nginx)地址埠
export KUBE_APISERVER="https://127.0.0.1:8443"

# 節點間互聯網路介面名稱
export IFACE="ens33"

# etcd 數據目錄
export ETCD_DATA_DIR="/data/k8s/etcd/data"

# etcd WAL 目錄,建議是 SSD 磁碟分區,或者和 ETCD_DATA_DIR 不同的磁碟分區
export ETCD_WAL_DIR="/data/k8s/etcd/wal"

# k8s 各組件數據目錄
export K8S_DIR="/data/k8s/k8s"

# docker 數據目錄
export DOCKER_DIR="/data/k8s/docker"

## 以下參數一般不需要修改

# TLS Bootstrapping 使用的 Token,可以使用命令 head -c 16 /dev/urandom | od -An -t x | tr -d ' ' 生成
BOOTSTRAP_TOKEN="4498a43c27ef382031e642587615ee63"

# 最好使用 當前未用的網段 來定義服務網段和 Pod 網段

# 服務網段,部署前路由不可達,部署後集群內路由可達(kube-proxy 保證)
SERVICE_CIDR="10.254.0.0/16"

# Pod 網段,建議 /16 段地址,部署前路由不可達,部署後集群內路由可達(flanneld 保證)
CLUSTER_CIDR="172.30.0.0/16"

# 服務埠範圍 (NodePort Range)
export NODE_PORT_RANGE="30000-32767"

# flanneld 網路配置首碼
export FLANNEL_ETCD_PREFIX="/kubernetes/network"

# kubernetes 服務 IP (一般是 SERVICE_CIDR 中第一個IP)
export CLUSTER_KUBERNETES_SVC_IP="10.254.0.1"

# 集群 DNS 服務 IP (從 SERVICE_CIDR 中預分配)
export CLUSTER_DNS_SVC_IP="10.254.0.2"

# 集群 DNS 功能變數名稱(末尾不帶點號)
export CLUSTER_DNS_DOMAIN="cluster.local"

# 將二進位目錄 /opt/k8s/bin 加到 PATH 中
export PATH=/opt/k8s/bin:$PATH

   將文件發送到所有節點

source environment.sh
for node_ip in ${NODE_IPS[@]}
do
echo ">>> ${node_ip}"
scp environment.sh root@${node_ip}:/opt/k8s/bin/
ssh root@${node_ip} "chmod +x /opt/k8s/bin/*"
done


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. 先說幾句 如果你, 知道什麼是Windows系統 簡單使用Windows系統 想要瞭解或安裝Linux 剛接觸Linux會有以下疑惑, 什麼是分區? 如何建立分區? 怎麼安裝系統到到D盤? 安裝Linux時怎麼沒有看到C盤了? 那麼,且聽我請聽我娓娓道來。 2. 分區?路徑?文件夾?目錄? 2 ...
  • 記憶體擴充的實現方式:1、請求調⼊: 允許系統在裝⼊⼀部分⽤戶程式時就啟動該程式運 ⾏,在程式運⾏過程中若發現要執⾏的指令或訪問的 數據尚未裝⼊記憶體,通過請求調⼊將需要指令或數據 裝⼊記憶體;2、置換功能: 在請求調⼊時,若發現記憶體空間不⾜,需要先將記憶體 中的⼀部分內容換到外存中,以便騰出記憶體空間裝⼊ ... ...
  • tc 是linux 內置的命令;使用man pages 查看 我們看到,其功能為 show / manipulate traffic control settings,可對操作系統進行流量控制; netem 與 tc: netem 是 Linux 2.6 及以上內核版本提供的一個網路模擬功能模塊。該 ...
  • 以下只說明各指令的基本用法,若需詳細說明,請用man去讀詳細的manual。[Cygwin通常沒有安裝 man相關的文件,所以沒有man功能] 1.關於文件/目錄處理的指令: 1.1 ls 這是最基本的文件指令。ls的意義為“list”,也就是將某一個目錄下的內容顯示出來。如果你在ls指令後 沒有跟 ...
  • linux centos 6安裝方法 前提需要: 1, centos6的鏡像文件 2,VMware 提前安裝 註: "獲取鏡像" 阿裡開源系統,此處可下載其他的 1.Ubuntu 2.Susa 3.Centos all 4. 。。。 步驟: 1. 創建 2. 安裝方式選擇 3. 系統選擇 4. 虛擬 ...
  • 大家好! 我是一名Linux小白,有幸來到馬哥教育這個大家庭與各位同學在未來的五個月里一起學習Linux技術!儘管Linux對於剛接觸到的新手會很難,但是我知道痛苦只是暫時的,滿路荊棘的後面必是明亮寬廣的大海! 在學習過程中我將堅持做到三個“做到”! 1.做到聽每節課時都做隨堂筆記! 2.做到將老師 ...
  • 學習《shell腳本學習指南》一書 一個Shell腳本的典型的開發周期: 直接在命令行上測試 找到能夠完成工作的適當的語法 將它們放進一個獨立的腳本文件里 為該腳本設置執行許可權 直接使用該腳本 ...
  • 排名不分先後。 學海無涯苦作舟。 博客: 1.slmba:LINUX博客原創大牛 2.edsionte's TechBlog:Linuxer (他的友情鏈接中還有一堆Linuxer,被公司屏蔽進不去。。) 3.Tommy_wxie:專註Linux學習,有原創也有轉發 4.JeanCheng:linu ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...