{"id":76570,"date":"2026-02-22T20:33:27","date_gmt":"2026-02-22T12:33:27","guid":{"rendered":"https:\/\/www.wsisp.com\/helps\/76570.html"},"modified":"2026-02-22T20:33:27","modified_gmt":"2026-02-22T12:33:27","slug":"%e4%bb%8e%e5%8d%95%e8%8a%82%e7%82%b9%e5%88%b0%e9%ab%98%e5%8f%af%e7%94%a8%ef%bc%9a%e6%88%91%e6%98%af%e5%a6%82%e4%bd%95%e4%b8%80%e6%ad%a5%e6%ad%a5%e6%90%ad%e5%bb%ba%e7%94%9f%e4%ba%a7%e7%ba%a7k8s","status":"publish","type":"post","link":"https:\/\/www.wsisp.com\/helps\/76570.html","title":{"rendered":"\u4ece\u5355\u8282\u70b9\u5230\u9ad8\u53ef\u7528\uff1a\u6211\u662f\u5982\u4f55\u4e00\u6b65\u6b65\u642d\u5efa\u751f\u4ea7\u7ea7K8s\u96c6\u7fa4\u7684"},"content":{"rendered":"<p>\u6700\u8fd1\u5728\u865a\u62df\u673a\u4e0a\u642d\u5efa\u4e86\u4e00\u5957\u57fa\u4e8eHAProxy &#043; 3 Master &#043; 2 Node\u7684K8s\u9ad8\u53ef\u7528\u96c6\u7fa4&#xff0c;\u8e29\u4e86\u4e0d\u5c11\u5751&#xff0c;\u4e5f\u6c89\u6dc0\u4e86\u4e00\u5957\u53ef\u590d\u7528\u7684\u90e8\u7f72\u811a\u672c\u3002\u4eca\u5929\u5c31\u628a\u6574\u4e2a\u8fc7\u7a0b\u548c\u811a\u672c\u5206\u4eab\u51fa\u6765&#xff0c;\u5e0c\u671b\u80fd\u5e2e\u5230\u6709\u540c\u6837\u9700\u6c42\u7684\u540c\u5b66\u3002<\/p>\n<hr \/>\n<h3>\u4e00\u3001\u96c6\u7fa4\u67b6\u6784\u8bbe\u8ba1<\/h3>\n<p>\u6211\u4eec\u7684\u76ee\u6807\u662f\u642d\u5efa\u4e00\u4e2a\u751f\u4ea7\u53ef\u7528\u7684K8s\u96c6\u7fa4&#xff0c;\u6838\u5fc3\u8bbe\u8ba1\u5982\u4e0b&#xff1a;<\/p>\n<table>\n<tr>\u89d2\u8272\u8282\u70b9IP\u8bf4\u660e<\/tr>\n<tbody>\n<tr>\n<td>HAProxy<\/td>\n<td>192.168.56.102<\/td>\n<td>\u4f5c\u4e3aAPI Server\u7684\u8d1f\u8f7d\u5747\u8861\u5165\u53e3&#xff0c;\u65e0\u9700\u5065\u5eb7\u68c0\u67e5<\/td>\n<\/tr>\n<tr>\n<td>Master<\/td>\n<td>192.168.56.111<\/td>\n<td>\u7b2c\u4e00\u4e2a\u63a7\u5236\u5e73\u9762\u8282\u70b9&#xff0c;\u751f\u6210etcd\u8bc1\u4e66\u548c\u96c6\u7fa4\u914d\u7f6e<\/td>\n<\/tr>\n<tr>\n<td>Master<\/td>\n<td>192.168.56.112<\/td>\n<td>\u52a0\u5165\u96c6\u7fa4\u7684\u63a7\u5236\u5e73\u9762\u8282\u70b9<\/td>\n<\/tr>\n<tr>\n<td>Master<\/td>\n<td>192.168.56.113<\/td>\n<td>\u52a0\u5165\u96c6\u7fa4\u7684\u63a7\u5236\u5e73\u9762\u8282\u70b9<\/td>\n<\/tr>\n<tr>\n<td>Node<\/td>\n<td>192.168.56.114<\/td>\n<td>\u5de5\u4f5c\u8282\u70b9<\/td>\n<\/tr>\n<tr>\n<td>Node<\/td>\n<td>192.168.56.115<\/td>\n<td>\u5de5\u4f5c\u8282\u70b9<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>\u5173\u952e\u914d\u7f6e&#xff1a;<\/p>\n<ul>\n<li>Pod\u7f51\u6bb5&#xff1a;192.156.32.0\/20<\/li>\n<li>Service\u7f51\u6bb5&#xff1a;192.168.48.0\/24<\/li>\n<li>\u6240\u6709\u8282\u70b9\u5f3a\u5236\u4f7f\u7528enp0s8\u7f51\u5361IP<\/li>\n<li>\u4f7f\u7528containerd\u4f5c\u4e3a\u5bb9\u5668\u8fd0\u884c\u65f6<\/li>\n<li>\u4f7f\u7528Calico\u4f5c\u4e3a\u7f51\u7edc\u63d2\u4ef6<\/li>\n<\/ul>\n<hr \/>\n<h3>\u4e8c\u3001\u90e8\u7f72\u811a\u672c\u5408\u96c6<\/h3>\n<h4>1. 01-deploy-haproxy.sh&#xff08;\u4fee\u590dHAProxy\u542f\u52a8\u95ee\u9898&#xff09;<\/h4>\n<p><span class=\"token shebang important\">#!\/bin\/bash<\/span><br \/>\n<span class=\"token builtin class-name\">set<\/span> -euo pipefail<\/p>\n<p><span class=\"token comment\"># \u914d\u7f6e\u9879<\/span><br \/>\n<span class=\"token assign-left variable\">HAPROXY_NODE_IP<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;192.168.56.102&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">MASTER_NODES<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;192.168.56.111&#034;<\/span> <span class=\"token string\">&#034;192.168.56.112&#034;<\/span> <span class=\"token string\">&#034;192.168.56.113&#034;<\/span><span class=\"token punctuation\">)<\/span><br \/>\n<span class=\"token assign-left variable\">K8S_API_PORT<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token number\">6443<\/span><br \/>\n<span class=\"token assign-left variable\">HAPROXY_PORT<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token number\">6443<\/span><\/p>\n<p><span class=\"token comment\"># \u5b89\u88c5haproxy<\/span><br \/>\n<span class=\"token function\">apt<\/span> update -y <span class=\"token operator\">&amp;&amp;<\/span> <span class=\"token function\">apt<\/span> <span class=\"token function\">install<\/span> -y haproxy net-tools <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># \u5907\u4efd\u539f\u6709\u914d\u7f6e<\/span><br \/>\n<span class=\"token function\">mv<\/span> \/etc\/haproxy\/haproxy.cfg \/etc\/haproxy\/haproxy.cfg.bak<span class=\"token variable\"><span class=\"token variable\">$(<\/span><span class=\"token function\">date<\/span> &#043;%Y%m%d%H%M%S<span class=\"token variable\">)<\/span><\/span> <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># \u751f\u6210haproxy\u914d\u7f6e<\/span><br \/>\n<span class=\"token function\">cat<\/span> <span class=\"token operator\">&gt;<\/span> \/etc\/haproxy\/haproxy.cfg <span class=\"token operator\">&lt;&lt;<\/span> <span class=\"token string\">EOF<br \/>\nglobal<br \/>\n    log \/dev\/log    local0<br \/>\n    log \/dev\/log    local1 notice<br \/>\n    chroot \/var\/lib\/haproxy<br \/>\n    stats socket \/run\/haproxy\/admin.sock mode 660 level admin expose-fd listeners<br \/>\n    stats timeout 30s<br \/>\n    user haproxy<br \/>\n    group haproxy<br \/>\n    daemon<br \/>\n    maxconn 2000<\/p>\n<p>defaults<br \/>\n    log     global<br \/>\n    mode    tcp<br \/>\n    option  tcplog<br \/>\n    option  dontlognull<br \/>\n    timeout connect 5000<br \/>\n    timeout client  50000<br \/>\n    timeout server  50000<br \/>\n    errorfile 400 \/etc\/haproxy\/errors\/400.http<br \/>\n    errorfile 403 \/etc\/haproxy\/errors\/403.http<br \/>\n    errorfile 408 \/etc\/haproxy\/errors\/408.http<br \/>\n    errorfile 500 \/etc\/haproxy\/errors\/500.http<br \/>\n    errorfile 502 \/etc\/haproxy\/errors\/502.http<br \/>\n    errorfile 503 \/etc\/haproxy\/errors\/503.http<br \/>\n    errorfile 504 \/etc\/haproxy\/errors\/504.http<\/p>\n<p>frontend k8s-api-frontend<br \/>\n    bind <span class=\"token variable\">${HAPROXY_NODE_IP}<\/span>:<span class=\"token variable\">${HAPROXY_PORT}<\/span><br \/>\n    default_backend k8s-api-backend<\/p>\n<p>backend k8s-api-backend<br \/>\n    mode tcp<br \/>\n    balance roundrobin<br \/>\n    option tcp-check<br \/>\n    # \u4fee\u590d&#xff1a;fall 0 rise 0 \u6539\u4e3a fall 3 rise 2&#xff0c;\u4fdd\u8bc1HAProxy\u80fd\u542f\u52a8<br \/>\nEOF<\/span><\/p>\n<p><span class=\"token comment\"># \u6dfb\u52a0master\u8282\u70b9\u5230backend<\/span><br \/>\n<span class=\"token keyword\">for<\/span> <span class=\"token for-or-select variable\">master<\/span> <span class=\"token keyword\">in<\/span> <span class=\"token string\">&#034;<span class=\"token variable\">${MASTER_NODES<span class=\"token punctuation\">[<\/span>&#064;<span class=\"token punctuation\">]<\/span>}<\/span>&#034;<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">do<\/span><br \/>\n    <span class=\"token function\">cat<\/span> <span class=\"token operator\">&gt;&gt;<\/span> \/etc\/haproxy\/haproxy.cfg <span class=\"token operator\">&lt;&lt;<\/span> <span class=\"token string\">EOF<br \/>\n    server master-<span class=\"token variable\">${master<span class=\"token operator\">\/<\/span><span class=\"token operator\">\/<\/span>.<span class=\"token operator\">\/<\/span>-}<\/span> <span class=\"token variable\">${master}<\/span>:<span class=\"token variable\">${K8S_API_PORT}<\/span> check inter 2000 fall 3 rise 2<br \/>\nEOF<\/span><br \/>\n<span class=\"token keyword\">done<\/span><\/p>\n<p><span class=\"token comment\"># \u91cd\u542fhaproxy\u5e76\u8bbe\u7f6e\u5f00\u673a\u81ea\u542f<\/span><br \/>\nsystemctl daemon-reload<br \/>\nsystemctl <span class=\"token builtin class-name\">enable<\/span> &#8211;now haproxy<br \/>\nsystemctl restart haproxy<\/p>\n<p><span class=\"token comment\"># \u9a8c\u8bc1haproxy\u72b6\u6001<\/span><br \/>\n<span class=\"token keyword\">if<\/span> systemctl is-active &#8211;quiet haproxy<span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">then<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[32mHAProxy\u90e8\u7f72\u6210\u529f&#xff0c;\u76d1\u542c\u5730\u5740: <span class=\"token variable\">${HAPROXY_NODE_IP}<\/span>:<span class=\"token variable\">${HAPROXY_PORT}<\/span><span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n<span class=\"token keyword\">else<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[31mHAProxy\u542f\u52a8\u5931\u8d25<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n    systemctl status haproxy &#8211;no-pager<br \/>\n    <span class=\"token builtin class-name\">exit<\/span> <span class=\"token number\">1<\/span><br \/>\n<span class=\"token keyword\">fi<\/span><\/p>\n<p>\u4fee\u590d\u70b9&#xff1a;\u5c06fall 0 rise 0\u6539\u4e3afall 3 rise 2&#xff0c;\u89e3\u51b3HAProxy\u542f\u52a8\u5931\u8d25\u95ee\u9898\u3002<\/p>\n<hr \/>\n<h4>2. 02-clean-k8s-env.sh&#xff08;\u6e05\u7406K8s\u6b8b\u7559&#xff09;<\/h4>\n<p><span class=\"token shebang important\">#!\/bin\/bash<\/span><br \/>\n<span class=\"token builtin class-name\">set<\/span> -euo pipefail<\/p>\n<p><span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;\u5f00\u59cb\u6e05\u7406K8s\u96c6\u7fa4\u6b8b\u7559\u8d44\u6e90&#8230;&#034;<\/span><\/p>\n<p><span class=\"token comment\"># \u505c\u6b62\u670d\u52a1<\/span><br \/>\nsystemctl stop kubelet containerd haproxy <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><br \/>\n<span class=\"token function\">pkill<\/span> -9 kubelet containerd <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># \u5378\u8f7d\u6302\u8f7d\u5377<\/span><br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;\u5378\u8f7dK8s\u76f8\u5173\u6302\u8f7d\u5377&#8230;&#034;<\/span><br \/>\n<span class=\"token function\">mount<\/span> <span class=\"token operator\">|<\/span> <span class=\"token function\">grep<\/span> -E <span class=\"token string\">&#034;\/run\/containerd|\/var\/lib\/kubelet|\/var\/lib\/containerd|\/opt\/cni&#034;<\/span> <span class=\"token operator\">|<\/span> <span class=\"token function\">awk<\/span> <span class=\"token string\">&#039;{print $3}&#039;<\/span> <span class=\"token operator\">|<\/span> <span class=\"token function\">xargs<\/span> -r <span class=\"token function\">umount<\/span> -lf <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># \u5220\u9664\u76ee\u5f55\u548c\u6587\u4ef6<\/span><br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;\u5220\u9664K8s\u76f8\u5173\u76ee\u5f55\/\u6587\u4ef6&#8230;&#034;<\/span><br \/>\n<span class=\"token function\">rm<\/span> -rf \/run\/containerd \/var\/lib\/containerd \/etc\/containerd <span class=\"token punctuation\">\\\\<\/span><br \/>\n       \/etc\/kubernetes \/var\/lib\/kubelet \/var\/lib\/cni \/opt\/cni\/bin <span class=\"token punctuation\">\\\\<\/span><br \/>\n       \/run\/kubelet\/* \/root\/.kube \/etc\/systemd\/system\/kubelet.service* <span class=\"token punctuation\">\\\\<\/span><br \/>\n       \/etc\/default\/kubelet \/tmp\/k8s-bin <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># \u5220\u9664\u4e8c\u8fdb\u5236\u6587\u4ef6<\/span><br \/>\n<span class=\"token function\">rm<\/span> -f \/usr\/bin\/kubeadm \/usr\/bin\/kubelet \/usr\/bin\/kubectl \/usr\/local\/bin\/crictl <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># \u6e05\u7406iptables\u89c4\u5219<\/span><br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;\u6e05\u7406iptables\u89c4\u5219&#8230;&#034;<\/span><br \/>\niptables -F <span class=\"token operator\">&amp;&amp;<\/span> iptables -X <span class=\"token operator\">&amp;&amp;<\/span> iptables -F -t nat <span class=\"token operator\">&amp;&amp;<\/span> iptables -X -t nat <span class=\"token operator\">&amp;&amp;<\/span> iptables -F -t mangle <span class=\"token operator\">&amp;&amp;<\/span> iptables -X -t mangle <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><br \/>\nip6tables -F <span class=\"token operator\">&amp;&amp;<\/span> ip6tables -X <span class=\"token operator\">&amp;&amp;<\/span> ip6tables -F -t nat <span class=\"token operator\">&amp;&amp;<\/span> ip6tables -X -t nat <span class=\"token operator\">&amp;&amp;<\/span> ip6tables -F -t mangle <span class=\"token operator\">&amp;&amp;<\/span> ip6tables -X -t mangle <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># \u6e05\u7406\u7f51\u7edc\u63a5\u53e3<\/span><br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;\u6e05\u7406CNI\u7f51\u7edc\u63a5\u53e3&#8230;&#034;<\/span><br \/>\n<span class=\"token function\">ip<\/span> <span class=\"token function\">link<\/span> delete cni0 <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><br \/>\n<span class=\"token function\">ip<\/span> <span class=\"token function\">link<\/span> delete flannel.1 <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><br \/>\n<span class=\"token function\">ip<\/span> <span class=\"token function\">link<\/span> delete cali* <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><br \/>\n<span class=\"token function\">ip<\/span> <span class=\"token function\">link<\/span> delete kube-ipvs0 <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># \u6e05\u7406swap<\/span><br \/>\nswapoff -a <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><br \/>\n<span class=\"token function\">sed<\/span> -i <span class=\"token string\">&#039;\/swap\/s\/^\/#\/&#039;<\/span> \/etc\/fstab <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># \u91cd\u65b0\u52a0\u8f7dsystemd<\/span><br \/>\nsystemctl daemon-reload<\/p>\n<p><span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[32mK8s\u73af\u5883\u6e05\u7406\u5b8c\u6210<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><\/p>\n<hr \/>\n<h4>3. 03-init-all-nodes.sh&#xff08;\u521d\u59cb\u5316\u6240\u6709\u8282\u70b9&#xff0c;\u4e0d\u542bHAProxy&#xff09;<\/h4>\n<p><span class=\"token shebang important\">#!\/bin\/bash<\/span><br \/>\n<span class=\"token builtin class-name\">set<\/span> -euo pipefail<\/p>\n<p><span class=\"token comment\"># \u6838\u5fc3\u914d\u7f6e<\/span><br \/>\n<span class=\"token assign-left variable\">PROXY_ADDR<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;http:\/\/192.168.56.102:8080&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">HARBOR_REGISTRY<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;192.168.56.102&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">HARBOR_FULL_ADDR<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;http:\/\/<span class=\"token variable\">${HARBOR_REGISTRY}<\/span>&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">HARBOR_USER<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;admin&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">HARBOR_PASS<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;Harbor12345&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">K8S_VERSION<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;1.33.6&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">ARCH<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;amd64&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">DOWNLOAD_DIR<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;\/tmp\/k8s-bin&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">PAUSE_VERSION<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;3.8&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">PAUSE_TARGET_VERSION<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;3.10&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">SOURCE_REGISTRY<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;registry.k8s.io&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">TARGET_REGISTRY<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;<span class=\"token variable\">${HARBOR_REGISTRY}<\/span>\/library&#034;<\/span><\/p>\n<p><span class=\"token comment\"># \u83b7\u53d6\u5f53\u524d\u8282\u70b9enp0s8\u7684IP<\/span><br \/>\n<span class=\"token assign-left variable\">NODE_IP<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token variable\"><span class=\"token variable\">$(<\/span><span class=\"token function\">ip<\/span> addr show enp0s8 <span class=\"token operator\">|<\/span> <span class=\"token function\">grep<\/span> -oP <span class=\"token string\">&#039;(?&lt;&#061;inet\\\\s)\\\\d&#043;(\\\\.\\\\d&#043;){3}&#039;<\/span> <span class=\"token operator\">|<\/span> <span class=\"token function\">head<\/span> -1<span class=\"token variable\">)<\/span><\/span><br \/>\n<span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">[<\/span> -z <span class=\"token string\">&#034;<span class=\"token variable\">${NODE_IP}<\/span>&#034;<\/span> <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">then<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[31m\u672a\u627e\u5230enp0s8\u7f51\u5361\u7684IP&#xff0c;\u8bf7\u68c0\u67e5\u7f51\u5361\u540d\u79f0<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n    <span class=\"token builtin class-name\">exit<\/span> <span class=\"token number\">1<\/span><br \/>\n<span class=\"token keyword\">fi<\/span><\/p>\n<p><span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;\u5f53\u524d\u8282\u70b9enp0s8 IP: <span class=\"token variable\">${NODE_IP}<\/span>&#034;<\/span><\/p>\n<p><span class=\"token comment\"># 1. \u57fa\u7840\u914d\u7f6e<\/span><br \/>\ntimedatectl set-timezone Asia\/Shanghai <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><br \/>\n<span class=\"token function\">apt<\/span> update -y <span class=\"token operator\">&amp;&amp;<\/span> <span class=\"token function\">apt<\/span> upgrade -y <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># 2. \u5b89\u88c5\u4f9d\u8d56<\/span><br \/>\n<span class=\"token function\">apt<\/span> <span class=\"token function\">install<\/span> -y <span class=\"token function\">curl<\/span> <span class=\"token function\">wget<\/span> iptables apt-transport-https ca-certificates gnupg2 software-properties-common net-tools socat conntrack ipset <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># 3. \u5173\u95edswap<\/span><br \/>\nswapoff -a<br \/>\n<span class=\"token function\">sed<\/span> -i <span class=\"token string\">&#039;\/swap\/s\/^\/#\/&#039;<\/span> \/etc\/fstab<\/p>\n<p><span class=\"token comment\"># 4. \u52a0\u8f7d\u5185\u6838\u6a21\u5757<\/span><br \/>\n<span class=\"token function\">cat<\/span> <span class=\"token operator\">&lt;&lt;<\/span><span class=\"token string\">EOF<span class=\"token bash punctuation\"> <span class=\"token operator\">|<\/span> <span class=\"token function\">tee<\/span> \/etc\/modules-load.d\/containerd.conf<\/span><br \/>\noverlay<br \/>\nbr_netfilter<br \/>\nEOF<\/span><br \/>\nmodprobe overlay <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><br \/>\nmodprobe br_netfilter <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># 5. \u8bbe\u7f6esysctl\u53c2\u6570<\/span><br \/>\n<span class=\"token function\">cat<\/span> <span class=\"token operator\">&lt;&lt;<\/span><span class=\"token string\">EOF<span class=\"token bash punctuation\"> <span class=\"token operator\">|<\/span> <span class=\"token function\">tee<\/span> \/etc\/sysctl.d\/99-kubernetes-cri.conf<\/span><br \/>\nnet.bridge.bridge-nf-call-iptables  &#061; 1<br \/>\nnet.ipv4.ip_forward                 &#061; 1<br \/>\nnet.bridge.bridge-nf-call-ip6tables &#061; 1<br \/>\nnet.ipv4.tcp_tw_recycle &#061; 0<br \/>\nvm.swappiness&#061;0<br \/>\nEOF<\/span><br \/>\nsysctl &#8211;system <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># 6. \u90e8\u7f72containerd<\/span><br \/>\n<span class=\"token comment\"># \u4e0b\u8f7dcontainerd<\/span><br \/>\n<span class=\"token function\">curl<\/span> -L &#8211;proxy <span class=\"token variable\">${PROXY_ADDR}<\/span> &#8211;insecure -s https:\/\/github.com\/containerd\/containerd\/releases\/download\/v1.7.30\/containerd-1.7.30-linux-<span class=\"token variable\">${ARCH}<\/span>.tar.gz -o \/tmp\/containerd.tar.gz<br \/>\n<span class=\"token function\">tar<\/span> Cxzvf \/usr\/local \/tmp\/containerd.tar.gz <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># \u4e0b\u8f7drunc<\/span><br \/>\n<span class=\"token function\">curl<\/span> -L &#8211;proxy <span class=\"token variable\">${PROXY_ADDR}<\/span> &#8211;insecure -s https:\/\/github.com\/opencontainers\/runc\/releases\/download\/v1.1.12\/runc.<span class=\"token variable\">${ARCH}<\/span> -o \/tmp\/runc<br \/>\n<span class=\"token function\">install<\/span> -m <span class=\"token number\">755<\/span> \/tmp\/runc \/usr\/local\/sbin\/runc <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># \u4e0b\u8f7dCNI\u63d2\u4ef6<\/span><br \/>\n<span class=\"token assign-left variable\">CNI_VERSION<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;1.4.0&#034;<\/span><br \/>\n<span class=\"token function\">curl<\/span> -L &#8211;proxy <span class=\"token variable\">${PROXY_ADDR}<\/span> &#8211;insecure -s https:\/\/github.com\/containernetworking\/plugins\/releases\/download\/v<span class=\"token variable\">${CNI_VERSION}<\/span>\/cni-plugins-linux-<span class=\"token variable\">${ARCH}<\/span>-v<span class=\"token variable\">${CNI_VERSION}<\/span>.tgz -o \/tmp\/cni-plugins.tgz<br \/>\n<span class=\"token function\">mkdir<\/span> -p \/opt\/cni\/bin<br \/>\n<span class=\"token function\">tar<\/span> Cxzvf \/opt\/cni\/bin \/tmp\/cni-plugins.tgz <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># \u914d\u7f6econtainerd<\/span><br \/>\n<span class=\"token function\">mkdir<\/span> -p \/etc\/containerd<br \/>\ncontainerd config default <span class=\"token operator\">&gt;<\/span> \/etc\/containerd\/config.toml <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><br \/>\n<span class=\"token function\">sed<\/span> -i <span class=\"token string\">&#039;s\/SystemdCgroup \\\\&#061; false\/SystemdCgroup \\\\&#061; true\/&#039;<\/span> \/etc\/containerd\/config.toml<br \/>\n<span class=\"token function\">sed<\/span> -i <span class=\"token string\">&#039;s\/config_path &#061; &#034;&#034;\/config_path &#061; &#034;\\\\\/etc\\\\\/containerd\\\\\/certs.d&#034;\/&#039;<\/span> \/etc\/containerd\/config.toml<br \/>\n<span class=\"token function\">sed<\/span> -i <span class=\"token string\">&#039;s\/^\\\\(\\\\s*\\\\)tls_verify &#061; true\/\\\\1tls_verify &#061; false\/&#039;<\/span> \/etc\/containerd\/config.toml<\/p>\n<p><span class=\"token comment\"># \u914d\u7f6eHarbor\u955c\u50cf\u4ed3\u5e93<\/span><br \/>\n<span class=\"token function\">mkdir<\/span> -p \/etc\/containerd\/certs.d\/<span class=\"token variable\">${HARBOR_REGISTRY}<\/span><br \/>\n<span class=\"token function\">cat<\/span> <span class=\"token operator\">&gt;<\/span> \/etc\/containerd\/certs.d\/<span class=\"token variable\">${HARBOR_REGISTRY}<\/span>\/hosts.toml <span class=\"token operator\">&lt;&lt;<\/span> <span class=\"token string\">EOF<br \/>\nserver &#061; &#034;<span class=\"token variable\">${HARBOR_FULL_ADDR}<\/span>&#034;<br \/>\n[host.&#034;<span class=\"token variable\">${HARBOR_FULL_ADDR}<\/span>&#034;]<br \/>\n  capabilities &#061; [&#034;pull&#034;, &#034;resolve&#034;, &#034;push&#034;]<br \/>\n  skip_verify &#061; true<br \/>\n  allow_insecure &#061; true<br \/>\n  [host.&#034;<span class=\"token variable\">${HARBOR_FULL_ADDR}<\/span>&#034;.auth]<br \/>\n    username &#061; &#034;<span class=\"token variable\">${HARBOR_USER}<\/span>&#034;<br \/>\n    password &#061; &#034;<span class=\"token variable\">${HARBOR_PASS}<\/span>&#034;<br \/>\nEOF<\/span><\/p>\n<p><span class=\"token comment\"># \u914d\u7f6econtainerd\u670d\u52a1<\/span><br \/>\n<span class=\"token function\">cat<\/span> <span class=\"token operator\">&lt;&lt;<\/span><span class=\"token string\">EOF<span class=\"token bash punctuation\"> <span class=\"token operator\">|<\/span> <span class=\"token function\">tee<\/span> \/etc\/systemd\/system\/containerd.service<\/span><br \/>\n[Unit]<br \/>\nDescription&#061;containerd container runtime<br \/>\nAfter&#061;network.target local-fs.target<br \/>\n[Service]<br \/>\nExecStartPre&#061;-\/sbin\/modprobe overlay<br \/>\nExecStart&#061;\/usr\/local\/bin\/containerd<br \/>\nType&#061;notify<br \/>\nRestart&#061;always<br \/>\nRestartSec&#061;5<br \/>\nLimitNOFILE&#061;infinity<br \/>\n[Install]<br \/>\nWantedBy&#061;multi-user.target<br \/>\nEOF<\/span><\/p>\n<p><span class=\"token comment\"># \u542f\u52a8containerd<\/span><br \/>\nsystemctl daemon-reload<br \/>\nsystemctl <span class=\"token builtin class-name\">enable<\/span> &#8211;now containerd <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># 7. \u5b89\u88c5crictl<\/span><br \/>\n<span class=\"token assign-left variable\">CRICTL_VERSION<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;v1.30.0&#034;<\/span><br \/>\n<span class=\"token function\">curl<\/span> -L &#8211;proxy <span class=\"token variable\">${PROXY_ADDR}<\/span> &#8211;insecure -s https:\/\/github.com\/kubernetes-sigs\/cri-tools\/releases\/download\/<span class=\"token variable\">${CRICTL_VERSION}<\/span>\/crictl-<span class=\"token variable\">${CRICTL_VERSION}<\/span>-linux-amd64.tar.gz <span class=\"token operator\">|<\/span> <span class=\"token function\">tar<\/span> zxvf &#8211; -C \/usr\/local\/bin <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><br \/>\n<span class=\"token function\">cat<\/span> <span class=\"token operator\">&gt;<\/span> \/etc\/crictl.yaml <span class=\"token operator\">&lt;&lt;<\/span> <span class=\"token string\">EOF<br \/>\nruntime-endpoint: unix:\/\/\/run\/containerd\/containerd.sock<br \/>\ntimeout: 10<br \/>\ndebug: false<br \/>\nEOF<\/span><\/p>\n<p><span class=\"token comment\"># 8. \u914d\u7f6epause\u955c\u50cf<\/span><br \/>\ncrictl pull <span class=\"token variable\">${TARGET_REGISTRY}<\/span>\/pause:<span class=\"token variable\">${PAUSE_TARGET_VERSION}<\/span> <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><br \/>\nctr -n k8s.io images tag <span class=\"token variable\">${TARGET_REGISTRY}<\/span>\/pause:<span class=\"token variable\">${PAUSE_TARGET_VERSION}<\/span> <span class=\"token variable\">${SOURCE_REGISTRY}<\/span>\/pause:<span class=\"token variable\">${PAUSE_VERSION}<\/span> <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># 9. \u5b89\u88c5K8s\u7ec4\u4ef6<\/span><br \/>\n<span class=\"token function\">mkdir<\/span> -p <span class=\"token variable\">${DOWNLOAD_DIR}<\/span> <span class=\"token operator\">&amp;&amp;<\/span> <span class=\"token builtin class-name\">cd<\/span> <span class=\"token variable\">${DOWNLOAD_DIR}<\/span><br \/>\n<span class=\"token keyword\">for<\/span> <span class=\"token for-or-select variable\">bin<\/span> <span class=\"token keyword\">in<\/span> kubeadm kubelet kubectl<span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">do<\/span><br \/>\n  <span class=\"token function\">curl<\/span> -L &#8211;proxy <span class=\"token variable\">${PROXY_ADDR}<\/span> &#8211;insecure -s https:\/\/dl.k8s.io\/v<span class=\"token variable\">${K8S_VERSION}<\/span>\/bin\/linux\/<span class=\"token variable\">${ARCH}<\/span>\/<span class=\"token variable\">${bin}<\/span> -o <span class=\"token variable\">${bin}<\/span><br \/>\n  <span class=\"token function\">chmod<\/span> &#043;x <span class=\"token variable\">${bin}<\/span> <span class=\"token operator\">&amp;&amp;<\/span> <span class=\"token function\">mv<\/span> <span class=\"token variable\">${bin}<\/span> \/usr\/bin\/ <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><br \/>\n<span class=\"token keyword\">done<\/span><\/p>\n<p><span class=\"token comment\"># 10. \u914d\u7f6ekubelet<\/span><br \/>\n<span class=\"token function\">cat<\/span> <span class=\"token operator\">&lt;&lt;<\/span><span class=\"token string\">EOF<span class=\"token bash punctuation\"> <span class=\"token operator\">|<\/span> <span class=\"token function\">tee<\/span> \/etc\/systemd\/system\/kubelet.service<\/span><br \/>\n[Unit]<br \/>\nDescription&#061;kubelet: The Kubernetes Node Agent<br \/>\nAfter&#061;network-online.target<br \/>\n[Service]<br \/>\nExecStart&#061;\/usr\/bin\/kubelet<br \/>\nRestart&#061;always<br \/>\nRestartSec&#061;10<br \/>\nLimitNOFILE&#061;infinity<br \/>\n[Install]<br \/>\nWantedBy&#061;multi-user.target<br \/>\nEOF<\/span><\/p>\n<p><span class=\"token function\">mkdir<\/span> -p \/etc\/systemd\/system\/kubelet.service.d<br \/>\n<span class=\"token function\">cat<\/span> <span class=\"token operator\">&lt;&lt;<\/span><span class=\"token string\">EOF<span class=\"token bash punctuation\"> <span class=\"token operator\">|<\/span> <span class=\"token function\">tee<\/span> \/etc\/systemd\/system\/kubelet.service.d\/10-kubeadm.conf<\/span><br \/>\n[Service]<br \/>\nEnvironment&#061;&#034;KUBELET_KUBECONFIG_ARGS&#061;&#8211;bootstrap-kubeconfig&#061;\/etc\/kubernetes\/bootstrap-kubelet.conf &#8211;kubeconfig&#061;\/etc\/kubernetes\/kubelet.conf&#034;<br \/>\nEnvironment&#061;&#034;KUBELET_CONFIG_ARGS&#061;&#8211;config&#061;\/var\/lib\/kubelet\/config.yaml&#034;<br \/>\nEnvironmentFile&#061;-\/var\/lib\/kubelet\/kubeadm-flags.env<br \/>\nExecStart&#061;<br \/>\nExecStart&#061;\/usr\/bin\/kubelet \\\\<span class=\"token variable\">$KUBELET_KUBECONFIG_ARGS<\/span> \\\\<span class=\"token variable\">$KUBELET_CONFIG_ARGS<\/span> \\\\<span class=\"token variable\">$KUBELET_KUBEADM_ARGS<\/span> &#8211;container-runtime-endpoint&#061;unix:\/\/\/run\/containerd\/containerd.sock &#8211;node-ip&#061;<span class=\"token variable\">${NODE_IP}<\/span><br \/>\nEOF<\/span><\/p>\n<p><span class=\"token function\">cat<\/span> <span class=\"token operator\">&lt;&lt;<\/span><span class=\"token string\">EOF<span class=\"token bash punctuation\"> <span class=\"token operator\">|<\/span> <span class=\"token function\">tee<\/span> \/etc\/default\/kubelet<\/span><br \/>\nKUBELET_EXTRA_ARGS&#061;&#034;&#8211;pod-infra-container-image&#061;<span class=\"token variable\">${TARGET_REGISTRY}<\/span>\/pause:<span class=\"token variable\">${PAUSE_TARGET_VERSION}<\/span> &#8211;node-ip&#061;<span class=\"token variable\">${NODE_IP}<\/span>&#034;<br \/>\nEOF<\/span><\/p>\n<p>systemctl daemon-reload<br \/>\nsystemctl <span class=\"token builtin class-name\">enable<\/span> kubelet <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># \u6e05\u7406\u4e34\u65f6\u6587\u4ef6<\/span><br \/>\n<span class=\"token function\">rm<\/span> -rf <span class=\"token variable\">${DOWNLOAD_DIR}<\/span> \/tmp\/containerd.tar.gz \/tmp\/runc \/tmp\/cni-plugins.tgz <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[32m\u8282\u70b9<span class=\"token variable\">${NODE_IP}<\/span>\u521d\u59cb\u5316\u5b8c\u6210<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><\/p>\n<hr \/>\n<h4>4. 04-init-first-master.sh&#xff08;\u521d\u59cb\u5316\u7b2c\u4e00\u4e2aMaster\u8282\u70b9111&#xff09;<\/h4>\n<p><span class=\"token shebang important\">#!\/bin\/bash<\/span><br \/>\n<span class=\"token builtin class-name\">set<\/span> -euo pipefail<\/p>\n<p><span class=\"token comment\"># \u6838\u5fc3\u914d\u7f6e<\/span><br \/>\n<span class=\"token assign-left variable\">HAPROXY_IP<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;192.168.56.102&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">HAPROXY_PORT<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token number\">6443<\/span><br \/>\n<span class=\"token assign-left variable\">K8S_VERSION<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;1.33.6&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">HARBOR_REGISTRY<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;192.168.56.102&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">TARGET_REGISTRY<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;<span class=\"token variable\">${HARBOR_REGISTRY}<\/span>\/library&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">POD_SUBNET<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;192.156.32.0\/20&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">SVC_SUBNET<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;192.156.48.0\/24&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">CALICO_VERSION<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;v3.29.0&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">PROXY_ADDR<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;http:\/\/192.168.56.102:8080&#034;<\/span><\/p>\n<p><span class=\"token comment\"># \u83b7\u53d6\u5f53\u524d\u8282\u70b9enp0s8\u7684IP<\/span><br \/>\n<span class=\"token assign-left variable\">NODE_IP<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token variable\"><span class=\"token variable\">$(<\/span><span class=\"token function\">ip<\/span> addr show enp0s8 <span class=\"token operator\">|<\/span> <span class=\"token function\">grep<\/span> -oP <span class=\"token string\">&#039;(?&lt;&#061;inet\\\\s)\\\\d&#043;(\\\\.\\\\d&#043;){3}&#039;<\/span> <span class=\"token operator\">|<\/span> <span class=\"token function\">head<\/span> -1<span class=\"token variable\">)<\/span><\/span><br \/>\n<span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">[<\/span> -z <span class=\"token string\">&#034;<span class=\"token variable\">${NODE_IP}<\/span>&#034;<\/span> <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">then<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[31m\u672a\u627e\u5230enp0s8\u7f51\u5361\u7684IP&#xff0c;\u8bf7\u68c0\u67e5\u7f51\u5361\u540d\u79f0<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n    <span class=\"token builtin class-name\">exit<\/span> <span class=\"token number\">1<\/span><br \/>\n<span class=\"token keyword\">fi<\/span><\/p>\n<p><span class=\"token comment\"># \u751f\u6210kubeadm\u914d\u7f6e\u6587\u4ef6&#xff08;\u542betcd\u8bc1\u4e66\u914d\u7f6e\u3001\u6307\u5b9aenp0s8 IP&#xff09;<\/span><br \/>\n<span class=\"token function\">cat<\/span> <span class=\"token operator\">&gt;<\/span> \/root\/kubeadm-config.yaml <span class=\"token operator\">&lt;&lt;<\/span> <span class=\"token string\">EOF<br \/>\napiVersion: kubeadm.k8s.io\/v1beta3<br \/>\nkind: ClusterConfiguration<br \/>\nkubernetesVersion: v<span class=\"token variable\">${K8S_VERSION}<\/span><br \/>\nimageRepository: <span class=\"token variable\">${TARGET_REGISTRY}<\/span><br \/>\ncontrolPlaneEndpoint: &#034;<span class=\"token variable\">${HAPROXY_IP}<\/span>:<span class=\"token variable\">${HAPROXY_PORT}<\/span>&#034;<br \/>\nnetworking:<br \/>\n  podSubnet: <span class=\"token variable\">${POD_SUBNET}<\/span><br \/>\n  serviceSubnet: <span class=\"token variable\">${SVC_SUBNET}<\/span><br \/>\n  dnsDomain: cluster.local<br \/>\netcd:<br \/>\n  local:<br \/>\n    serverCertSANs:<br \/>\n      &#8211; &#034;<span class=\"token variable\">${NODE_IP}<\/span>&#034;<br \/>\n      &#8211; &#034;<span class=\"token variable\">${HAPROXY_IP}<\/span>&#034;<br \/>\n      &#8211; &#034;127.0.0.1&#034;<br \/>\n    peerCertSANs:<br \/>\n      &#8211; &#034;<span class=\"token variable\">${NODE_IP}<\/span>&#034;<br \/>\n      &#8211; &#034;127.0.0.1&#034;<br \/>\n    dataDir: \/var\/lib\/etcd<br \/>\n&#8212;<br \/>\napiVersion: kubelet.config.k8s.io\/v1beta1<br \/>\nkind: KubeletConfiguration<br \/>\npodSandboxImage: &#034;<span class=\"token variable\">${TARGET_REGISTRY}<\/span>\/pause:3.10&#034;<br \/>\nstaticPodPath: \/etc\/kubernetes\/manifests<br \/>\nclusterDomain: cluster.local<br \/>\nclusterDNS:<br \/>\n  &#8211; <span class=\"token variable\">${SVC_SUBNET<span class=\"token operator\">%<\/span>.*.*}<\/span>.10<br \/>\n&#8212;<br \/>\napiVersion: kubeadm.k8s.io\/v1beta3<br \/>\nkind: InitConfiguration<br \/>\nlocalAPIEndpoint:<br \/>\n  advertiseAddress: <span class=\"token variable\">${NODE_IP}<\/span><br \/>\n  bindPort: 6443<br \/>\nnodeRegistration:<br \/>\n  criSocket: unix:\/\/\/run\/containerd\/containerd.sock<br \/>\n  kubeletExtraArgs:<br \/>\n    node-ip: <span class=\"token variable\">${NODE_IP}<\/span><br \/>\nEOF<\/span><\/p>\n<p><span class=\"token comment\"># \u521d\u59cb\u5316\u96c6\u7fa4&#xff08;\u751f\u6210etcd\u8bc1\u4e66&#xff09;<\/span><br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;\u5f00\u59cb\u521d\u59cb\u5316\u7b2c\u4e00\u4e2aMaster\u8282\u70b9(<span class=\"token variable\">${NODE_IP}<\/span>)&#8230;&#034;<\/span><br \/>\nkubeadm init &#8211;config \/root\/kubeadm-config.yaml &#8211;ignore-preflight-errors all &#8211;upload-certs -v<span class=\"token operator\">&#061;<\/span><span class=\"token number\">5<\/span><\/p>\n<p><span class=\"token comment\"># \u914d\u7f6ekubectl<\/span><br \/>\n<span class=\"token function\">mkdir<\/span> -p <span class=\"token environment constant\">$HOME<\/span>\/.kube<br \/>\n<span class=\"token function\">cp<\/span> -i \/etc\/kubernetes\/admin.conf <span class=\"token environment constant\">$HOME<\/span>\/.kube\/config<br \/>\n<span class=\"token function\">chown<\/span> <span class=\"token variable\"><span class=\"token variable\">$(<\/span><span class=\"token function\">id<\/span> -u<span class=\"token variable\">)<\/span><\/span><span class=\"token builtin class-name\">:<\/span><span class=\"token variable\"><span class=\"token variable\">$(<\/span><span class=\"token function\">id<\/span> -g<span class=\"token variable\">)<\/span><\/span> <span class=\"token environment constant\">$HOME<\/span>\/.kube\/config<\/p>\n<p><span class=\"token comment\"># \u90e8\u7f72Calico\u7f51\u7edc<\/span><br \/>\n<span class=\"token function\">curl<\/span> -L &#8211;proxy <span class=\"token variable\">${PROXY_ADDR}<\/span> &#8211;insecure -s https:\/\/raw.githubusercontent.com\/projectcalico\/calico\/<span class=\"token variable\">${CALICO_VERSION}<\/span>\/manifests\/calico.yaml -o \/tmp\/calico.yaml<br \/>\n<span class=\"token comment\"># \u4fee\u6539Calico\u7f51\u6bb5\u4e3a\u81ea\u5b9a\u4e49Pod\u7f51\u6bb5<\/span><br \/>\n<span class=\"token function\">sed<\/span> -i <span class=\"token string\">&#034;s|192.168.0.0\/16|<span class=\"token variable\">${POD_SUBNET}<\/span>|g&#034;<\/span> \/tmp\/calico.yaml<br \/>\n<span class=\"token comment\"># \u4fee\u6539\u955c\u50cf\u4ed3\u5e93<\/span><br \/>\n<span class=\"token function\">sed<\/span> -i <span class=\"token string\">&#034;s|docker.io\/calico|<span class=\"token variable\">${TARGET_REGISTRY}<\/span>\/calico|g&#034;<\/span> \/tmp\/calico.yaml<br \/>\nkubectl apply -f \/tmp\/calico.yaml<\/p>\n<p><span class=\"token comment\"># \u79fb\u9664master\u8282\u70b9\u7684taint&#xff08;\u53ef\u9009&#xff0c;\u8ba9master\u4e5f\u80fd\u8fd0\u884cpod&#xff09;<\/span><br \/>\nkubectl taint nodes &#8211;all node-role.kubernetes.io\/control-plane- <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># \u4fdd\u5b58join\u547d\u4ee4&#xff08;\u7528\u4e8e\u5176\u4ed6master\/node\u8282\u70b9&#xff09;<\/span><br \/>\nkubeadm token create &#8211;print-join-command <span class=\"token operator\">&gt;<\/span> \/root\/k8s-join-command.sh<br \/>\n<span class=\"token function\">chmod<\/span> &#043;x \/root\/k8s-join-command.sh<\/p>\n<p><span class=\"token comment\"># \u4fdd\u5b58certificate-key&#xff08;\u7528\u4e8emaster\u8282\u70b9\u52a0\u5165&#xff09;<\/span><br \/>\n<span class=\"token assign-left variable\">CERT_KEY<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token variable\"><span class=\"token variable\">$(<\/span>kubeadm init phase upload-certs &#8211;upload-certs <span class=\"token operator\">|<\/span> <span class=\"token function\">tail<\/span> -1<span class=\"token variable\">)<\/span><\/span><br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;export CERT_KEY&#061;<span class=\"token variable\">${CERT_KEY}<\/span>&#034;<\/span> <span class=\"token operator\">&gt;<\/span> \/root\/k8s-cert-key.sh<br \/>\n<span class=\"token function\">chmod<\/span> &#043;x \/root\/k8s-cert-key.sh<\/p>\n<p><span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[32m\u7b2c\u4e00\u4e2aMaster\u8282\u70b9(<span class=\"token variable\">${NODE_IP}<\/span>)\u521d\u59cb\u5316\u5b8c\u6210&#xff01;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;join\u547d\u4ee4\u5df2\u4fdd\u5b58\u81f3: \/root\/k8s-join-command.sh&#034;<\/span><br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;certificate-key\u5df2\u4fdd\u5b58\u81f3: \/root\/k8s-cert-key.sh&#034;<\/span><\/p>\n<hr \/>\n<h4>5. 05-join-master-nodes.sh&#xff08;112\/113\u52a0\u5165\u96c6\u7fa4&#xff0c;\u4fee\u590d\u4f9d\u8d56&#043;\u81ea\u52a8\u62f7\u8d1d\u6587\u4ef6&#xff09;<\/h4>\n<p><span class=\"token shebang important\">#!\/bin\/bash<\/span><br \/>\n<span class=\"token builtin class-name\">set<\/span> -euo pipefail<\/p>\n<p><span class=\"token comment\"># \u6838\u5fc3\u914d\u7f6e<\/span><br \/>\n<span class=\"token assign-left variable\">HAPROXY_IP<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;192.168.56.102&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">HAPROXY_PORT<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token number\">6443<\/span><br \/>\n<span class=\"token assign-left variable\">K8S_VERSION<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;1.33.6&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">HARBOR_REGISTRY<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;192.168.56.102&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">TARGET_REGISTRY<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;<span class=\"token variable\">${HARBOR_REGISTRY}<\/span>\/library&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">FIRST_MASTER_IP<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;192.168.56.111&#034;<\/span>  <span class=\"token comment\"># \u7b2c\u4e00\u4e2amaster\u8282\u70b9IP<\/span><br \/>\n<span class=\"token assign-left variable\">FIRST_MASTER_USER<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;root&#034;<\/span>          <span class=\"token comment\"># \u7b2c\u4e00\u4e2amaster\u8282\u70b9\u767b\u5f55\u7528\u6237<\/span><\/p>\n<p><span class=\"token comment\"># \u83b7\u53d6\u5f53\u524d\u8282\u70b9enp0s8\u7684IP<\/span><br \/>\n<span class=\"token assign-left variable\">NODE_IP<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token variable\"><span class=\"token variable\">$(<\/span><span class=\"token function\">ip<\/span> addr show enp0s8 <span class=\"token operator\">|<\/span> <span class=\"token function\">grep<\/span> -oP <span class=\"token string\">&#039;(?&lt;&#061;inet\\\\s)\\\\d&#043;(\\\\.\\\\d&#043;){3}&#039;<\/span> <span class=\"token operator\">|<\/span> <span class=\"token function\">head<\/span> -1<span class=\"token variable\">)<\/span><\/span><br \/>\n<span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">[<\/span> -z <span class=\"token string\">&#034;<span class=\"token variable\">${NODE_IP}<\/span>&#034;<\/span> <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">then<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[31m\u672a\u627e\u5230enp0s8\u7f51\u5361\u7684IP&#xff0c;\u8bf7\u68c0\u67e5\u7f51\u5361\u540d\u79f0<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n    <span class=\"token builtin class-name\">exit<\/span> <span class=\"token number\">1<\/span><br \/>\n<span class=\"token keyword\">fi<\/span><br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;\u5f53\u524d\u8282\u70b9enp0s8 IP: <span class=\"token variable\">${NODE_IP}<\/span>&#034;<\/span><\/p>\n<p><span class=\"token comment\"># \u65b0\u589e&#xff1a;\u81ea\u52a8\u4ece\u7b2c\u4e00\u4e2amaster\u8282\u70b9\u62f7\u8d1d\u5173\u952e\u6587\u4ef6<\/span><br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;\u5f00\u59cb\u4ece<span class=\"token variable\">${FIRST_MASTER_IP}<\/span>\u62f7\u8d1dk8s-join-command.sh\u548ck8s-cert-key.sh&#8230;&#034;<\/span><br \/>\n<span class=\"token comment\"># \u5c1d\u8bd5\u514d\u5bc6\u62f7\u8d1d&#xff0c;\u82e5\u5931\u8d25\u5219\u63d0\u793a\u8f93\u5165\u5bc6\u7801<\/span><br \/>\n<span class=\"token keyword\">if<\/span> <span class=\"token operator\">!<\/span> <span class=\"token function\">scp<\/span> -o <span class=\"token assign-left variable\">StrictHostKeyChecking<\/span><span class=\"token operator\">&#061;<\/span>no <span class=\"token variable\">${FIRST_MASTER_USER}<\/span>&#064;<span class=\"token variable\">${FIRST_MASTER_IP}<\/span>:\/root\/k8s-join-command.sh \/root\/<span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">then<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[33m\u514d\u5bc6\u62f7\u8d1d\u5931\u8d25&#xff0c;\u8bf7\u8f93\u5165<span class=\"token variable\">${FIRST_MASTER_IP}<\/span>\u7684<span class=\"token variable\">${FIRST_MASTER_USER}<\/span>\u5bc6\u7801&#xff1a;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n    <span class=\"token function\">scp<\/span> <span class=\"token variable\">${FIRST_MASTER_USER}<\/span>&#064;<span class=\"token variable\">${FIRST_MASTER_IP}<\/span>:\/root\/k8s-join-command.sh \/root\/ <span class=\"token operator\">||<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[31m\u62f7\u8d1dk8s-join-command.sh\u5931\u8d25&#xff0c;\u8bf7\u624b\u52a8\u62f7\u8d1d\u540e\u91cd\u8bd5&#xff01;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n        <span class=\"token builtin class-name\">exit<\/span> <span class=\"token number\">1<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token keyword\">fi<\/span><\/p>\n<p><span class=\"token keyword\">if<\/span> <span class=\"token operator\">!<\/span> <span class=\"token function\">scp<\/span> -o <span class=\"token assign-left variable\">StrictHostKeyChecking<\/span><span class=\"token operator\">&#061;<\/span>no <span class=\"token variable\">${FIRST_MASTER_USER}<\/span>&#064;<span class=\"token variable\">${FIRST_MASTER_IP}<\/span>:\/root\/k8s-cert-key.sh \/root\/<span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">then<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[33m\u514d\u5bc6\u62f7\u8d1d\u5931\u8d25&#xff0c;\u8bf7\u8f93\u5165<span class=\"token variable\">${FIRST_MASTER_IP}<\/span>\u7684<span class=\"token variable\">${FIRST_MASTER_USER}<\/span>\u5bc6\u7801&#xff1a;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n    <span class=\"token function\">scp<\/span> <span class=\"token variable\">${FIRST_MASTER_USER}<\/span>&#064;<span class=\"token variable\">${FIRST_MASTER_IP}<\/span>:\/root\/k8s-cert-key.sh \/root\/ <span class=\"token operator\">||<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[31m\u62f7\u8d1dk8s-cert-key.sh\u5931\u8d25&#xff0c;\u8bf7\u624b\u52a8\u62f7\u8d1d\u540e\u91cd\u8bd5&#xff01;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n        <span class=\"token builtin class-name\">exit<\/span> <span class=\"token number\">1<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token keyword\">fi<\/span><\/p>\n<p><span class=\"token comment\"># \u68c0\u67e5\u6587\u4ef6\u662f\u5426\u5b58\u5728<\/span><br \/>\n<span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">[<\/span> <span class=\"token operator\">!<\/span> -f \/root\/k8s-join-command.sh <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">then<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[31m\u672a\u627e\u5230k8s-join-command.sh\u6587\u4ef6&#xff01;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n    <span class=\"token builtin class-name\">exit<\/span> <span class=\"token number\">1<\/span><br \/>\n<span class=\"token keyword\">fi<\/span><br \/>\n<span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">[<\/span> <span class=\"token operator\">!<\/span> -f \/root\/k8s-cert-key.sh <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">then<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[31m\u672a\u627e\u5230k8s-cert-key.sh\u6587\u4ef6&#xff01;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n    <span class=\"token builtin class-name\">exit<\/span> <span class=\"token number\">1<\/span><br \/>\n<span class=\"token keyword\">fi<\/span><\/p>\n<p><span class=\"token comment\"># \u52a0\u8f7dcertificate-key<\/span><br \/>\n<span class=\"token builtin class-name\">source<\/span> \/root\/k8s-cert-key.sh<br \/>\n<span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">[<\/span> -z <span class=\"token string\">&#034;<span class=\"token variable\">${CERT_KEY}<\/span>&#034;<\/span> <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">then<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[31m\u672a\u63d0\u53d6\u5230CERT_KEY&#xff0c;\u8bf7\u68c0\u67e5k8s-cert-key.sh\u6587\u4ef6\u5185\u5bb9&#xff01;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n    <span class=\"token function\">cat<\/span> \/root\/k8s-cert-key.sh<br \/>\n    <span class=\"token builtin class-name\">exit<\/span> <span class=\"token number\">1<\/span><br \/>\n<span class=\"token keyword\">fi<\/span><\/p>\n<p><span class=\"token comment\"># \u4ecejoin\u547d\u4ee4\u6587\u4ef6\u63d0\u53d6token\u548ccaCertHash&#xff08;\u4fee\u590d\u4f9d\u8d56\u89e3\u6790&#xff09;<\/span><br \/>\n<span class=\"token assign-left variable\">JOIN_CMD<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token variable\"><span class=\"token variable\">$(<\/span><span class=\"token function\">cat<\/span> \/root\/k8s-join-command.sh<span class=\"token variable\">)<\/span><\/span><br \/>\n<span class=\"token assign-left variable\">TOKEN<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token variable\"><span class=\"token variable\">$(<\/span><span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;<span class=\"token variable\">${JOIN_CMD}<\/span>&#034;<\/span> <span class=\"token operator\">|<\/span> <span class=\"token function\">grep<\/span> -oP <span class=\"token string\">&#039;token \\\\K\\\\S&#043;&#039;<\/span><span class=\"token variable\">)<\/span><\/span><br \/>\n<span class=\"token assign-left variable\">CA_CERT_HASH<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token variable\"><span class=\"token variable\">$(<\/span><span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;<span class=\"token variable\">${JOIN_CMD}<\/span>&#034;<\/span> <span class=\"token operator\">|<\/span> <span class=\"token function\">grep<\/span> -oP <span class=\"token string\">&#039;discovery-token-ca-cert-hash \\\\K\\\\S&#043;&#039;<\/span><span class=\"token variable\">)<\/span><\/span><br \/>\n<span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">[<\/span> -z <span class=\"token string\">&#034;<span class=\"token variable\">${TOKEN}<\/span>&#034;<\/span> <span class=\"token punctuation\">]<\/span> <span class=\"token operator\">||<\/span> <span class=\"token punctuation\">[<\/span> -z <span class=\"token string\">&#034;<span class=\"token variable\">${CA_CERT_HASH}<\/span>&#034;<\/span> <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">then<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[31m\u65e0\u6cd5\u4ecejoin\u547d\u4ee4\u4e2d\u63d0\u53d6token\u6216caCertHash&#xff01;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;join\u547d\u4ee4\u5185\u5bb9&#xff1a;<span class=\"token variable\">${JOIN_CMD}<\/span>&#034;<\/span><br \/>\n    <span class=\"token builtin class-name\">exit<\/span> <span class=\"token number\">1<\/span><br \/>\n<span class=\"token keyword\">fi<\/span><\/p>\n<p><span class=\"token comment\"># \u751f\u6210kubeadm join\u914d\u7f6e\u6587\u4ef6<\/span><br \/>\n<span class=\"token function\">cat<\/span> <span class=\"token operator\">&gt;<\/span> \/root\/kubeadm-join-master.yaml <span class=\"token operator\">&lt;&lt;<\/span> <span class=\"token string\">EOF<br \/>\napiVersion: kubeadm.k8s.io\/v1beta3<br \/>\nkind: JoinConfiguration<br \/>\ndiscovery:<br \/>\n  bootstrapToken:<br \/>\n    apiServerEndpoint: &#034;<span class=\"token variable\">${HAPROXY_IP}<\/span>:<span class=\"token variable\">${HAPROXY_PORT}<\/span>&#034;<br \/>\n    token: &#034;<span class=\"token variable\">${TOKEN}<\/span>&#034;<br \/>\n    caCertHashes:<br \/>\n      &#8211; &#034;<span class=\"token variable\">${CA_CERT_HASH}<\/span>&#034;<br \/>\n  timeout: 5m0s<br \/>\nnodeRegistration:<br \/>\n  criSocket: unix:\/\/\/run\/containerd\/containerd.sock<br \/>\n  kubeletExtraArgs:<br \/>\n    node-ip: <span class=\"token variable\">${NODE_IP}<\/span><br \/>\ncontrolPlane:<br \/>\n  certificateKey: &#034;<span class=\"token variable\">${CERT_KEY}<\/span>&#034;<br \/>\n  localAPIEndpoint:<br \/>\n    advertiseAddress: <span class=\"token variable\">${NODE_IP}<\/span><br \/>\n    bindPort: 6443<br \/>\nEOF<\/span><\/p>\n<p><span class=\"token comment\"># \u52a0\u5165\u96c6\u7fa4<\/span><br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;\u5f00\u59cb\u5c06\u8282\u70b9<span class=\"token variable\">${NODE_IP}<\/span>\u52a0\u5165\u96c6\u7fa4&#xff08;Master\u89d2\u8272&#xff09;&#8230;&#034;<\/span><br \/>\nkubeadm <span class=\"token function\">join<\/span> &#8211;config \/root\/kubeadm-join-master.yaml &#8211;ignore-preflight-errors all -v<span class=\"token operator\">&#061;<\/span><span class=\"token number\">5<\/span><\/p>\n<p><span class=\"token comment\"># \u914d\u7f6ekubectl&#xff08;\u53ef\u9009&#xff09;<\/span><br \/>\n<span class=\"token function\">mkdir<\/span> -p <span class=\"token environment constant\">$HOME<\/span>\/.kube<br \/>\n<span class=\"token function\">cp<\/span> -i \/etc\/kubernetes\/admin.conf <span class=\"token environment constant\">$HOME<\/span>\/.kube\/config <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><br \/>\n<span class=\"token function\">chown<\/span> <span class=\"token variable\"><span class=\"token variable\">$(<\/span><span class=\"token function\">id<\/span> -u<span class=\"token variable\">)<\/span><\/span><span class=\"token builtin class-name\">:<\/span><span class=\"token variable\"><span class=\"token variable\">$(<\/span><span class=\"token function\">id<\/span> -g<span class=\"token variable\">)<\/span><\/span> <span class=\"token environment constant\">$HOME<\/span>\/.kube\/config <span class=\"token operator\">||<\/span> <span class=\"token boolean\">true<\/span><\/p>\n<p><span class=\"token comment\"># \u6e05\u7406\u4e34\u65f6\u6587\u4ef6<\/span><br \/>\n<span class=\"token function\">rm<\/span> -f \/root\/kubeadm-join-master.yaml<\/p>\n<p><span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[32mMaster\u8282\u70b9<span class=\"token variable\">${NODE_IP}<\/span>\u52a0\u5165\u96c6\u7fa4\u5b8c\u6210<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><\/p>\n<hr \/>\n<h4>6. 06-join-node-nodes.sh&#xff08;114\/115\u52a0\u5165\u96c6\u7fa4&#xff0c;\u4fee\u590d&#043;\u81ea\u52a8\u62f7\u8d1d\u6587\u4ef6&#xff09;<\/h4>\n<p><span class=\"token shebang important\">#!\/bin\/bash<\/span><br \/>\n<span class=\"token builtin class-name\">set<\/span> -euo pipefail<\/p>\n<p><span class=\"token comment\"># \u6838\u5fc3\u914d\u7f6e<\/span><br \/>\n<span class=\"token assign-left variable\">HAPROXY_IP<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;192.168.56.102&#034;<\/span><br \/>\n<span class=\"token assign-left variable\">HAPROXY_PORT<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token number\">6443<\/span><br \/>\n<span class=\"token assign-left variable\">FIRST_MASTER_IP<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;192.168.56.111&#034;<\/span>  <span class=\"token comment\"># \u7b2c\u4e00\u4e2amaster\u8282\u70b9IP<\/span><br \/>\n<span class=\"token assign-left variable\">FIRST_MASTER_USER<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;root&#034;<\/span>          <span class=\"token comment\"># \u7b2c\u4e00\u4e2amaster\u8282\u70b9\u767b\u5f55\u7528\u6237<\/span><\/p>\n<p><span class=\"token comment\"># 1. \u83b7\u53d6\u5f53\u524d\u8282\u70b9enp0s8\u7684IP&#xff08;\u9c81\u68d2\u6027\u68c0\u67e5&#xff09;<\/span><br \/>\n<span class=\"token assign-left variable\">NODE_IP<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token variable\"><span class=\"token variable\">$(<\/span><span class=\"token function\">ip<\/span> addr show enp0s8 <span class=\"token operator\">|<\/span> <span class=\"token function\">grep<\/span> -oP <span class=\"token string\">&#039;(?&lt;&#061;inet\\\\s)\\\\d&#043;(\\\\.\\\\d&#043;){3}&#039;<\/span> <span class=\"token operator\">|<\/span> <span class=\"token function\">head<\/span> -1<span class=\"token variable\">)<\/span><\/span><br \/>\n<span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">[<\/span> -z <span class=\"token string\">&#034;<span class=\"token variable\">${NODE_IP}<\/span>&#034;<\/span> <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">then<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[31m\u9519\u8bef&#xff1a;\u672a\u627e\u5230enp0s8\u7f51\u5361\u7684IP&#xff0c;\u8bf7\u68c0\u67e5\u7f51\u5361\u540d\u79f0&#xff01;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n    <span class=\"token builtin class-name\">exit<\/span> <span class=\"token number\">1<\/span><br \/>\n<span class=\"token keyword\">fi<\/span><br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;\u5f53\u524d\u8282\u70b9enp0s8 IP: <span class=\"token variable\">${NODE_IP}<\/span>&#034;<\/span><\/p>\n<p><span class=\"token comment\"># \u65b0\u589e&#xff1a;\u81ea\u52a8\u4ece\u7b2c\u4e00\u4e2amaster\u8282\u70b9\u62f7\u8d1djoin\u547d\u4ee4\u6587\u4ef6<\/span><br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;\u5f00\u59cb\u4ece<span class=\"token variable\">${FIRST_MASTER_IP}<\/span>\u62f7\u8d1dk8s-join-command.sh&#8230;&#034;<\/span><br \/>\n<span class=\"token comment\"># \u5c1d\u8bd5\u514d\u5bc6\u62f7\u8d1d&#xff0c;\u82e5\u5931\u8d25\u5219\u63d0\u793a\u8f93\u5165\u5bc6\u7801<\/span><br \/>\n<span class=\"token keyword\">if<\/span> <span class=\"token operator\">!<\/span> <span class=\"token function\">scp<\/span> -o <span class=\"token assign-left variable\">StrictHostKeyChecking<\/span><span class=\"token operator\">&#061;<\/span>no <span class=\"token variable\">${FIRST_MASTER_USER}<\/span>&#064;<span class=\"token variable\">${FIRST_MASTER_IP}<\/span>:\/root\/k8s-join-command.sh \/root\/<span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">then<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[33m\u514d\u5bc6\u62f7\u8d1d\u5931\u8d25&#xff0c;\u8bf7\u8f93\u5165<span class=\"token variable\">${FIRST_MASTER_IP}<\/span>\u7684<span class=\"token variable\">${FIRST_MASTER_USER}<\/span>\u5bc6\u7801&#xff1a;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n    <span class=\"token function\">scp<\/span> <span class=\"token variable\">${FIRST_MASTER_USER}<\/span>&#064;<span class=\"token variable\">${FIRST_MASTER_IP}<\/span>:\/root\/k8s-join-command.sh \/root\/ <span class=\"token operator\">||<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[31m\u62f7\u8d1dk8s-join-command.sh\u5931\u8d25&#xff0c;\u8bf7\u624b\u52a8\u62f7\u8d1d\u540e\u91cd\u8bd5&#xff01;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n        <span class=\"token builtin class-name\">exit<\/span> <span class=\"token number\">1<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token keyword\">fi<\/span><\/p>\n<p><span class=\"token comment\"># 2. \u68c0\u67e5join\u547d\u4ee4\u6587\u4ef6\u662f\u5426\u5b58\u5728<\/span><br \/>\n<span class=\"token assign-left variable\">JOIN_CMD_FILE<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;\/root\/k8s-join-command.sh&#034;<\/span><br \/>\n<span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">[<\/span> <span class=\"token operator\">!<\/span> -f <span class=\"token string\">&#034;<span class=\"token variable\">${JOIN_CMD_FILE}<\/span>&#034;<\/span> <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">then<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[31m\u9519\u8bef&#xff1a;\u672a\u627e\u5230join\u547d\u4ee4\u6587\u4ef6&#xff01;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n    <span class=\"token builtin class-name\">exit<\/span> <span class=\"token number\">1<\/span><br \/>\n<span class=\"token keyword\">fi<\/span><\/p>\n<p><span class=\"token comment\"># 3. \u4ecejoin\u547d\u4ee4\u6587\u4ef6\u4e2d\u63d0\u53d6token\u548ccaCertHash&#xff08;\u4fee\u590d\u89e3\u6790\u903b\u8f91&#xff09;<\/span><br \/>\n<span class=\"token assign-left variable\">JOIN_CMD<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token variable\"><span class=\"token variable\">$(<\/span><span class=\"token function\">cat<\/span> <span class=\"token string\">&#034;<span class=\"token variable\">${JOIN_CMD_FILE}<\/span>&#034;<\/span><span class=\"token variable\">)<\/span><\/span><br \/>\n<span class=\"token assign-left variable\">TOKEN<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token variable\"><span class=\"token variable\">$(<\/span><span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;<span class=\"token variable\">${JOIN_CMD}<\/span>&#034;<\/span> <span class=\"token operator\">|<\/span> <span class=\"token function\">grep<\/span> -oP <span class=\"token string\">&#039;token \\\\K\\\\S&#043;&#039;<\/span><span class=\"token variable\">)<\/span><\/span><br \/>\n<span class=\"token assign-left variable\">CA_CERT_HASH<\/span><span class=\"token operator\">&#061;<\/span><span class=\"token variable\"><span class=\"token variable\">$(<\/span><span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;<span class=\"token variable\">${JOIN_CMD}<\/span>&#034;<\/span> <span class=\"token operator\">|<\/span> <span class=\"token function\">grep<\/span> -oP <span class=\"token string\">&#039;discovery-token-ca-cert-hash \\\\K\\\\S&#043;&#039;<\/span><span class=\"token variable\">)<\/span><\/span><\/p>\n<p><span class=\"token comment\"># 4. \u9a8c\u8bc1\u63d0\u53d6\u7ed3\u679c&#xff08;\u9c81\u68d2\u6027\u68c0\u67e5&#xff09;<\/span><br \/>\n<span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">[<\/span> -z <span class=\"token string\">&#034;<span class=\"token variable\">${TOKEN}<\/span>&#034;<\/span> <span class=\"token punctuation\">]<\/span> <span class=\"token operator\">||<\/span> <span class=\"token punctuation\">[<\/span> -z <span class=\"token string\">&#034;<span class=\"token variable\">${CA_CERT_HASH}<\/span>&#034;<\/span> <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token keyword\">then<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[31m\u9519\u8bef&#xff1a;\u65e0\u6cd5\u4ecejoin\u547d\u4ee4\u4e2d\u63d0\u53d6token\u6216caCertHash&#xff01;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><br \/>\n    <span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;\u5f53\u524djoin\u547d\u4ee4\u5185\u5bb9&#xff1a;<span class=\"token variable\">${JOIN_CMD}<\/span>&#034;<\/span><br \/>\n    <span class=\"token builtin class-name\">exit<\/span> <span class=\"token number\">1<\/span><br \/>\n<span class=\"token keyword\">fi<\/span><\/p>\n<p><span class=\"token comment\"># 5. \u751f\u6210kubeadm join\u914d\u7f6e\u6587\u4ef6&#xff08;\u6b63\u786e\u914d\u7f6enode-ip&#xff09;<\/span><br \/>\n<span class=\"token function\">cat<\/span> <span class=\"token operator\">&gt;<\/span> \/root\/kubeadm-join-node.yaml <span class=\"token operator\">&lt;&lt;<\/span> <span class=\"token string\">EOF<br \/>\napiVersion: kubeadm.k8s.io\/v1beta3<br \/>\nkind: JoinConfiguration<br \/>\ndiscovery:<br \/>\n  bootstrapToken:<br \/>\n    apiServerEndpoint: &#034;<span class=\"token variable\">${HAPROXY_IP}<\/span>:<span class=\"token variable\">${HAPROXY_PORT}<\/span>&#034;<br \/>\n    token: &#034;<span class=\"token variable\">${TOKEN}<\/span>&#034;<br \/>\n    caCertHashes:<br \/>\n      &#8211; &#034;<span class=\"token variable\">${CA_CERT_HASH}<\/span>&#034;<br \/>\n  timeout: 5m0s<br \/>\nnodeRegistration:<br \/>\n  criSocket: unix:\/\/\/run\/containerd\/containerd.sock<br \/>\n  # \u6838\u5fc3\u4fee\u590d&#xff1a;\u901a\u8fc7kubeletExtraArgs\u6307\u5b9anode-ip&#xff08;\u800c\u975e\u547d\u4ee4\u884c\u53c2\u6570&#xff09;<br \/>\n  kubeletExtraArgs:<br \/>\n    node-ip: <span class=\"token variable\">${NODE_IP}<\/span><br \/>\nEOF<\/span><\/p>\n<p><span class=\"token comment\"># 6. \u6267\u884cjoin\u547d\u4ee4&#xff08;\u4f7f\u7528\u914d\u7f6e\u6587\u4ef6&#xff0c;\u907f\u514d\u547d\u4ee4\u884c\u53c2\u6570\u9519\u8bef&#xff09;<\/span><br \/>\n<span class=\"token builtin class-name\">echo<\/span> <span class=\"token string\">&#034;\u5f00\u59cb\u5c06\u8282\u70b9<span class=\"token variable\">${NODE_IP}<\/span>\u52a0\u5165\u96c6\u7fa4&#xff08;Node\u89d2\u8272&#xff09;&#8230;&#034;<\/span><br \/>\nkubeadm <span class=\"token function\">join<\/span> &#8211;config \/root\/kubeadm-join-node.yaml &#8211;ignore-preflight-errors all -v<span class=\"token operator\">&#061;<\/span><span class=\"token number\">5<\/span><\/p>\n<p><span class=\"token comment\"># 7. \u6e05\u7406\u4e34\u65f6\u914d\u7f6e\u6587\u4ef6<\/span><br \/>\n<span class=\"token function\">rm<\/span> -f \/root\/kubeadm-join-node.yaml<\/p>\n<p><span class=\"token builtin class-name\">echo<\/span> -e <span class=\"token string\">&#034;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[32mNode\u8282\u70b9<span class=\"token variable\">${NODE_IP}<\/span>\u52a0\u5165\u96c6\u7fa4\u5b8c\u6210&#xff01;<span class=\"token entity\" title=\"\\\\033\">\\\\033<\/span>[0m&#034;<\/span><\/p>\n<hr \/>\n<h3>\u4e09\u3001\u90e8\u7f72\u6b65\u9aa4<\/h3>\n<li>\u90e8\u7f72HAProxy&#xff1a;\u5728192.168.56.102\u6267\u884c01-deploy-haproxy.sh&#xff1b;<\/li>\n<li>\u6e05\u7406\u73af\u5883&#xff1a;\u5728111\/112\/113\/114\/115\u6267\u884c02-clean-k8s-env.sh&#xff08;\u4fdd\u8bc1\u73af\u5883\u5e72\u51c0&#xff09;&#xff1b;<\/li>\n<li>\u521d\u59cb\u5316\u6240\u6709\u8282\u70b9&#xff1a;\u5728111\/112\/113\/114\/115\u6267\u884c03-init-all-nodes.sh&#xff08;\u5b89\u88c5\u4f9d\u8d56\u3001containerd\u3001k8s\u7ec4\u4ef6&#xff09;&#xff1b;<\/li>\n<li>\u521d\u59cb\u5316\u7b2c\u4e00\u4e2aMaster&#xff1a;\u5728111\u6267\u884c04-init-first-master.sh&#xff08;\u751f\u6210etcd\u8bc1\u4e66\u3001\u521d\u59cb\u5316\u96c6\u7fa4\u3001\u90e8\u7f72Calico&#xff09;&#xff1b;<\/li>\n<li>\u52a0\u5165\u5176\u4ed6Master&#xff1a;\u5728112\/113\u6267\u884c05-join-master-nodes.sh&#xff08;\u81ea\u52a8\u62f7\u8d1d\u6587\u4ef6&#xff0c;\u65e0\u9700\u624b\u52a8\u64cd\u4f5c&#xff09;&#xff1b;<\/li>\n<li>\u52a0\u5165Node\u8282\u70b9&#xff1a;\u5728114\/115\u6267\u884c06-join-node-nodes.sh&#xff08;\u81ea\u52a8\u62f7\u8d1d\u6587\u4ef6&#xff0c;\u4fee\u590dnode-ip\u53c2\u6570&#xff09;\u3002<\/li>\n<hr \/>\n<h3>\u56db\u3001\u5173\u952e\u4fee\u590d\u70b9\u603b\u7ed3<\/h3>\n<li>HAProxy\u542f\u52a8\u5931\u8d25&#xff1a;\u5c06fall 0 rise 0\u6539\u4e3afall 3 rise 2&#xff0c;\u89e3\u51b3\u5065\u5eb7\u68c0\u67e5\u9608\u503c\u4e3a0\u5bfc\u81f4\u7684\u542f\u52a8\u5931\u8d25\u95ee\u9898\u3002<\/li>\n<li>Node\u8282\u70b9join\u9519\u8bef&#xff1a;\u901a\u8fc7\u914d\u7f6e\u6587\u4ef6JoinConfiguration\u7684nodeRegistration.kubeletExtraArgs\u6307\u5b9anode-ip&#xff0c;\u800c\u975e\u76f4\u63a5\u62fc\u63a5\u5230\u547d\u4ee4\u884c&#xff0c;\u89e3\u51b3unknown flag: &#8211;node-ip\u9519\u8bef\u3002<\/li>\n<li>Master\u8282\u70b9join\u4f9d\u8d56&#xff1a;\u4fee\u590d\u4e86\u5bf9k8s-join-command.sh\u7684\u4f9d\u8d56\u89e3\u6790\u903b\u8f91&#xff0c;\u81ea\u52a8\u63d0\u53d6token\u548ccaCertHash\u3002<\/li>\n<li>\u81ea\u52a8\u62f7\u8d1d\u6587\u4ef6&#xff1a;\u5728\u4e24\u4e2ajoin\u811a\u672c\u4e2d\u65b0\u589e\u4e86\u4ece\u7b2c\u4e00\u4e2aMaster\u8282\u70b9\u81ea\u52a8\u62f7\u8d1d\u5173\u952e\u6587\u4ef6\u7684\u903b\u8f91&#xff0c;\u652f\u6301\u514d\u5bc6\u767b\u5f55\u548c\u5bc6\u7801\u767b\u5f55\u4e24\u79cd\u65b9\u5f0f&#xff0c;\u51cf\u5c11\u4e86\u624b\u52a8\u64cd\u4f5c\u3002<\/li>\n<hr \/>\n<h3>\u4e94\u3001\u9a8c\u8bc1\u96c6\u7fa4<\/h3>\n<p>\u90e8\u7f72\u5b8c\u6210\u540e&#xff0c;\u5728\u7b2c\u4e00\u4e2aMaster\u8282\u70b9\u6267\u884c\u4ee5\u4e0b\u547d\u4ee4\u9a8c\u8bc1\u96c6\u7fa4\u72b6\u6001&#xff1a;<\/p>\n<p><span class=\"token comment\"># \u67e5\u770b\u6240\u6709\u8282\u70b9\u72b6\u6001<\/span><br \/>\nkubectl get nodes<\/p>\n<p><span class=\"token comment\"># \u67e5\u770b\u96c6\u7fa4\u7ec4\u4ef6\u72b6\u6001<\/span><br \/>\nkubectl get cs<\/p>\n<p><span class=\"token comment\"># \u67e5\u770bCalico Pod\u72b6\u6001<\/span><br \/>\nkubectl get pods -n kube-system<\/p>\n<p>\u5982\u679c\u6240\u6709\u8282\u70b9\u72b6\u6001\u4e3aReady&#xff0c;\u4e14\u6240\u6709Pod\u90fd\u6b63\u5e38\u8fd0\u884c&#xff0c;\u8bf4\u660e\u96c6\u7fa4\u90e8\u7f72\u6210\u529f\u3002<\/p>\n<hr \/>\n<h3>\u516d\u3001\u603b\u7ed3<\/h3>\n<p>\u901a\u8fc7\u8fd9\u5957\u811a\u672c&#xff0c;\u6211\u4eec\u6210\u529f\u642d\u5efa\u4e86\u4e00\u4e2a\u9ad8\u53ef\u7528\u7684K8s\u96c6\u7fa4\u3002\u5728\u90e8\u7f72\u8fc7\u7a0b\u4e2d&#xff0c;\u6211\u4eec\u9047\u5230\u4e86\u4e00\u4e9b\u5e38\u89c1\u7684\u5751&#xff0c;\u6bd4\u5982HAProxy\u5065\u5eb7\u68c0\u67e5\u914d\u7f6e\u3001kubeadm join\u53c2\u6570\u9519\u8bef\u7b49&#xff0c;\u901a\u8fc7\u4e0d\u65ad\u8c03\u8bd5\u548c\u4f18\u5316&#xff0c;\u6700\u7ec8\u5f97\u5230\u4e86\u4e00\u5957\u9c81\u68d2\u6027\u5f3a\u3001\u53ef\u590d\u7528\u7684\u90e8\u7f72\u65b9\u6848\u3002<\/p>\n<p>\u5e0c\u671b\u8fd9\u7bc7\u6587\u7ae0\u80fd\u5e2e\u52a9\u5230\u6b63\u5728\u642d\u5efaK8s\u96c6\u7fa4\u7684\u540c\u5b66&#xff0c;\u5982\u679c\u4f60\u6709\u4efb\u4f55\u95ee\u9898\u6216\u5efa\u8bae&#xff0c;\u6b22\u8fce\u5728\u8bc4\u8bba\u533a\u7559\u8a00\u4ea4\u6d41\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u6700\u8fd1\u5728\u865a\u62df\u673a\u4e0a\u642d\u5efa\u4e86\u4e00\u5957\u57fa\u4e8eHAProxy  3 Master  2 Node\u7684K8s\u9ad8\u53ef\u7528\u96c6\u7fa4&#xff0c;\u8e29\u4e86\u4e0d\u5c11\u5751&#xff0c;\u4e5f\u6c89\u6dc0\u4e86\u4e00\u5957\u53ef\u590d\u7528\u7684\u90e8\u7f72\u811a\u672c\u3002\u4eca\u5929\u5c31\u628a\u6574\u4e2a\u8fc7\u7a0b\u548c\u811a\u672c\u5206\u4eab\u51fa\u6765&#xff0c;\u5e0c\u671b\u80fd\u5e2e\u5230\u6709\u540c\u6837\u9700\u6c42\u7684\u540c\u5b66\u3002\u4e00\u3001\u96c6\u7fa4\u67b6\u6784\u8bbe\u8ba1<br \/>\n\u6211\u4eec\u7684\u76ee\u6807\u662f\u642d\u5efa\u4e00\u4e2a\u751f\u4ea7\u53ef\u7528\u7684K8s\u96c6\u7fa4&#xff0c;\u6838\u5fc3\u8bbe\u8ba1\u5982\u4e0b&#xff1a;\u89d2\u8272\u8282\u70b9IP\u8bf4\u660eHAProxy192.168.56.102\u4f5c\u4e3aAPI Server\u7684\u8d1f\u8f7d\u5747\u8861\u5165\u53e3&#xff0c;\u65e0\u9700\u5065\u5eb7\u68c0\u67e5Master<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[1493,763,121],"topic":[],"class_list":["post-76570","post","type-post","status-publish","format-standard","hentry","category-server","tag-k8s","tag-763","tag-121"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v20.3 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u4ece\u5355\u8282\u70b9\u5230\u9ad8\u53ef\u7528\uff1a\u6211\u662f\u5982\u4f55\u4e00\u6b65\u6b65\u642d\u5efa\u751f\u4ea7\u7ea7K8s\u96c6\u7fa4\u7684 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.wsisp.com\/helps\/76570.html\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u4ece\u5355\u8282\u70b9\u5230\u9ad8\u53ef\u7528\uff1a\u6211\u662f\u5982\u4f55\u4e00\u6b65\u6b65\u642d\u5efa\u751f\u4ea7\u7ea7K8s\u96c6\u7fa4\u7684 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"og:description\" content=\"\u6700\u8fd1\u5728\u865a\u62df\u673a\u4e0a\u642d\u5efa\u4e86\u4e00\u5957\u57fa\u4e8eHAProxy 3 Master 2 Node\u7684K8s\u9ad8\u53ef\u7528\u96c6\u7fa4&#xff0c;\u8e29\u4e86\u4e0d\u5c11\u5751&#xff0c;\u4e5f\u6c89\u6dc0\u4e86\u4e00\u5957\u53ef\u590d\u7528\u7684\u90e8\u7f72\u811a\u672c\u3002\u4eca\u5929\u5c31\u628a\u6574\u4e2a\u8fc7\u7a0b\u548c\u811a\u672c\u5206\u4eab\u51fa\u6765&#xff0c;\u5e0c\u671b\u80fd\u5e2e\u5230\u6709\u540c\u6837\u9700\u6c42\u7684\u540c\u5b66\u3002\u4e00\u3001\u96c6\u7fa4\u67b6\u6784\u8bbe\u8ba1 \u6211\u4eec\u7684\u76ee\u6807\u662f\u642d\u5efa\u4e00\u4e2a\u751f\u4ea7\u53ef\u7528\u7684K8s\u96c6\u7fa4&#xff0c;\u6838\u5fc3\u8bbe\u8ba1\u5982\u4e0b&#xff1a;\u89d2\u8272\u8282\u70b9IP\u8bf4\u660eHAProxy192.168.56.102\u4f5c\u4e3aAPI Server\u7684\u8d1f\u8f7d\u5747\u8861\u5165\u53e3&#xff0c;\u65e0\u9700\u5065\u5eb7\u68c0\u67e5Master\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.wsisp.com\/helps\/76570.html\" \/>\n<meta property=\"og:site_name\" content=\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"article:published_time\" content=\"2026-02-22T12:33:27+00:00\" \/>\n<meta name=\"author\" content=\"admin\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"13 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/76570.html\",\"url\":\"https:\/\/www.wsisp.com\/helps\/76570.html\",\"name\":\"\u4ece\u5355\u8282\u70b9\u5230\u9ad8\u53ef\u7528\uff1a\u6211\u662f\u5982\u4f55\u4e00\u6b65\u6b65\u642d\u5efa\u751f\u4ea7\u7ea7K8s\u96c6\u7fa4\u7684 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"isPartOf\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\"},\"datePublished\":\"2026-02-22T12:33:27+00:00\",\"dateModified\":\"2026-02-22T12:33:27+00:00\",\"author\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/76570.html#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.wsisp.com\/helps\/76570.html\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/76570.html#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.wsisp.com\/helps\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u4ece\u5355\u8282\u70b9\u5230\u9ad8\u53ef\u7528\uff1a\u6211\u662f\u5982\u4f55\u4e00\u6b65\u6b65\u642d\u5efa\u751f\u4ea7\u7ea7K8s\u96c6\u7fa4\u7684\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\",\"url\":\"https:\/\/www.wsisp.com\/helps\/\",\"name\":\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"description\":\"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\",\"name\":\"admin\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"contentUrl\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"caption\":\"admin\"},\"sameAs\":[\"http:\/\/wp.wsisp.com\"],\"url\":\"https:\/\/www.wsisp.com\/helps\/author\/admin\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"\u4ece\u5355\u8282\u70b9\u5230\u9ad8\u53ef\u7528\uff1a\u6211\u662f\u5982\u4f55\u4e00\u6b65\u6b65\u642d\u5efa\u751f\u4ea7\u7ea7K8s\u96c6\u7fa4\u7684 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.wsisp.com\/helps\/76570.html","og_locale":"zh_CN","og_type":"article","og_title":"\u4ece\u5355\u8282\u70b9\u5230\u9ad8\u53ef\u7528\uff1a\u6211\u662f\u5982\u4f55\u4e00\u6b65\u6b65\u642d\u5efa\u751f\u4ea7\u7ea7K8s\u96c6\u7fa4\u7684 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","og_description":"\u6700\u8fd1\u5728\u865a\u62df\u673a\u4e0a\u642d\u5efa\u4e86\u4e00\u5957\u57fa\u4e8eHAProxy 3 Master 2 Node\u7684K8s\u9ad8\u53ef\u7528\u96c6\u7fa4&#xff0c;\u8e29\u4e86\u4e0d\u5c11\u5751&#xff0c;\u4e5f\u6c89\u6dc0\u4e86\u4e00\u5957\u53ef\u590d\u7528\u7684\u90e8\u7f72\u811a\u672c\u3002\u4eca\u5929\u5c31\u628a\u6574\u4e2a\u8fc7\u7a0b\u548c\u811a\u672c\u5206\u4eab\u51fa\u6765&#xff0c;\u5e0c\u671b\u80fd\u5e2e\u5230\u6709\u540c\u6837\u9700\u6c42\u7684\u540c\u5b66\u3002\u4e00\u3001\u96c6\u7fa4\u67b6\u6784\u8bbe\u8ba1 \u6211\u4eec\u7684\u76ee\u6807\u662f\u642d\u5efa\u4e00\u4e2a\u751f\u4ea7\u53ef\u7528\u7684K8s\u96c6\u7fa4&#xff0c;\u6838\u5fc3\u8bbe\u8ba1\u5982\u4e0b&#xff1a;\u89d2\u8272\u8282\u70b9IP\u8bf4\u660eHAProxy192.168.56.102\u4f5c\u4e3aAPI Server\u7684\u8d1f\u8f7d\u5747\u8861\u5165\u53e3&#xff0c;\u65e0\u9700\u5065\u5eb7\u68c0\u67e5Master","og_url":"https:\/\/www.wsisp.com\/helps\/76570.html","og_site_name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","article_published_time":"2026-02-22T12:33:27+00:00","author":"admin","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"admin","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"13 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.wsisp.com\/helps\/76570.html","url":"https:\/\/www.wsisp.com\/helps\/76570.html","name":"\u4ece\u5355\u8282\u70b9\u5230\u9ad8\u53ef\u7528\uff1a\u6211\u662f\u5982\u4f55\u4e00\u6b65\u6b65\u642d\u5efa\u751f\u4ea7\u7ea7K8s\u96c6\u7fa4\u7684 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","isPartOf":{"@id":"https:\/\/www.wsisp.com\/helps\/#website"},"datePublished":"2026-02-22T12:33:27+00:00","dateModified":"2026-02-22T12:33:27+00:00","author":{"@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41"},"breadcrumb":{"@id":"https:\/\/www.wsisp.com\/helps\/76570.html#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.wsisp.com\/helps\/76570.html"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.wsisp.com\/helps\/76570.html#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.wsisp.com\/helps"},{"@type":"ListItem","position":2,"name":"\u4ece\u5355\u8282\u70b9\u5230\u9ad8\u53ef\u7528\uff1a\u6211\u662f\u5982\u4f55\u4e00\u6b65\u6b65\u642d\u5efa\u751f\u4ea7\u7ea7K8s\u96c6\u7fa4\u7684"}]},{"@type":"WebSite","@id":"https:\/\/www.wsisp.com\/helps\/#website","url":"https:\/\/www.wsisp.com\/helps\/","name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","description":"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41","name":"admin","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/","url":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","contentUrl":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","caption":"admin"},"sameAs":["http:\/\/wp.wsisp.com"],"url":"https:\/\/www.wsisp.com\/helps\/author\/admin"}]}},"_links":{"self":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/76570","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/comments?post=76570"}],"version-history":[{"count":0,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/76570\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/media?parent=76570"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/categories?post=76570"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/tags?post=76570"},{"taxonomy":"topic","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/topic?post=76570"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}