部署K8s多節(jié)點,首先得署單節(jié)master的k8s群集
詳情參考:
blog.csdn.net/caozhengtao1213/article/details/103987039
1.部署Master2
2.Nginx負載均衡部署-keeplived服務(wù)
3.node節(jié)點修改配置文件統(tǒng)一VIP
4.創(chuàng)建Pod
5.創(chuàng)建UI顯示界面
角色 | 地址 | 安裝組件 |
---|---|---|
master | 192.168.142.129 | kube-apiserver kube-controller-manager kube-scheduler etcd |
master2 | 192.168.142.120 | kube-apiserver kube-controller-manager kube-scheduler |
node1 | 192.168.142.130 | kubelet kube-proxy docker flannel etcd |
node2 | 192.168.142.131 | kubelet kube-proxy docker flannel etcd |
nginx1(lbm) | 192.168.142.140 | nginx keepalived |
nginx2(lbb) | 192.168.142.150 | nginx keepalived |
VIP | 192.168.142.20 | - |
資源包鏈接:
https://pan.baidu.com/s/183G9ZzBNdcUUFV7Y8-K4CQ
提取碼:6z0j
1.遠程復(fù)制master的相關(guān)目錄
systemctl stop firewalld.service
setenforce 0
scp -r /opt/kubernetes/ root@192.168.142.120:/opt
scp -r /opt/etcd/ root@192.168.142.120:/opt
scp /usr/lib/systemd/system/{kube-apiserver,kube-controller-manager,kube-scheduler}.service root@192.168.142.120:/usr/lib/systemd/system/
2.修改kube-apiserver配置文件
vim /opt/kubernetes/cfg/kube-apiserver
#將第5和7行IP地址改為master2主機的地址
--bind-address=192.168.142.120 \
--advertise-address=192.168.142.120 \
3.啟動服務(wù)并設(shè)定開機自啟
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
4.追加環(huán)境變量并生效
vim /etc/profile
#末尾追加
export PATH=$PATH:/opt/kubernetes/bin/
source /etc/profile
5.查看node節(jié)點
kubectl get node
NAME STATUS ROLES AGE VERSION
192.168.142.130 Ready 10d12h v1.12.3
192.168.142.131 Ready 10d11h v1.12.3
1.在lbm&lbb端的操作,安裝nginx服務(wù)
#nginx.sh
cat > /etc/yum.repos.d/nginx.repo << EOF
[nginx]
name=nginx repo
baseurl=http://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
EOF
stream {
log_format main '$remote_addr $upstream_addr - [$time_local] $status $upstream_bytes_sent';
access_log /var/log/nginx/k8s-access.log main;
upstream k8s-apiserver {
server 10.0.0.3:6443;
server 10.0.0.8:6443;
}
server {
listen 6443;
proxy_pass k8s-apiserver;
}
}
#keepalived.conf
! Configuration File for keepalived
global_defs {
# 接收郵件地址
notification_email {
acassen@firewall.loc
failover@firewall.loc
sysadmin@firewall.loc
}
# 郵件發(fā)送地址
notification_email_from Alexandre.Cassen@firewall.loc
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id NGINX_MASTER
}
vrrp_script check_nginx {
script "/usr/local/nginx/sbin/check_nginx.sh"
}
vrrp_instance VI_1 {
state MASTER
interface eth0
virtual_router_id 51 # VRRP 路由 ID實例,每個實例是唯一的
priority 100 # 優(yōu)先級,備服務(wù)器設(shè)置 90
advert_int 1 # 指定VRRP 心跳包通告間隔時間,默認1秒
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
10.0.0.188/24
}
track_script {
check_nginx
}
}
mkdir /usr/local/nginx/sbin/ -p
vim /usr/local/nginx/sbin/check_nginx.sh
count=$(ps -ef |grep nginx |egrep -cv "grep|$$")
if [ "$count" -eq 0 ];then
/etc/init.d/keepalived stop
fi
chmod +x /usr/local/nginx/sbin/check_nginx.sh
vim /etc/yum.repos.d/nginx.repo
[nginx]
name=nginx repo
baseurl=http://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
yum install nginx -y
vim /etc/nginx/nginx.conf
#在第12行下追加以下內(nèi)容
stream {
log_format main '$remote_addr $upstream_addr - [$time_local] $status $upstream_bytes_sent';
access_log /var/log/nginx/k8s-access.log main;
upstream k8s-apiserver {
server 192.168.142.129:6443; #此處為master的ip地址
server 192.168.142.120:6443; #此處為master2的ip地址
}
server {
listen 6443;
proxy_pass k8s-apiserver;
}
}
2.部署keeplived服務(wù)
#安裝keepalived
yum install keepalived -y
復(fù)制前面的keepalived.conf配置文件,覆蓋安裝后原有的配置文件
cp keepalived.conf /etc/keepalived/keepalived.conf
vim /etc/keepalived/keepalived.conf
script "/etc/nginx/check_nginx.sh" #18行,目錄改為/etc/nginx/,腳本后寫
interface ens33 #23行,eth0改為ens33,此處的網(wǎng)卡名稱可以使用ifconfig命令查詢
virtual_router_id 51 #24行,vrrp路由ID實例,每個實例是唯一的
priority 100 #25行,優(yōu)先級,備服務(wù)器設(shè)置90
virtual_ipaddress { #31行,
192.168.142.20/24 #32行,vip地址改為之前設(shè)定好的192.168.142.20
#38行以下全部刪除
vim /etc/nginx/check_nginx.sh
#統(tǒng)計數(shù)量
count=$(ps -ef |grep nginx |egrep -cv "grep|$$") #統(tǒng)計數(shù)量
#匹配為0,關(guān)閉keepalived服務(wù)
if [ "$count" -eq 0 ];then
systemctl stop keepalived
fi
chmod +x /etc/nginx/check_nginx.sh
#啟動服務(wù)
systemctl start keepalived
ip a
# lbm地址信息
2: ens33: mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 00:0c:29:eb:11:2a brd ff:ff:ff:ff:ff:ff
inet 192.168.142.140/24 brd 192.168.142.255 scope global ens33
valid_lft forever preferred_lft forever
inet 192.168.142.20/24 scope global secondary ens33 //漂移地址在lb01中
valid_lft forever preferred_lft forever
inet6 fe80::53ba:daab:3e22:e711/64 scope link
valid_lft forever preferred_lft forever
#lbb地址信息
2: ens33: mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 00:0c:29:c9:9d:88 brd ff:ff:ff:ff:ff:ff
inet 192.168.142.150/24 brd 192.168.142.255 scope global ens33
valid_lft forever preferred_lft forever
inet6 fe80::55c0:6788:9feb:550d/64 scope link
valid_lft forever preferred_lft forever
#停止lbm端的nginx服務(wù)
pkill nginx
#查看服務(wù)狀態(tài)
systemctl status nginx
systemctl status keepalived.service
#此時判斷條件若為0,keepalived服務(wù)則是停止的
ps -ef |grep nginx |egrep -cv "grep|$$"
ip a
# lbm地址信息
2: ens33: mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 00:0c:29:eb:11:2a brd ff:ff:ff:ff:ff:ff
inet 192.168.142.140/24 brd 192.168.142.255 scope global ens33
valid_lft forever preferred_lft forever
inet6 fe80::53ba:daab:3e22:e711/64 scope link
valid_lft forever preferred_lft forever
#lbb地址信息
2: ens33: mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 00:0c:29:c9:9d:88 brd ff:ff:ff:ff:ff:ff
inet 192.168.142.150/24 brd 192.168.142.255 scope global ens33
valid_lft forever preferred_lft forever
inet 192.168.142.20/24 scope global secondary ens33 //漂移地址在lb01中
valid_lft forever preferred_lft forever
inet6 fe80::55c0:6788:9feb:550d/64 scope link
valid_lft forever preferred_lft forever
#在lbm端啟動nginx和keepalived服務(wù)
systemctl start nginx
systemctl start keepalived
ip a
# lbm地址信息
2: ens33: mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 00:0c:29:eb:11:2a brd ff:ff:ff:ff:ff:ff
inet 192.168.142.140/24 brd 192.168.142.255 scope global ens33
valid_lft forever preferred_lft forever
inet 192.168.142.20/24 scope global secondary ens33 //漂移地址在lb01中
valid_lft forever preferred_lft forever
inet6 fe80::53ba:daab:3e22:e711/64 scope link
valid_lft forever preferred_lft forever
cd /opt/kubernetes/cfg/
#配置文件統(tǒng)一修改為VIP
vim /opt/kubernetes/cfg/bootstrap.kubeconfig
server: https://192.168.142.20:6443
#第5行改為Vip的地址
vim /opt/kubernetes/cfg/kubelet.kubeconfig
server: https://192.168.142.20:6443
#第5行改為Vip的地址
vim /opt/kubernetes/cfg/kube-proxy.kubeconfig
server: https://192.168.142.20:6443
#第5行改為Vip的地址
grep 20 *
bootstrap.kubeconfig: server: https://192.168.142.20:6443
kubelet.kubeconfig: server: https://192.168.142.20:6443
kube-proxy.kubeconfig: server: https://192.168.142.20:6443
tail /var/log/nginx/k8s-access.log
192.168.142.140 192.168.142.129:6443 - [08/Feb/2020:19:20:40 +0800] 200 1119
192.168.142.140 192.168.142.120:6443 - [08/Feb/2020:19:20:40 +0800] 200 1119
192.168.142.150 192.168.142.129:6443 - [08/Feb/2020:19:20:44 +0800] 200 1120
192.168.142.150 192.168.142.120:6443 - [08/Feb/2020:19:20:44 +0800] 200 1120
kubectl run nginx --image=nginx
kubectl get pods
kubectl create clusterrolebinding cluster-system-anonymous --clusterrole=cluster-admin --user=system:anonymous
kubectl get pods -o wid
mkdir /k8s/dashboard
cd /k8s/dashboard
#上傳官方的文件到該目錄中
#授權(quán)訪問api
kubectl create -f dashboard-rbac.yaml
#進行加密
kubectl create -f dashboard-secret.yaml
#配置應(yīng)用
kubectl create -f dashboard-configmap.yaml
#控制器
kubectl create -f dashboard-controller.yaml
#發(fā)布出去進行訪問
kubectl create -f dashboard-service.yaml
kubectl get pods -n kube-system
kubectl get pods,svc -n kube-system
1.在master端操作,編寫進行證書自簽
vim dashboard-cert.sh
cat > dashboard-csr.json <
2.重新應(yīng)用新的自簽證書
bash dashboard-cert.sh /root/k8s/apiserver/
3.修改yaml文件
vim dashboard-controller.yaml
#在47行下追加以下內(nèi)容
- --tls-key-file=dashboard-key.pem
- --tls-cert-file=dashboard.pem
4.重新進行部署
kubectl apply -f dashboard-controller.yaml
5.生成登錄令牌
kubectl create -f k8s-admin.yaml
kubectl get secret -n kube-system
NAME TYPE DATA AGE
dashboard-admin-token-drs7c kubernetes.io/service-account-token 3 60s
default-token-mmvcg kubernetes.io/service-account-token 3 55m
kubernetes-dashboard-certs Opaque 10 10m
kubernetes-dashboard-key-holder Opaque 2 23m
kubernetes-dashboard-token-crqvs kubernetes.io/service-account-token 3 23m
kubectl describe secret dashboard-admin-token-drs7c -n kube-system
6.復(fù)制粘貼令牌后,登錄到UI界面