k8s的二进制部署
k8s的二进制部署的实验:
源码包部署
k8s的master01:192.168.233.91
组件:kube-apiserver kube-controller-manager kube-scheduler etcd
k8s的master02:192.168.233.92
组件:kube-apiserver kube-controller-manager kube-scheduler
node节点01:192.168.233.93 kubelet kube-proxy etcd
node节点02:192.168.233.94 kubelet kube-proxy etcd
负载均衡:nginx+keepalived:master:192.168.233.95
backup:192.168.233.96
etcd:192.168.233.91
192.168.233.93
192.168.233.94
91、93、94主机:
data:image/s3,"s3://crabby-images/9e6cd/9e6cd0949f25f280ac4afd888ccc36d8482086e8" alt=""
清空iptables的所有策略
data:image/s3,"s3://crabby-images/a5bbb/a5bbb5a5c1ddca85963caa1d53fac0fabc16a780" alt=""
关闭交换分区
swapoff -a
data:image/s3,"s3://crabby-images/8ee99/8ee994768bff68e69df3329d86eac4c02062f02f" alt=""
k8s在设计时,为了提升性能,默认是不使用swap交换分区的,kubenetes在初始化时,会检测swap是否关闭
91:
data:image/s3,"s3://crabby-images/95ae2/95ae262822aa9d721dd8bb65ab68eb827c81f089" alt=""
93:
data:image/s3,"s3://crabby-images/25305/25305177f9f1ee546691f5eb6924597b535f9989" alt=""
94:
data:image/s3,"s3://crabby-images/bd629/bd6290c53a7fe56d0f4b94567ee8eb6842ee1a66" alt=""
91、93、94:
data:image/s3,"s3://crabby-images/c83fd/c83fdc6adc6d0484581ad6f0e1b573d0e81b67c3" alt=""
data:image/s3,"s3://crabby-images/79b0d/79b0dd24b6e2b90ac597fd2d9f5e0a4f171b47f8" alt=""
data:image/s3,"s3://crabby-images/7373f/7373f4a55e875439d3249f96559028d24e02ed67" alt=""
#开启网桥模式
net.bridge.brideg-nf-call-ip6tables=1
net.bridge.brideg-nf-call-iptables=1
#网桥的流量传给iptables链,实现地址映射
#关闭ipv6的流量(可关也可以不关)
net.ipv6.conf.all.disable_ipv6=1
#根据工作中的实际情况,自定
net.ipv4.ip_forward=1
data:image/s3,"s3://crabby-images/91025/91025ddc831f04e26ea721f310e682962caecc2b" alt=""
data:image/s3,"s3://crabby-images/7afda/7afda035a86ade669266ac1663385b2258dd1b5c" alt=""
时间同步
yum install ntpdate -y
ntpdate ntp.aliyun.com
data:image/s3,"s3://crabby-images/6d3df/6d3df2ba72fe7766bc9f3bdd9ebbbfa46dbcee31" alt=""
data:image/s3,"s3://crabby-images/d3f6e/d3f6eaa07c38be782e67f6dd29a4ee42306f43bd" alt=""
date
data:image/s3,"s3://crabby-images/54193/5419332f1d5cc7b39df543f4dd124b0a23c119f3" alt=""
部署 docker引擎
91、93、94:
yum install -y yum-utils device-mapper-persistent-data lvm2
data:image/s3,"s3://crabby-images/683d6/683d6b7cb116b16d29445e7a4c6abd961ead60cb" alt=""
yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
data:image/s3,"s3://crabby-images/eca64/eca64eaa2941e8856009a5e0460be32303e38a9a" alt=""
yum install -y docker-ce docker-ce-cli containerd.io
systemctl start docker.service
systemctl enable docker.service
data:image/s3,"s3://crabby-images/9cb1f/9cb1fd44ca03d1087b9105d96b790904365e3b2b" alt=""
部署 etcd 集群
(部署第一个组件,存储k8s的集群信息和用户配置组件)
(etcd是一个高可用----分布式的键值存储数据库,采用raft算法保证节点的信息一致性。etcd是go语言写的)
(etcd的端口:2379:api接口,对外为客户端提供通信
2380:内部服务的通信端口
etcd一般都是集群部署,etcd也有选举leader的机制,至少要三台,或者奇数台)
k8s的内部通信依靠证书认证,密钥认证:证书的签发环境
91:
把三个证书拖进来
data:image/s3,"s3://crabby-images/b3f22/b3f2226634ef244282f782551a80d4b9befc4bc4" alt=""
sfssl:证书签发的命令工具
cfssl-certinfo:查看证书信息的工具
cfssljson:把证书的格式转化成json格式,变成文件的承载式证书
移到bin目录下面
mv cfssl-certinfo cfssljson cfssl /usr/local/bin/
data:image/s3,"s3://crabby-images/2cc32/2cc32ed02f42d626f3529bd0b3a3735e5788d6b6" alt=""
chmod 777 /usr/local/bin/cfssl*
data:image/s3,"s3://crabby-images/fca5d/fca5d95b2fc6860d5c8cab5f7fb49855dc4069c5" alt=""
cd到opt,然后创建一个mkdir k8s的目录
mkdir /opt/k8s
data:image/s3,"s3://crabby-images/02959/02959dea0dfc8e429aa744239f4a2f1d06e0fb7e" alt=""
data:image/s3,"s3://crabby-images/1f80d/1f80d33f603aa8f663e269734eb240102b6a40d8" alt=""
拖两个证书包到k8s
data:image/s3,"s3://crabby-images/ef40f/ef40fed3d3d65265640a05fd5a214e4515492ae6" alt=""
vim etcd-cert.sh
data:image/s3,"s3://crabby-images/cf08b/cf08b8e92af0c21d427a4f7730f39bddf4b324ea" alt=""
记得改文件里的IP地址
data:image/s3,"s3://crabby-images/66864/66864bba00d77d3d30ba3cf66fe9c2e6d9dd16a9" alt=""
赋权
chmod 777 etcd-cert.sh etcd.sh
data:image/s3,"s3://crabby-images/a00b5/a00b5d969eb2d936cd2488d98060cd5c37a6ccfd" alt=""
mkdir /opt/k8s/etcd-cert
data:image/s3,"s3://crabby-images/cd9c0/cd9c0191dee53b834eba1f729ca2be8d319b3b90" alt=""
mv etcd-cert.sh etcd-cert
data:image/s3,"s3://crabby-images/7c3e1/7c3e1a4f3ee2a30c0726ff3deeae3547cacac220" alt=""
cd etcd-cert/
./etcd-cert.sh
data:image/s3,"s3://crabby-images/952c9/952c9672f45bc0c84ae377b0297ce39bc78edad0" alt=""
ca-config.json:配置了证书生成策略,定义了默认过期时间和一个名为 "www" 的配置模板
ca-csr.json:用于生成根证书和私钥的签名请求文件。包括了Common Name(CN),密钥算法和一些组织信息
ca.pem:根证书文件
server-csr:服务器证书签名请求文件
server-key.pem:生成etcd服务器证书和私钥
server.pem:etcd服务器的证书文件,用于加密和认证etcd节点之间的通信
data:image/s3,"s3://crabby-images/7cb83/7cb83884b286a1f5caedf10546a5db2d44fcaf01" alt=""
data:image/s3,"s3://crabby-images/a0f57/a0f57f3924109faadfe0bb8dd9014ae396de9a83" alt=""
tar zxvf etcd-v3.4.9-linux-amd64.tar.gz
data:image/s3,"s3://crabby-images/e607e/e607e2defdf3b39fa13f528a145ef5afe9628612" alt=""
data:image/s3,"s3://crabby-images/47ae3/47ae30c672a35fb209710ac1d8aa12f757b97b49" alt=""
data:image/s3,"s3://crabby-images/26018/2601873e656c63faea15a30a3c5cfba9330d29a9" alt=""
data:image/s3,"s3://crabby-images/1f870/1f870aedf8afff753a4e8bf43aef40f4b8690007" alt=""
data:image/s3,"s3://crabby-images/97efc/97efc1dbccc6d866f3c0726687b39bac7a60107d" alt=""
data:image/s3,"s3://crabby-images/645fe/645fee454ad5c99c6ba837358b1008083f6d5572" alt=""
cd /opt/k8s/etcd-cert/
cp *.pem /opt/etcd/ssl/
data:image/s3,"s3://crabby-images/847c9/847c988905643b79a23f9d138e6479a518d807f8" alt=""
data:image/s3,"s3://crabby-images/d0c52/d0c528510ee7ffcf861039fd6cd09f3f42bc67a6" alt=""
data:image/s3,"s3://crabby-images/5d565/5d565d1777ff054ffd555e11ee23b65230abd760" alt=""
./etcd.sh etcd01 192.168.233.31 etcd02=https://192.168.233.33:2380,etcd03=https://192.168.233.34:2380
data:image/s3,"s3://crabby-images/1c693/1c693a33eaf09d6aa7bbdc7231f48bf995befb73" alt=""
再开一台91的终端:
传参到93和94的主机
scp -r /opt/etcd/ root@192.168.233.93:/opt/
data:image/s3,"s3://crabby-images/dce3e/dce3ee23aff03baea4e32a490affb52f495a48cd" alt=""
scp -r /opt/etcd/ root@192.168.233.94:/opt/
data:image/s3,"s3://crabby-images/d3dd6/d3dd6c1d46a56ae20d32184137377e50afa7411b" alt=""
scp /usr/lib/systemd/system/etcd.service root@192.168.233.93:/usr/lib/systemd/system/
data:image/s3,"s3://crabby-images/174c6/174c6a7d87fe530c5ab6fd6e9115516f35de6af8" alt=""
scp /usr/lib/systemd/system/etcd.service root@192.168.233.94:/usr/lib/systemd/system/
data:image/s3,"s3://crabby-images/97a43/97a433af351c2345cdbc7d68d35a958636e935f1" alt=""
93:
data:image/s3,"s3://crabby-images/c26c2/c26c242dcb8440e4c95dc45aa9c30368e99ffb29" alt=""
data:image/s3,"s3://crabby-images/4cd93/4cd93e36f35034e4bf073c303df8dbf85ce10668" alt=""
data:image/s3,"s3://crabby-images/a2cc0/a2cc00a1f64d82151e1a3ac7b941aeaba1d20aae" alt=""
94:
data:image/s3,"s3://crabby-images/152bf/152bf245b96e0a9fe89115c292c80523e6a39c36" alt=""
data:image/s3,"s3://crabby-images/4cd93/4cd93e36f35034e4bf073c303df8dbf85ce10668" alt=""
data:image/s3,"s3://crabby-images/b5e5b/b5e5b3fe1641d844902c18c8c6185fb7f0792a5c" alt=""
91、93、94:
(谁先启动谁是主)
data:image/s3,"s3://crabby-images/6df45/6df45aa87ceda5780abdedc68d24232906285cf5" alt=""
data:image/s3,"s3://crabby-images/768e9/768e97bd26e21e7b002f7c6cbf3ee93a533c75e8" alt=""
91:
检查etcd群集状态
ETCDCTL_API=3 /opt/etcd/bin/etcdctl --cacert=/opt/etcd/ssl/ca.pem --cert=/opt/etcd/ssl/server.pem --key=/opt/etcd/ssl/server-key.pem --endpoints="https://192.168.233.91:2379,https://192.168.233.93:2379,https://192.168.233.94:2379" endpoint health --write-out=table
data:image/s3,"s3://crabby-images/217b3/217b3ca1bbbe5f0a922efa108b45aa85b4ba1990" alt=""
master节点的部署:
91:
上传 master.zip 和 k8s-cert.sh 到 /opt/k8s 目录中,解压 master.zip 压缩包
data:image/s3,"s3://crabby-images/d7fb5/d7fb50eb8598863e7603ca3ffa7a65d9e51a20a2" alt=""
data:image/s3,"s3://crabby-images/5b598/5b598d23539929fbb27553e986b092de1faa56e4" alt=""
91是主节点
92是从节点
95和96是nginx的IP地址
data:image/s3,"s3://crabby-images/e326a/e326a4ba3ae4c2064d142c76eae8c6c8f75c8e9d" alt=""
unzip master.zip
data:image/s3,"s3://crabby-images/b0acd/b0acd5b11624eff812ab917ab41011663589b009" alt=""
data:image/s3,"s3://crabby-images/69ee3/69ee36c0c88872e7e06909854eabcc18c840ca2c" alt=""
指向apiserver的ip地址
data:image/s3,"s3://crabby-images/95d82/95d82c558902e8690cf6838279b4b4d495c5fe05" alt=""
data:image/s3,"s3://crabby-images/11512/1151207e270e1e719a3bb3c2013c1dd4b5d6edfd" alt=""
data:image/s3,"s3://crabby-images/01341/01341588e9aa8baea57af6af0897a8b033327c8e" alt=""
data:image/s3,"s3://crabby-images/1fd0b/1fd0bf1270dcbe41eb82273e077fc9ce4b5ca27e" alt=""
data:image/s3,"s3://crabby-images/2c290/2c2906620e55e8b502b10ac54c1faf37864821d6" alt=""
chmod 777 *.sh
data:image/s3,"s3://crabby-images/ea1ce/ea1cee131b61574b43888e1614f30ad0c0f93c0d" alt=""
mkdir -p /opt/kubernetes/{bin,cfg,ssl,logs}
data:image/s3,"s3://crabby-images/5edcf/5edcfa523630d66ed88e8fb0af39a1d3dd60c24f" alt=""
mkdir /opt/k8s/k8s-cert
data:image/s3,"s3://crabby-images/10cd1/10cd120592326d00b7d53bcf93cd613596e6e8cc" alt=""
mv /opt/k8s/k8s-cert.sh /opt/k8s/k8s-cert
data:image/s3,"s3://crabby-images/8ed43/8ed43fb6cd9bbf0927451ef89643748858121166" alt=""
cd /opt/k8s/k8s-cert/
./k8s-cert.sh
cp ca*pem apiserver*pem /opt/kubernetes/ssl/
data:image/s3,"s3://crabby-images/9c947/9c947d956f9a4e0d55347103bfb87776ce358d42" alt=""
cd /opt/k8s/
data:image/s3,"s3://crabby-images/f2c98/f2c98046bb19eefd54968b07a863231f6f391431" alt=""
拖软件包
data:image/s3,"s3://crabby-images/3f575/3f5759a4fdc73ec4c882425dc913ed430a521981" alt=""
tar zxvf kubernetes-server-linux-amd64.tar.gz
data:image/s3,"s3://crabby-images/fc9f0/fc9f06deaf1af62ed798fc947ebc55c1bcc6ea43" alt=""
cp kube-apiserver kubectl kube-controller-manager kube-scheduler /opt/kubernetes/bin/
data:image/s3,"s3://crabby-images/e2779/e277929c9368896f4342ba140e46777076e7a243" alt=""
ln -s /opt/kubernetes/bin/* /usr/local/bin/
data:image/s3,"s3://crabby-images/f8e05/f8e0505d01cf561cd7d01de77a8bc0a4d1ffa22e" alt=""
data:image/s3,"s3://crabby-images/2a9a1/2a9a1b7948c8decd7a4a3f1ce9dfd43830d7f873" alt=""
#!/bin/bash
#获取随机数前16个字节内容,以十六进制格式输出,并删除其中空格
BOOTSTRAP_TOKEN=$(head -c 16 /dev/urandom | od -An -t x | tr -d ' ')
#生成 token.csv 文件,按照 Token序列号,用户名,UID,用户组 的格式生成
cat > /opt/kubernetes/cfg/token.csv <<EOF
${BOOTSTRAP_TOKEN},kubelet-bootstrap,10001,"system:kubelet-bootstrap"
EOF
data:image/s3,"s3://crabby-images/e6595/e659587637f580ebb376e5cee317d5f93ec127ba" alt=""
chmod 777 token.sh
data:image/s3,"s3://crabby-images/fb6cd/fb6cd778acea14904e6f39e4cb6cf12be12b6130" alt=""
./token.sh
data:image/s3,"s3://crabby-images/3d267/3d2677a0d20d63a451747fac4c22ab0b0a995352" alt=""
cat /opt/kubernetes/cfg/token.csv
data:image/s3,"s3://crabby-images/51203/512039c124b63950a9d10b2adc488dfa577a69f7" alt=""
二进制文件、token、证书都准备好后,开启 apiserver 服务
cd /opt/k8s/
./apiserver.sh 192.168.233.91 https://192.168.233.91:2379,https://192.168.233.93:2379,https://192.168.233.94:2379
data:image/s3,"s3://crabby-images/de80b/de80be37bbbe3f652b73cf7773ca717a2b167035" alt=""
netstat -antp | grep 6443
data:image/s3,"s3://crabby-images/f96e7/f96e77227fbaf95042c127dc6d9fc5572fbca5a9" alt=""
./scheduler.sh
data:image/s3,"s3://crabby-images/36fe2/36fe2151ca71c588f5b959523aea647ae33d105b" alt=""
./controller-manager.sh
data:image/s3,"s3://crabby-images/05ded/05dedda9e3f6fc921ed2f4a18d1de7cae0a141aa" alt=""
./admin.sh
data:image/s3,"s3://crabby-images/235d0/235d0a7775eab125e3ed0d88e127ceec054f9146" alt=""
通过kubectl工具查看当前集群组件状态
kubectl get cs
data:image/s3,"s3://crabby-images/6bb49/6bb4985ad00edc62103d0a6914a310a02b30363f" alt=""
data:image/s3,"s3://crabby-images/48b8f/48b8f7f592b0ec0afa4a00189b37e1069a99bb9b" alt=""
node节点的部署:
93、94:
mkdir -p /opt/kubernetes/{bin,cfg,ssl,logs}
data:image/s3,"s3://crabby-images/dced2/dced29800c6cb3e011d65690d75e6cb3e1c7d32c" alt=""
data:image/s3,"s3://crabby-images/84f54/84f541c3c3d4219a417d3087b9f55593c634b0c1" alt=""
拖软件包
data:image/s3,"s3://crabby-images/dbe32/dbe3263e41b7dd11fa73ac5ec299fedcb7304d0b" alt=""
unzip node.zip
data:image/s3,"s3://crabby-images/b22c2/b22c27f9daf862c6ea8de5b941cc3a19ffa74c35" alt=""
91:
data:image/s3,"s3://crabby-images/931b8/931b8a968c6364e04bed6a6c26ac36a8e2459961" alt=""
scp kubelet kube-proxy root@192.168.233.93:/opt/kubernetes/bin/
data:image/s3,"s3://crabby-images/edea0/edea0681bc1d0b3aa258fb5ec21366ea5887cb64" alt=""
scp kubelet kube-proxy root@192.168.233.94:/opt/kubernetes/bin/
data:image/s3,"s3://crabby-images/a72f6/a72f6e313922aea8af0f5946c7925c18dadce28e" alt=""
91:
data:image/s3,"s3://crabby-images/8be03/8be035a8217ed037f6624b6198937b9a0b251f03" alt=""
拖软件包
data:image/s3,"s3://crabby-images/a2830/a2830fc276518a12e377c82753dae488becaf219" alt=""
data:image/s3,"s3://crabby-images/a0ac0/a0ac041930129f6758f9b88e5ce7c8a70c243477" alt=""
data:image/s3,"s3://crabby-images/467fa/467fa5902101712d5788a6c761f2c08c78154698" alt=""
data:image/s3,"s3://crabby-images/9c649/9c6491caac551be20ae37ef8e3aed2abc7a25e4a" alt=""
chmod 777 kubeconfig.sh
data:image/s3,"s3://crabby-images/221a9/221a955d06f57ff19447f8c6bbdbd53405ae50f0" alt=""
data:image/s3,"s3://crabby-images/0adb4/0adb464b0e38b5c023458e60cb86dfe0c40af69e" alt=""
data:image/s3,"s3://crabby-images/dee07/dee078f913aae38c8e40edd37fe96d100e111555" alt=""
scp bootstrap.kubeconfig kube-proxy.kubeconfig root@192.168.233.93:/opt/kubernetes/cfg/
data:image/s3,"s3://crabby-images/8f72d/8f72d8caac103eac616ecb27c99aebe07c8a4770" alt=""
scp bootstrap.kubeconfig kube-proxy.kubeconfig root@192.168.233.94:/opt/kubernetes/cfg/
data:image/s3,"s3://crabby-images/b3026/b30267f94b84f8f189c2a5d1d43b69be806b76a8" alt=""
93:
data:image/s3,"s3://crabby-images/4cdd1/4cdd15785ea2c93e5cea55efd0436383a18ca9e4" alt=""
94:
data:image/s3,"s3://crabby-images/4cdd1/4cdd15785ea2c93e5cea55efd0436383a18ca9e4" alt=""
91:
RBAC授权,生成和赋权用户,使用户 kubelet-bootstrap 能够有权限发起 CSR 请求证书
kubectl create clusterrolebinding kubelet-bootstrap --clusterrole=system:node-bootstrapper --user=kubelet-bootstrap
data:image/s3,"s3://crabby-images/19e9a/19e9aa4f7769a7cf755847f1bb62e3d149e3b226" alt=""
若执行失败,可先给kubectl绑定默认cluster-admin管理员集群角色,授权对整个集群的管理员权限
kubectl create clusterrolebinding cluster-system-anonymous --clusterrole=cluster-admin --user=system:anonymous
data:image/s3,"s3://crabby-images/0cd11/0cd11c4bbd13501e991eabf0011646b8faffbddf" alt=""
93:
chmod 777 kubelet.sh
data:image/s3,"s3://crabby-images/1fa8d/1fa8d91228b03f06cfcd4d6d3f38a9cf3c59ecf5" alt=""
./kubelet.sh 192.168.233.93
data:image/s3,"s3://crabby-images/2f64b/2f64bb6b094dac96532d17afd9e96eacb420784d" alt=""
91:
data:image/s3,"s3://crabby-images/494cd/494cd767d784ebef5f94590a9a0ab8cb7f887cf6" alt=""
data:image/s3,"s3://crabby-images/ba204/ba204336444deed9d0fe95716a3dc7bff8c0c6d0" alt=""
data:image/s3,"s3://crabby-images/2a365/2a365cd58e81d9de077a0de33f4741ed3ebeb66b" alt=""
data:image/s3,"s3://crabby-images/cd833/cd83357b86be16a8046dcb1c53b38fcf5ab8aeee" alt=""
94:
data:image/s3,"s3://crabby-images/cb9f8/cb9f82865ae4c915ee28c0ce203440f8c7aa0a47" alt=""
data:image/s3,"s3://crabby-images/303ca/303cabbac98762fb61615ab0fbef55779eb202b1" alt=""
data:image/s3,"s3://crabby-images/4c458/4c458f2132177e0f402e1af4ae43bca49fca8fd5" alt=""
data:image/s3,"s3://crabby-images/cce3e/cce3e38dc480128932d1fd93d00f2c051eaf4648" alt=""
91:
data:image/s3,"s3://crabby-images/ea7ba/ea7ba501b0f3242a5d08bfff3f9ad4c97eba55aa" alt=""
data:image/s3,"s3://crabby-images/2a365/2a365cd58e81d9de077a0de33f4741ed3ebeb66b" alt=""
data:image/s3,"s3://crabby-images/cd833/cd83357b86be16a8046dcb1c53b38fcf5ab8aeee" alt=""
data:image/s3,"s3://crabby-images/4728b/4728ba7a021295f6ff67caec54fea751c4f7a88e" alt=""
kube-proxy节点上的网络代理部署:
93:
cd /opt
data:image/s3,"s3://crabby-images/1c704/1c704ee5e0785a8ca60fc8fbf0dcbf5c223c8592" alt=""
for i in (ls /usr/lib/modules/(uname -r)/kernel/net/netfilter/ipvs|grep -o "^[^.]*");do echo $i; /sbin/modinfo -F filename $i >/dev/null 2>&1 && /sbin/modprobe $i;done
data:image/s3,"s3://crabby-images/351b8/351b88fca570744623439017f1c9c5cdaa0500e7" alt=""
chmod 777 proxy.sh
data:image/s3,"s3://crabby-images/6029b/6029b2e15f9bfb407bd2087be9c1b9ca2345bd59" alt=""
./proxy.sh 192.168.233.93
data:image/s3,"s3://crabby-images/0f460/0f460917df1b1784c77ff92fc2bf1f2529ee6400" alt=""
ps aux | grep kube-proxy
data:image/s3,"s3://crabby-images/bac0c/bac0c58ef4c740a224f9fe4f7833b2f9166549dd" alt=""
94:
cd /opt
data:image/s3,"s3://crabby-images/bf4b9/bf4b96cd0f4c70644c05c1e07823a41a705280ad" alt=""
for i in (ls /usr/lib/modules/(uname -r)/kernel/net/netfilter/ipvs|grep -o "^[^.]*");do echo $i; /sbin/modinfo -F filename $i >/dev/null 2>&1 && /sbin/modprobe $i;done
data:image/s3,"s3://crabby-images/a5775/a57753c286e5009db008dce699d81e03861ec759" alt=""
data:image/s3,"s3://crabby-images/afbb6/afbb60c9fbb2bd2ed0bf5a0c0da1dff85dc460de" alt=""
安装flannel:
93、94:
把软件包拖到opt目录
data:image/s3,"s3://crabby-images/88543/88543057233eafca815022aa3191a854fd087af5" alt=""
data:image/s3,"s3://crabby-images/688a1/688a16ec1ee05d16a60213cd44846b50a8fdc5eb" alt=""
data:image/s3,"s3://crabby-images/c31b8/c31b883d8d323b49d57b799797381dac750fc829" alt=""
data:image/s3,"s3://crabby-images/20a84/20a84dd2931defca07d5c5f8f8db7461046f2b21" alt=""
data:image/s3,"s3://crabby-images/74b9a/74b9a69d763b431e052dd4e5c325f3b044329a26" alt=""
91:
cd /opt/k8s
传 kube-flannel.yml 文件到 /opt/k8s 目录中,部署 CNI 网络
data:image/s3,"s3://crabby-images/73f63/73f6317f1a8f036dfdc469c12a4232f871a76d99" alt=""
data:image/s3,"s3://crabby-images/cd9f8/cd9f82ec4bbbaad2356d45c1d3d1806f27d83fe3" alt=""
data:image/s3,"s3://crabby-images/cbe78/cbe784086013bd78933c6c5afd0ab881c62cc140" alt=""
93、94:
ifconfig查看一下有没有flannel.1
部署 CoreDNS
CoreDNS:可以为集群中的 service 资源创建一个域名与 IP 的对应关系解析。
service是对外提供访问的地址,现在我们加入DNS机制之后,可以直接访问服务名
在所有 node 节点上操作
93、94:
#上传 coredns.tar 到 /opt 目录中
cd /opt
docker load -i coredns.tar
data:image/s3,"s3://crabby-images/85354/85354610a3905f9c8832d40630b755c1ebe1aecb" alt=""
//在 master01 节点上操作
91:
#上传 coredns.yaml 文件到 /opt/k8s 目录中,部署 CoreDNS
cd /opt/k8s
kubectl apply -f coredns.yaml
data:image/s3,"s3://crabby-images/11573/1157304d913fc7ffeb5b157a08ac72b1a4faecfc" alt=""
kubectl get pods -n kube-system
data:image/s3,"s3://crabby-images/939f2/939f23be6908f960f81151a2cfeaa6b9ab17d61b" alt=""
#DNS 解析测试
kubectl create clusterrolebinding cluster-system-anonymous --clusterrole=cluster-admin --user=system:anonymous
data:image/s3,"s3://crabby-images/170c8/170c87301748a3a6edd7aec01d271c750f9ffa3a" alt=""
kubectl run -it --rm dns-test --image=busybox:1.28.4 sh
data:image/s3,"s3://crabby-images/3648e/3648ef03a7e42e00fba7723210e1a79080f33911" alt=""
/ # nslookup kubernetes
data:image/s3,"s3://crabby-images/31146/31146742d50d511e043963790db6010fac6a10e1" alt=""
Server: 10.0.0.2
Address 1: 10.0.0.2 kube-dns.kube-system.svc.cluster.local
Name: kubernetes
Address 1: 10.0.0.1 kubernetes.default.svc.cluster.local
data:image/s3,"s3://crabby-images/082c2/082c2075a9892773de6d7d2590ce67afb662bd4b" alt=""
exit
master02 节点部署
92:
iptables -F && iptables -t nat -F && iptables -t mangle -F && iptables -X
data:image/s3,"s3://crabby-images/79756/797566d676af3267eee7ccc39d5531db3b48e956" alt=""
#在master添加hosts
cat >> /etc/hosts << EOF
192.168.233.91 master01
192.168.233.93 node01
192.168.233.94 node02
EOF
data:image/s3,"s3://crabby-images/46054/46054d2b12ab56d0dae90194ad901960737ecc90" alt=""
91:
data:image/s3,"s3://crabby-images/9f931/9f931759603011571857661e1550e6bb76ee7951" alt=""
data:image/s3,"s3://crabby-images/ee92b/ee92b85cbcaae77f07c0c387962296e3617d61e2" alt=""
92:
data:image/s3,"s3://crabby-images/9f931/9f931759603011571857661e1550e6bb76ee7951" alt=""
data:image/s3,"s3://crabby-images/a1672/a16727562370065619327f9ad06eda32a9d16610" alt=""
93:
如上同步
94:
如上同步
91、92、93、94同步操作:
data:image/s3,"s3://crabby-images/770a5/770a59241ea1a8ed4575dd99207ef8507a30e024" alt=""
data:image/s3,"s3://crabby-images/cfb9e/cfb9e38e8cf6a16f9a6d7ce00ad102b7e0b2ab39" alt=""
data:image/s3,"s3://crabby-images/cef26/cef26c72e728bca228607ef84d01f7649ceaaaa9" alt=""
91:
从 master01 节点上拷贝证书文件、各master组件的配置文件和服务管理文件到 master02 节点
scp -r /opt/etcd/ root@192.168.233.92:/opt/
scp -r /opt/kubernetes/ root@192.168.233.92:/opt
scp -r /root/.kube root@192.168.233.92:/root
scp /usr/lib/systemd/system/{kube-apiserver,kube-controller-manager,kube-scheduler}.service root@192.168.233.92:/usr/lib/systemd/system/
92:
修改配置文件kube-apiserver中的IP
vim /opt/kubernetes/cfg/kube-apiserver
KUBE_APISERVER_OPTS="--logtostderr=true \
--v=4 \
--etcd-servers=https://192.168.233.91:2379,https://192.168.233.93:2379,https://192.168.233.94:2379 \
--bind-address=192.168.233.92 \ #修改
--secure-port=6443 \
--advertise-address=192.168.233.92 \ #修改
在 master02 节点上启动各服务并设置开机自启
systemctl start kube-apiserver.service
systemctl enable kube-apiserver.service
systemctl start kube-controller-manager.service
systemctl enable kube-controller-manager.service
systemctl start kube-scheduler.service
systemctl enable kube-scheduler.service
data:image/s3,"s3://crabby-images/6c33a/6c33a7728c7067d9cf5d4bb98073f054a58a1d0b" alt=""
查看node节点状态
ln -s /opt/kubernetes/bin/* /usr/local/bin/
kubectl get nodes
data:image/s3,"s3://crabby-images/4cf28/4cf28f2e1e49de76ce3f01654d4a1efe0408d394" alt=""
弄完之后查看一下node状态 以及pod
data:image/s3,"s3://crabby-images/12ef3/12ef31278ead4b7fc093d648c00c1720746d24ac" alt=""
负载均衡部署 :
35、36同步操作:
data:image/s3,"s3://crabby-images/22602/226025bd5c6b17de1a42c03a9b758636a0e0291d" alt=""
配置nginx的官方在线yum源,配置本地nginx的yum源
cat > /etc/yum.repos.d/nginx.repo << 'EOF'
[nginx]
name=nginx repo
baseurl=http://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
EOF
data:image/s3,"s3://crabby-images/9d24a/9d24a3f24dd2d2f33adf393dc1a8d0b7ea8263a3" alt=""
yum install nginx -y
data:image/s3,"s3://crabby-images/d3db5/d3db57fd4dbf6942be202937c4b532dace68de18" alt=""
修改nginx配置文件,配置四层反向代理负载均衡,指定k8s群集2台master的节点ip和6443端口
vim /etc/nginx/nginx.conf
data:image/s3,"s3://crabby-images/d8cc6/d8cc61db1f20a71d16b624631c1964fc504dc598" alt=""
(以下内容可以直接把配置文件里的东西全部删掉,然后使用)
user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log notice;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
#添加
stream {
log_format main '$remote_addr upstream_addr - \[time_local] $status $upstream_bytes_sent';
#日志记录格式
#$remote_addr: 客户端的 IP 地址。
#$upstream_addr: 上游服务器的地址。
#[$time_local]: 访问时间,使用本地时间。
#$status: HTTP 响应状态码。
#$upstream_bytes_sent: 从上游服务器发送到客户端的字节数。
access_log /var/log/nginx/k8s-access.log main;
upstream k8s-apiserver {
server 192.168.233.31:6443;
server 192.168.233.32:6443;
}
server {
listen 6443;
proxy_pass k8s-apiserver;
}
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - remote_user \[time_local] "$request" '
'$status body_bytes_sent "http_referer" '
'"http_user_agent" "http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
#tcp_nopush on;
keepalive_timeout 65;
#gzip on;
include /etc/nginx/conf.d/*.conf;
}
data:image/s3,"s3://crabby-images/497ae/497aed6b935f0399c9aa34f5547d8569282f3869" alt=""
重启和开启自启nginx
data:image/s3,"s3://crabby-images/4acd8/4acd8e321dffa6ccca4ae3cfa4895c3b59ec0b44" alt=""
部署keepalived服务
yum install keepalived -y
data:image/s3,"s3://crabby-images/71156/71156db4ba8f1a34bff906b8a36b3954aff8b647" alt=""
! Configuration File for keepalived
global_defs {
接收邮件地址
notification_email {
acassen@firewall.loc
failover@firewall.loc
sysadmin@firewall.loc
}
邮件发送地址
notification_email_from Alexandre.Cassen@firewall.loc
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id NGINX_MASTER
#lb01节点的为 NGINX_MASTER,lb02节点的为 NGINX_BACKUP
#vrrp_strict #注释掉
}
#添加一个周期性执行的脚本
vrrp_script check_nginx {
script "/etc/nginx/check_nginx.sh"
#指定检查nginx存活的脚本路径
}
vrrp_instance VI_1 {
state MASTER
#lb01节点的为 MASTER,lb02节点的为 BACKUP
interface ens33
#指定网卡名称 ens33
virtual_router_id 51
#指定vrid,两个节点要一致
priority 10 0
#lb01节点的为 100,lb02节点的为 90
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.233.100/24 #指定 VIP
}
track_script {
check_nginx #指定vrrp_script配置的脚本
}
}
data:image/s3,"s3://crabby-images/4007f/4007fcc9d3b7497b1ad39a665199a391d4d7d85a" alt=""
data:image/s3,"s3://crabby-images/d9ebb/d9ebbee219d4c816acd1de58d6450898c757472a" alt=""
data:image/s3,"s3://crabby-images/acd41/acd4113ce696e4f3f091f7eed057760a9db427a9" alt=""
data:image/s3,"s3://crabby-images/80dd0/80dd03a5156d9f7d739b96983879c6c309c51d7b" alt=""
创建nginx状态检查脚本
vim /etc/nginx/check_nginx.sh
data:image/s3,"s3://crabby-images/910ef/910ef7a9061d48c78cab8bbf0800bef24b45ffd4" alt=""
#!/bin/bash
/usr/bin/curl -I http://localhost &>/dev/null
if [ $? -ne 0 ];then
/etc/init.d/keepalived stop
systemctl stop keepalived
fi
data:image/s3,"s3://crabby-images/9c31f/9c31fe5e70972ec0d9974e56df09b66793004ab7" alt=""
chmod +x /etc/nginx/check_nginx.sh
data:image/s3,"s3://crabby-images/b22fb/b22fb4d6d078f100143963e21194a20cad724614" alt=""
先启动nginx,再启动keepalived
data:image/s3,"s3://crabby-images/3dd8f/3dd8fb9bce2021fe23fdba679c8c7ffc46391e85" alt=""
ip a查看虚拟ip地址
data:image/s3,"s3://crabby-images/53a90/53a905dd8e1e7b0ebb7ecde5c5a36030bb55faec" alt=""
可以停主的nginx 看看ip有没有飘到备上
data:image/s3,"s3://crabby-images/2971b/2971bd4513a2a5eca0ac9209955be881d785e76f" alt=""
93、94同步操作:
修改node节点上的bootstrap.kubeconfig,kubelet.kubeconfig配置文件为VIP
cd /opt/kubernetes/cfg/
vim bootstrap.kubeconfig
data:image/s3,"s3://crabby-images/44788/447882fcc342dcb258fe380980481506ed4c0c1b" alt=""
vim kubelet.kubeconfig
server: https://192.168.233.100:6443
vim kube-proxy.kubeconfig
server: https://192.168.233.100:6443
data:image/s3,"s3://crabby-images/7153f/7153fa03f0f7b80e7d7b23bafed617cc32876d8e" alt=""
重启kubelet和kube-proxy服务
systemctl restart kubelet.service
systemctl restart kube-proxy.service
data:image/s3,"s3://crabby-images/658bd/658bdfdf023a77bb5961b8ca802d26624e68b003" alt=""
然后用主的有虚拟ip的主机查看端口号6443
data:image/s3,"s3://crabby-images/a7948/a794881e7ec63056ec7ab4b059b08e337201e8c0" alt=""
##### 在 master01 节点上操作 #####
//测试创建pod
kubectl run nginx --image=nginx
//查看Pod的状态信息
kubectl get pods
部署 Dashboard :
Dashboard:仪表盘,kubernetes的可视化界面,在这个可视化界面上,可以对k8s集群进行管理
91:
在 master01 节点上操作
#上传 recommended.yaml 文件到 /opt/k8s 目录中
data:image/s3,"s3://crabby-images/6597c/6597c7a3a2273a240fa4586ddc08acbca176f204" alt=""
kubectl apply -f recommended.yaml
data:image/s3,"s3://crabby-images/1526f/1526f1e36deb3be4b3e718d4a312d979d8749c4c" alt=""
创建service account并绑定默认cluster-admin管理员集群角色
kubectl create serviceaccount dashboard-admin -n kube-system
data:image/s3,"s3://crabby-images/45770/4577012ec8d489062c1a1b39d6d1c272577064b8" alt=""
kubectl create clusterrolebinding dashboard-admin --clusterrole=cluster-admin --serviceaccount=kube-system:dashboard-admin
data:image/s3,"s3://crabby-images/0d9d8/0d9d8ee4048629787a5a82876cdd1d2e8427f72c" alt=""
获取token值
kubectl describe secrets -n kube-system $(kubectl -n kube-system get secret | awk '/dashboard-admin/{print $1}')
data:image/s3,"s3://crabby-images/7ca81/7ca81837574f9b0436a7d8c5f7ee60803a61e7fe" alt=""
然后用浏览器登录 (有的浏览器用不了)
data:image/s3,"s3://crabby-images/efe9a/efe9ad9ed0d7d60fe92591fce276fca80fae5a44" alt=""
点击高级
data:image/s3,"s3://crabby-images/66e6b/66e6bb49a5926c15a6155e5a6a51a0cdb9ec721d" alt=""
data:image/s3,"s3://crabby-images/d92ae/d92ae258273d7b4b2982cb5238eacb448e0eea99" alt=""
这一步的密码就是上面几步中获取token值的密码
data:image/s3,"s3://crabby-images/e45f8/e45f81b319ff2d724676962ffb7f913b7e0477a3" alt=""
data:image/s3,"s3://crabby-images/c6c0b/c6c0b3178c2fcdc1a17a920cf78a98c005b9aef6" alt=""
进入到这里算完成创建
data:image/s3,"s3://crabby-images/8d890/8d8904cf381a24e8ec0ba4965dc73910be30f749" alt=""
补齐的命令部署:
data:image/s3,"s3://crabby-images/a9140/a9140065398eced75a6ff3381caa1f52f1b97797" alt=""
在最后一行
data:image/s3,"s3://crabby-images/fca2e/fca2e032de906db34fea2c5fad527e078e0139b6" alt=""
data:image/s3,"s3://crabby-images/c70ab/c70ab1e206511dd8cfa9a55d92130797f74fb6aa" alt=""