{"id":33387,"date":"2025-04-27T11:23:14","date_gmt":"2025-04-27T03:23:14","guid":{"rendered":"https:\/\/www.wsisp.com\/helps\/33387.html"},"modified":"2025-04-27T11:23:14","modified_gmt":"2025-04-27T03:23:14","slug":"ubuntu-k8s%e9%9b%86%e7%be%a4%e5%ae%89%e5%85%a8%e5%8a%a0%e5%9b%ba%e6%96%b9%e6%a1%88","status":"publish","type":"post","link":"https:\/\/www.wsisp.com\/helps\/33387.html","title":{"rendered":"Ubuntu K8s\u96c6\u7fa4\u5b89\u5168\u52a0\u56fa\u65b9\u6848"},"content":{"rendered":"<h3>Ubuntu K8s\u96c6\u7fa4\u5b89\u5168\u52a0\u56fa\u65b9\u6848<\/h3>\n<p>\u5728Ubuntu\u7cfb\u7edf\u4e0a\u90e8\u7f72Kubernetes\u96c6\u7fa4\u65f6&#xff0c;\u82e5\u670d\u52a1\u5668\u62e5\u6709\u5916\u7f51IP&#xff0c;\u9700\u91c7\u53d6\u591a\u5c42\u6b21\u5b89\u5168\u9632\u62a4\u63aa\u65bd\u4ee5\u786e\u4fdd\u96c6\u7fa4\u5b89\u5168\u3002\u672c\u65b9\u6848\u901a\u8fc7\u7cfb\u7edf\u9632\u706b\u5899\u914d\u7f6e\u3001TLS\u901a\u4fe1\u542f\u7528\u3001\u7f51\u7edc\u7b56\u7565\u5b9e\u65bd\u548cRBAC\u6743\u9650\u63a7\u5236\u56db\u4e2a\u6838\u5fc3\u5c42\u9762&#xff0c;\u6784\u5efa\u5b89\u5168\u7684Kubernetes\u73af\u5883\u3002\u5b89\u5168\u9632\u62a4\u4e0d\u5e94\u4ec5\u505c\u7559\u5728\u5355\u70b9\u63aa\u65bd&#xff0c;\u800c\u5e94\u5f62\u6210\u7eb5\u6df1\u9632\u5fa1\u4f53\u7cfb&#xff0c;\u4ece\u7269\u7406\u4e3b\u673a\u5230\u96c6\u7fa4\u63a7\u5236\u9762\u518d\u5230\u5e94\u7528\u5c42\u8fdb\u884c\u5168\u9762\u4fdd\u62a4\u3002\u5728\u751f\u4ea7\u73af\u5883\u4e2d&#xff0c;\u9700\u786e\u4fdd\u6240\u6709\u5b89\u5168\u914d\u7f6e\u5747\u7b26\u5408\u6700\u5c0f\u6743\u9650\u539f\u5219&#xff0c;\u5e76\u5b9a\u671f\u8fdb\u884c\u5ba1\u8ba1\u4e0e\u76d1\u63a7\u3002<\/p>\n<h4>\u4e00\u3001\u57fa\u7840\u7cfb\u7edf\u5b89\u5168\u914d\u7f6e<\/h4>\n<p>Ubuntu\u670d\u52a1\u5668\u4f5c\u4e3aKubernetes\u96c6\u7fa4\u8282\u70b9&#xff0c;\u5176\u57fa\u7840\u7cfb\u7edf\u5b89\u5168\u81f3\u5173\u91cd\u8981\u3002\u9996\u5148&#xff0c;\u9700\u786e\u4fdd\u7cfb\u7edf\u65f6\u95f4\u540c\u6b65&#xff0c;\u8fd9\u53ef\u4ee5\u901a\u8fc7\u5b89\u88c5NTP\u670d\u52a1\u5e76\u914d\u7f6e\u53ef\u9760\u7684NTP\u670d\u52a1\u5668\u5b9e\u73b0\u3002\u5728Ubuntu\u4e0a&#xff0c;\u53ef\u4f7f\u7528\u4ee5\u4e0b\u547d\u4ee4\u5b89\u88c5\u5e76\u914d\u7f6eNTP\u670d\u52a1&#xff1a;<\/p>\n<p><span class=\"token function\">sudo<\/span> <span class=\"token function\">apt<\/span> update<br \/>\n<span class=\"token function\">sudo<\/span> <span class=\"token function\">apt<\/span> <span class=\"token function\">install<\/span> ntpdate ntp<br \/>\n<span class=\"token function\">sudo<\/span> ntpdate ntp1.aliyun.com<\/p>\n<p>\u5176\u6b21&#xff0c;\u5e94\u7981\u7528Swap\u529f\u80fd\u3002Kubernetes\u8981\u6c42\u6240\u6709\u8282\u70b9\u7981\u7528Swap&#xff0c;\u53ef\u901a\u8fc7\u7f16\u8f91\/etc\/fstab\u6587\u4ef6\u5e76\u6ce8\u91ca\u6389Swap\u884c\u5b9e\u73b0&#xff0c;\u7136\u540e\u6267\u884cswapoff &#8211;all\u547d\u4ee4\u3002<\/p>\n<p>\u7136\u540e&#xff0c;\u914d\u7f6e\u5bb9\u5668\u8fd0\u884c\u65f6\u73af\u5883\u3002\u5bf9\u4e8eUbuntu\u7cfb\u7edf&#xff0c;\u63a8\u8350\u4f7f\u7528Docker\u6216Containerd\u4f5c\u4e3a\u5bb9\u5668\u8fd0\u884c\u65f6\u3002Docker\u5b89\u88c5\u547d\u4ee4\u5982\u4e0b&#xff1a;<\/p>\n<p><span class=\"token function\">sudo<\/span> <span class=\"token function\">apt-get<\/span> update<br \/>\n<span class=\"token function\">sudo<\/span> <span class=\"token function\">apt-get<\/span> <span class=\"token function\">install<\/span> docker.io<\/p>\n<p>Containerd\u5b89\u88c5\u547d\u4ee4\u5982\u4e0b&#xff1a;<\/p>\n<p><span class=\"token function\">sudo<\/span> <span class=\"token function\">apt-get<\/span> update<br \/>\n<span class=\"token function\">sudo<\/span> <span class=\"token function\">apt-get<\/span> <span class=\"token function\">install<\/span> containerd<\/p>\n<p>\u6b64\u5916&#xff0c;\u8fd8\u9700\u8c03\u6574Linux\u5185\u6838\u53c2\u6570\u4ee5\u652f\u6301Kubernetes\u7f51\u7edc\u9700\u6c42\u3002\u5728Ubuntu\u4e0a&#xff0c;\u53ef\u901a\u8fc7\u4ee5\u4e0b\u547d\u4ee4\u4fee\u6539\u5185\u6838\u53c2\u6570&#xff1a;<\/p>\n<p><span class=\"token function\">cat<\/span> <span class=\"token operator\">&gt;&gt;<\/span> \/etc\/sysctl.d\/kubernetes.conf <span class=\"token operator\">&lt;&lt;<\/span><span class=\"token string\">EOF<br \/>\nnet.bridge.bridge-nf-call-ip6tables &#061; 1<br \/>\nnet.bridge.bridge-nf-call-iptables &#061; 1<br \/>\nnet.ipv4.ip_forward &#061; 1<br \/>\nEOF<\/span><br \/>\nsysctl -p<\/p>\n<p>\u8fd9\u4e9b\u5185\u6838\u53c2\u6570\u786e\u4fdd\u4e86\u5bb9\u5668\u7f51\u7edc\u548cKubernetes\u7ec4\u4ef6\u4e4b\u95f4\u7684\u6b63\u5e38\u901a\u4fe1\u3002<\/p>\n<h4>\u4e8c\u3001\u9632\u706b\u5899\u89c4\u5219\u914d\u7f6e<\/h4>\n<p>Ubuntu\u670d\u52a1\u5668\u7684\u9632\u706b\u5899\u89c4\u5219\u662f\u4fdd\u62a4\u96c6\u7fa4\u7684\u7b2c\u4e00\u9053\u9632\u7ebf&#xff0c;\u9700\u5bf9\u975e\u5fc5\u8981\u7aef\u53e3\u8fdb\u884c\u9650\u5236&#xff0c;\u4ec5\u5f00\u653eAPI Server\u7b49\u5fc5\u9700\u7aef\u53e3\u3002\u9ed8\u8ba4\u60c5\u51b5\u4e0b&#xff0c;UFW&#xff08;Uncomplicated Firewall&#xff09;\u662fUbuntu\u7684\u9ed8\u8ba4\u9632\u706b\u5899\u914d\u7f6e\u5de5\u5177&#xff0c;\u63d0\u4f9b\u4e86\u4e00\u4e2a\u7528\u6237\u53cb\u597d\u7684\u754c\u9762\u6765\u7ba1\u7406Linux\u7cfb\u7edf\u7684Netfilter\u9632\u706b\u5899\u3002<\/p>\n<p>\u9996\u5148&#xff0c;\u5b89\u88c5\u5e76\u542f\u7528UFW\u9632\u706b\u5899&#xff1a;<\/p>\n<p><span class=\"token function\">sudo<\/span> <span class=\"token function\">apt<\/span> update<br \/>\n<span class=\"token function\">sudo<\/span> <span class=\"token function\">apt<\/span> <span class=\"token function\">install<\/span> ufw<br \/>\n<span class=\"token function\">sudo<\/span> ufw <span class=\"token builtin class-name\">enable<\/span><\/p>\n<p>\u542f\u7528UFW\u540e&#xff0c;\u9ed8\u8ba4\u62d2\u7edd\u6240\u6709\u5165\u7ad9\u8fde\u63a5&#xff0c;\u4ec5\u5141\u8bb8\u5df2\u660e\u786e\u5141\u8bb8\u7684\u8fde\u63a5\u3002\u8fd9\u662f\u7b26\u5408\u5b89\u5168\u539f\u5219\u7684\u9ed8\u8ba4\u7b56\u7565\u3002<\/p>\n<p>\u9488\u5bf9Kubernetes\u96c6\u7fa4&#xff0c;\u9700\u5f00\u653e\u4ee5\u4e0b\u5173\u952e\u7aef\u53e3&#xff1a;<\/p>\n<table>\n<tr>\u7aef\u53e3\u534f\u8bae\u7528\u9014\u8bbf\u95ee\u63a7\u5236<\/tr>\n<tbody>\n<tr>\n<td>22<\/td>\n<td>TCP<\/td>\n<td>SSH\u7ba1\u7406<\/td>\n<td>\u4ec5\u5141\u8bb8\u7279\u5b9aIP\u6216\u5b50\u7f51\u8bbf\u95ee<\/td>\n<\/tr>\n<tr>\n<td>6443<\/td>\n<td>TCP<\/td>\n<td>API Server<\/td>\n<td>\u4ec5\u5141\u8bb8\u96c6\u7fa4\u5185\u8282\u70b9\u6216\u7ba1\u7406IP\u8bbf\u95ee<\/td>\n<\/tr>\n<tr>\n<td>10250<\/td>\n<td>TCP<\/td>\n<td>Kubelet API<\/td>\n<td>\u4ec5\u5141\u8bb8\u96c6\u7fa4\u5185\u8282\u70b9\u8bbf\u95ee<\/td>\n<\/tr>\n<tr>\n<td>10255<\/td>\n<td>TCP<\/td>\n<td>Kubelet\u53ea\u8bfb\u7aef\u53e3<\/td>\n<td>\u4ec5\u5141\u8bb8\u96c6\u7fa4\u5185\u8282\u70b9\u8bbf\u95ee<\/td>\n<\/tr>\n<tr>\n<td>53<\/td>\n<td>TCP\/UDP<\/td>\n<td>DNS\u670d\u52a1<\/td>\n<td>\u4ec5\u5141\u8bb8\u96c6\u7fa4\u5185\u8282\u70b9\u8bbf\u95ee<\/td>\n<\/tr>\n<tr>\n<td>2379\/2380<\/td>\n<td>TCP<\/td>\n<td>etcd\u96c6\u7fa4\u901a\u4fe1<\/td>\n<td>\u4ec5\u5141\u8bb8\u4e3b\u8282\u70b9\u95f4\u901a\u4fe1<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>\u5177\u4f53UFW\u89c4\u5219\u914d\u7f6e\u793a\u4f8b\u5982\u4e0b&#xff1a;<\/p>\n<p><span class=\"token comment\"># \u5141\u8bb8SSH\u7ba1\u7406\u8bbf\u95ee<\/span><br \/>\n<span class=\"token function\">sudo<\/span> ufw allow from <span class=\"token number\">192.168<\/span>.1.0\/24 to any port <span class=\"token number\">22<\/span> proto tcp<\/p>\n<p><span class=\"token comment\"># \u5141\u8bb8API Server\u8bbf\u95ee&#xff08;\u4ec5\u9650\u96c6\u7fa4\u5185\u8282\u70b9&#xff09;<\/span><br \/>\n<span class=\"token function\">sudo<\/span> ufw allow from <span class=\"token number\">10.0<\/span>.0.0\/24 to any port <span class=\"token number\">6443<\/span> proto tcp<\/p>\n<p><span class=\"token comment\"># \u5141\u8bb8etcd\u96c6\u7fa4\u901a\u4fe1&#xff08;\u4ec5\u9650\u4e3b\u8282\u70b9\u95f4&#xff09;<\/span><br \/>\n<span class=\"token function\">sudo<\/span> ufw allow from <span class=\"token operator\">&lt;<\/span>\u4e3b\u8282\u70b9IP<span class=\"token operator\"><span class=\"token file-descriptor important\">1<\/span>&gt;<\/span> to any port <span class=\"token number\">2379<\/span> proto tcp<br \/>\n<span class=\"token function\">sudo<\/span> ufw allow from <span class=\"token operator\">&lt;<\/span>\u4e3b\u8282\u70b9IP<span class=\"token operator\"><span class=\"token file-descriptor important\">2<\/span>&gt;<\/span> to any port <span class=\"token number\">2379<\/span> proto tcp<\/p>\n<p><span class=\"token comment\"># \u5141\u8bb8kubelet API\u8bbf\u95ee&#xff08;\u4ec5\u9650\u96c6\u7fa4\u5185\u8282\u70b9&#xff09;<\/span><br \/>\n<span class=\"token function\">sudo<\/span> ufw allow from <span class=\"token number\">10.0<\/span>.0.0\/24 to any port <span class=\"token number\">10250<\/span> proto tcp<\/p>\n<p><span class=\"token comment\"># \u5141\u8bb8DNS\u670d\u52a1\u8bbf\u95ee&#xff08;\u4ec5\u9650\u96c6\u7fa4\u5185\u8282\u70b9&#xff09;<\/span><br \/>\n<span class=\"token function\">sudo<\/span> ufw allow from <span class=\"token number\">10.0<\/span>.0.0\/24 to any port <span class=\"token number\">53<\/span> proto tcp<br \/>\n<span class=\"token function\">sudo<\/span> ufw allow from <span class=\"token number\">10.0<\/span>.0.0\/24 to any port <span class=\"token number\">53<\/span> proto udp<\/p>\n<p><span class=\"token comment\"># \u8bbe\u7f6e\u9ed8\u8ba4\u7b56\u7565\u4e3a\u62d2\u7edd\u6240\u6709\u5165\u7ad9\u8fde\u63a5<\/span><br \/>\n<span class=\"token function\">sudo<\/span> ufw default deny incoming<\/p>\n<p>\u7279\u522b\u6ce8\u610f&#xff1a;NodePort\u670d\u52a1\u7aef\u53e3\u8303\u56f4&#xff08;30000-32767&#xff09;\u4ec5\u5728\u5fc5\u8981\u65f6\u5f00\u653e&#xff0c;\u4e14\u5efa\u8bae\u9650\u5236\u8bbf\u95ee\u6765\u6e90\u4e3a\u7279\u5b9a\u7ba1\u7406IP\u3002\u82e5\u96c6\u7fa4\u4e0d\u4f7f\u7528NodePort\u670d\u52a1&#xff0c;\u5e94\u5b8c\u5168\u5173\u95ed\u6b64\u7aef\u53e3\u8303\u56f4\u3002<\/p>\n<p>\u6700\u540e&#xff0c;\u4fdd\u5b58\u5e76\u5e94\u7528UFW\u89c4\u5219&#xff1a;<\/p>\n<p><span class=\"token function\">sudo<\/span> ufw reload<br \/>\n<span class=\"token function\">sudo<\/span> ufw status numbered<\/p>\n<p>\u901a\u8fc7UFW\u89c4\u5219\u914d\u7f6e&#xff0c;\u786e\u4fdd\u4e86\u53ea\u6709\u6388\u6743\u6d41\u91cf\u624d\u80fd\u8bbf\u95ee\u670d\u52a1\u5668&#xff0c;\u5927\u5927\u964d\u4f4e\u4e86\u88ab\u653b\u51fb\u7684\u53ef\u80fd\u6027\u3002<\/p>\n<h4>\u4e09\u3001TLS\u5b89\u5168\u901a\u4fe1\u914d\u7f6e<\/h4>\n<p>\u5728Kubernetes\u96c6\u7fa4\u4e2d&#xff0c;TLS\u5b89\u5168\u901a\u4fe1\u662f\u4fdd\u62a4\u63a7\u5236\u5e73\u9762\u548c\u6570\u636e\u4f20\u8f93\u7684\u5173\u952e\u673a\u5236\u3002\u5728\u521d\u59cb\u5316\u96c6\u7fa4\u65f6&#xff0c;\u901a\u8fc7kubeadm init\u547d\u4ee4\u542f\u7528TLS\u901a\u4fe1&#xff0c;\u5e76\u914d\u7f6e\u8bc1\u4e66\u7ba1\u7406\u53ca\u8bbe\u7f6etoken\u6709\u6548\u671f\u3002<\/p>\n<p>\u9996\u5148&#xff0c;\u4f7f\u7528\u4ee5\u4e0b\u547d\u4ee4\u521d\u59cb\u5316\u4e3b\u8282\u70b9&#xff1a;<\/p>\n<p><span class=\"token function\">sudo<\/span> kubeadm init <span class=\"token punctuation\">\\\\<\/span><br \/>\n  &#8211;apiserver-advertise-address<span class=\"token operator\">&#061;<\/span>\u5185\u7f51IP <span class=\"token punctuation\">\\\\<\/span><br \/>\n  &#8211;apiserver-cert-extra-sans<span class=\"token operator\">&#061;<\/span>\u5916\u7f51IP <span class=\"token punctuation\">\\\\<\/span><br \/>\n  &#8211;pod-network-cidr<span class=\"token operator\">&#061;<\/span><span class=\"token number\">10.244<\/span>.0.0\/16<\/p>\n<p>\u5176\u4e2d&#xff0c;&#8211;apiserver-cert-extra-sans\u53c2\u6570\u81f3\u5173\u91cd\u8981&#xff0c;\u5b83\u5141\u8bb8\u4e3aAPI Server\u8bc1\u4e66\u6dfb\u52a0\u989d\u5916\u7684Subject Alternative Name&#xff08;SAN&#xff09;&#xff0c;\u786e\u4fddAPI Server\u53ef\u901a\u8fc7\u5916\u7f51IP\u6216\u57df\u540d\u5b89\u5168\u8bbf\u95ee\u3002<\/p>\n<p>\u521d\u59cb\u5316\u5b8c\u6210\u540e&#xff0c;\u7acb\u5373\u521b\u5efa\u5e26\u6709\u6548\u671f\u7684\u5f15\u5bfctoken&#xff1a;<\/p>\n<p><span class=\"token function\">sudo<\/span> kubeadm token create &#8211;validity 24h &#8211;print-join-command<\/p>\n<p>\u5efa\u8bae\u5c06\u9ed8\u8ba4token\u6709\u6548\u671f\u8bbe\u7f6e\u4e3a24\u5c0f\u65f6&#xff0c;\u800c\u975e\u4f7f\u7528\u6c38\u4e45\u6709\u6548\u7684token\u3002\u8fd9\u53ef\u4ee5\u901a\u8fc7\u4fee\u6539kubeadm\u914d\u7f6e\u6587\u4ef6\u5e76\u6307\u5b9a&#8211;token-ttl\u53c2\u6570\u5b9e\u73b0\u3002<\/p>\n<p>\u63a5\u4e0b\u6765&#xff0c;\u68c0\u67e5\u8bc1\u4e66\u6709\u6548\u671f&#xff1a;<\/p>\n<p><span class=\"token function\">sudo<\/span> kubeadm certs check-expiration<\/p>\n<p>\u63a7\u5236\u9762\u8bc1\u4e66\u9ed8\u8ba4\u6709\u6548\u671f\u4e3a1\u5e74&#xff0c;\u8fd9\u7b26\u5408\u751f\u4ea7\u73af\u5883\u7684\u5b89\u5168\u8981\u6c42\u3002\u82e5\u9700\u5ef6\u957f\u6709\u6548\u671f&#xff0c;\u53ef\u901a\u8fc7\u4fee\u6539kubeadm\u914d\u7f6e\u6587\u4ef6\u4e2d\u7684certificates.duration\u5b57\u6bb5\u5b9e\u73b0&#xff0c;\u4f46\u4e0d\u5efa\u8bae\u8d85\u8fc71\u5e74&#xff0c;\u4ee5\u964d\u4f4e\u7ef4\u62a4\u590d\u6742\u6027\u3002<\/p>\n<p>\u6700\u540e&#xff0c;\u624b\u52a8\u7eed\u7b7e\u8bc1\u4e66&#xff08;\u82e5\u9700\u8981&#xff09;&#xff1a;<\/p>\n<p><span class=\"token function\">sudo<\/span> kubeadm certs renew all<\/p>\n<p>\u7eed\u7b7e\u8bc1\u4e66\u540e&#xff0c;\u9700\u91cd\u542f\u76f8\u5173\u7ec4\u4ef6&#xff1a;<\/p>\n<p>systemctl restart kubelet<br \/>\nkubectl delete pod -n kube-system -l k8s-app<span class=\"token operator\">&#061;<\/span>kube-apiserver<br \/>\nkubectl delete pod -n kube-system -l k8s-app<span class=\"token operator\">&#061;<\/span>kube-controller-manager<br \/>\nkubectl delete pod -n kube-system -l k8s-app<span class=\"token operator\">&#061;<\/span>kube-scheduler<\/p>\n<p>\u901a\u8fc7\u4ee5\u4e0a\u914d\u7f6e&#xff0c;\u786e\u4fdd\u4e86Kubernetes\u96c6\u7fa4\u5185\u90e8\u901a\u4fe1\u7684\u5b89\u5168\u6027&#xff0c;\u907f\u514d\u4e86\u672a\u7ecf\u52a0\u5bc6\u7684HTTP\u6d41\u91cf\u4f20\u8f93\u3002<\/p>\n<h4>\u56db\u3001\u7f51\u7edc\u7b56\u7565\u63d2\u4ef6\u90e8\u7f72\u4e0e\u914d\u7f6e<\/h4>\n<p>\u90e8\u7f72\u7f51\u7edc\u7b56\u7565\u63d2\u4ef6\u5982Calico\u662f\u5b9e\u65bdPod\u95f4\u901a\u4fe1\u9650\u5236\u548c\u547d\u540d\u7a7a\u95f4\u9694\u79bb\u7684\u5173\u952e\u6b65\u9aa4\u3002Calico\u4e0d\u4ec5\u63d0\u4f9bCNI&#xff08;\u5bb9\u5668\u7f51\u7edc\u63a5\u53e3&#xff09;\u529f\u80fd&#xff0c;\u8fd8\u652f\u6301\u5f3a\u5927\u7684\u7f51\u7edc\u7b56\u7565\u529f\u80fd&#xff0c;\u80fd\u591f\u5b9e\u73b0\u7ec6\u7c92\u5ea6\u7684Pod\u95f4\u901a\u4fe1\u63a7\u5236\u3002<\/p>\n<p>\u9996\u5148&#xff0c;\u4e0b\u8f7dCalico\u7684YAML\u914d\u7f6e\u6587\u4ef6&#xff1a;<\/p>\n<p><span class=\"token function\">curl<\/span> https:\/\/docs.projectcalico.org\/manifests\/calico.yaml -O<\/p>\n<p>\u7136\u540e&#xff0c;\u5e94\u7528Calico\u914d\u7f6e&#xff1a;<\/p>\n<p>kubectl apply -f calico.yaml<\/p>\n<p>\u90e8\u7f72\u5b8c\u6210\u540e&#xff0c;\u9a8c\u8bc1Calico\u7ec4\u4ef6\u72b6\u6001&#xff1a;<\/p>\n<p>kubectl get pods -n calico-system<\/p>\n<p>\u786e\u4fdd\u6240\u6709Calico Pod\u5747\u5904\u4e8eRunning\u72b6\u6001\u3002<\/p>\n<p>\u63a5\u4e0b\u6765&#xff0c;\u5b9e\u65bd\u7f51\u7edc\u7b56\u7565\u3002\u5efa\u8bae\u9996\u5148\u542f\u7528\u5168\u5c40\u62d2\u7edd\u7b56\u7565&#xff0c;\u4f5c\u4e3a\u5b89\u5168\u57fa\u7ebf&#xff1a;<\/p>\n<p><span class=\"token key atrule\">apiVersion<\/span><span class=\"token punctuation\">:<\/span> projectcalico.org\/v3<br \/>\n<span class=\"token key atrule\">kind<\/span><span class=\"token punctuation\">:<\/span> GlobalNetworkPolicy<br \/>\n<span class=\"token key atrule\">metadata<\/span><span class=\"token punctuation\">:<\/span><br \/>\n  <span class=\"token key atrule\">name<\/span><span class=\"token punctuation\">:<\/span> default<span class=\"token punctuation\">&#8211;<\/span>deny<br \/>\n<span class=\"token key atrule\">spec<\/span><span class=\"token punctuation\">:<\/span><br \/>\n  <span class=\"token key atrule\">selector<\/span><span class=\"token punctuation\">:<\/span> all()<br \/>\n  <span class=\"token key atrule\">types<\/span><span class=\"token punctuation\">:<\/span><br \/>\n    <span class=\"token punctuation\">&#8211;<\/span> Ingress<br \/>\n    <span class=\"token punctuation\">&#8211;<\/span> Egress<\/p>\n<p>\u5e94\u7528\u5168\u5c40\u62d2\u7edd\u7b56\u7565&#xff1a;<\/p>\n<p>kubectl apply -f global-network-policy.yaml<\/p>\n<p>\u7136\u540e&#xff0c;\u9488\u5bf9DNS\u670d\u52a1\u521b\u5efa\u4f8b\u5916\u7b56\u7565&#xff1a;<\/p>\n<p><span class=\"token key atrule\">apiVersion<\/span><span class=\"token punctuation\">:<\/span> networking.k8s.io\/v1<br \/>\n<span class=\"token key atrule\">kind<\/span><span class=\"token punctuation\">:<\/span> NetworkPolicy<br \/>\n<span class=\"token key atrule\">metadata<\/span><span class=\"token punctuation\">:<\/span><br \/>\n  <span class=\"token key atrule\">name<\/span><span class=\"token punctuation\">:<\/span> allow<span class=\"token punctuation\">&#8211;<\/span>dns<br \/>\n  <span class=\"token key atrule\">namespace<\/span><span class=\"token punctuation\">:<\/span> default<br \/>\n<span class=\"token key atrule\">spec<\/span><span class=\"token punctuation\">:<\/span><br \/>\n  <span class=\"token key atrule\">podSelector<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">{<\/span><span class=\"token punctuation\">}<\/span><br \/>\n  <span class=\"token key atrule\">policyTypes<\/span><span class=\"token punctuation\">:<\/span><br \/>\n    <span class=\"token punctuation\">&#8211;<\/span> Ingress<br \/>\n  <span class=\"token key atrule\">ingress<\/span><span class=\"token punctuation\">:<\/span><br \/>\n    <span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">from<\/span><span class=\"token punctuation\">:<\/span><br \/>\n        <span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">namespaceSelector<\/span><span class=\"token punctuation\">:<\/span><br \/>\n            <span class=\"token key atrule\">matchLabels<\/span><span class=\"token punctuation\">:<\/span><br \/>\n              <span class=\"token key atrule\">name<\/span><span class=\"token punctuation\">:<\/span> kube<span class=\"token punctuation\">&#8211;<\/span>system<br \/>\n        <span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">podSelector<\/span><span class=\"token punctuation\">:<\/span><br \/>\n            <span class=\"token key atrule\">matchLabels<\/span><span class=\"token punctuation\">:<\/span><br \/>\n              <span class=\"token key atrule\">k8s-app<\/span><span class=\"token punctuation\">:<\/span> kube<span class=\"token punctuation\">&#8211;<\/span>dns<br \/>\n      <span class=\"token key atrule\">ports<\/span><span class=\"token punctuation\">:<\/span><br \/>\n        <span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">protocol<\/span><span class=\"token punctuation\">:<\/span> TCP<br \/>\n          <span class=\"token key atrule\">port<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token number\">53<\/span><br \/>\n        <span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">protocol<\/span><span class=\"token punctuation\">:<\/span> UDP<br \/>\n          <span class=\"token key atrule\">port<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token number\">53<\/span><\/p>\n<p>\u5e94\u7528DNS\u4f8b\u5916\u7b56\u7565&#xff1a;<\/p>\n<p>kubectl apply -f dns-policy.yaml<\/p>\n<p>\u547d\u540d\u7a7a\u95f4\u9694\u79bb\u793a\u4f8b&#xff1a;\u5bf9\u4e8e\u654f\u611f\u547d\u540d\u7a7a\u95f4\u5982database&#xff0c;\u53ef\u521b\u5efa\u5b8c\u5168\u9694\u79bb\u7b56\u7565&#xff1a;<\/p>\n<p><span class=\"token key atrule\">apiVersion<\/span><span class=\"token punctuation\">:<\/span> networking.k8s.io\/v1<br \/>\n<span class=\"token key atrule\">kind<\/span><span class=\"token punctuation\">:<\/span> NetworkPolicy<br \/>\n<span class=\"token key atrule\">metadata<\/span><span class=\"token punctuation\">:<\/span><br \/>\n  <span class=\"token key atrule\">name<\/span><span class=\"token punctuation\">:<\/span> default<span class=\"token punctuation\">&#8211;<\/span>deny<br \/>\n  <span class=\"token key atrule\">namespace<\/span><span class=\"token punctuation\">:<\/span> database<br \/>\n<span class=\"token key atrule\">spec<\/span><span class=\"token punctuation\">:<\/span><br \/>\n  <span class=\"token key atrule\">podSelector<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">{<\/span><span class=\"token punctuation\">}<\/span><br \/>\n  <span class=\"token key atrule\">policyTypes<\/span><span class=\"token punctuation\">:<\/span><br \/>\n    <span class=\"token punctuation\">&#8211;<\/span> Ingress<br \/>\n    <span class=\"token punctuation\">&#8211;<\/span> Egress<br \/>\n  <span class=\"token key atrule\">egress<\/span><span class=\"token punctuation\">:<\/span><br \/>\n    <span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">to<\/span><span class=\"token punctuation\">:<\/span><br \/>\n        <span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">ipBlock<\/span><span class=\"token punctuation\">:<\/span><br \/>\n            <span class=\"token key atrule\">cidr<\/span><span class=\"token punctuation\">:<\/span> 0.0.0.0\/0<br \/>\n          <span class=\"token key atrule\">except<\/span><span class=\"token punctuation\">:<\/span><br \/>\n            <span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">ipBlock<\/span><span class=\"token punctuation\">:<\/span><br \/>\n                <span class=\"token key atrule\">cidr<\/span><span class=\"token punctuation\">:<\/span> 10.0.0.0\/16<br \/>\n    <span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">ports<\/span><span class=\"token punctuation\">:<\/span><br \/>\n        <span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">protocol<\/span><span class=\"token punctuation\">:<\/span> TCP<br \/>\n          <span class=\"token key atrule\">port<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token number\">53<\/span><br \/>\n        <span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">protocol<\/span><span class=\"token punctuation\">:<\/span> UDP<br \/>\n          <span class=\"token key atrule\">port<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token number\">53<\/span><\/p>\n<p>\u6b64\u7b56\u7565\u62d2\u7edd\u6240\u6709\u5165\u7ad9\u6d41\u91cf&#xff0c;\u5e76\u4ec5\u5141\u8bb8\u51fa\u7ad9\u6d41\u91cf\u8bbf\u95ee\u96c6\u7fa4\u5185DNS\u670d\u52a1\u3002<\/p>\n<p>\u7f51\u7edc\u7b56\u7565\u5b9e\u65bd\u5e94\u9075\u5faa\u5206\u9636\u6bb5\u539f\u5219&#xff1a;\u9996\u5148\u5728\u6d4b\u8bd5\u547d\u540d\u7a7a\u95f4\u9a8c\u8bc1\u7b56\u7565&#xff0c;\u786e\u8ba4\u7b56\u7565\u751f\u6548\u4e14\u4e0d\u5f71\u54cd\u6b63\u5e38\u529f\u80fd\u540e&#xff0c;\u518d\u9010\u6b65\u6269\u5c55\u5230\u751f\u4ea7\u73af\u5883\u3002\u907f\u514d\u56e0\u7b56\u7565\u914d\u7f6e\u9519\u8bef\u5bfc\u81f4\u96c6\u7fa4\u7f51\u7edc\u4e2d\u65ad\u3002<\/p>\n<h4>\u4e94\u3001RBAC\u6743\u9650\u63a7\u5236\u4e0e\u5ba1\u8ba1<\/h4>\n<p>Kubernetes\u7684RBAC&#xff08;\u57fa\u4e8e\u89d2\u8272\u7684\u8bbf\u95ee\u63a7\u5236&#xff09;\u662f\u5b9e\u73b0\u6743\u9650\u6700\u5c0f\u5316\u7684\u6838\u5fc3\u673a\u5236\u3002\u901a\u8fc7Role\u3001ClusterRole\u3001RoleBinding\u548cClusterRoleBinding&#xff0c;\u53ef\u4e3a\u4e0d\u540c\u7528\u6237\u548c\u670d\u52a1\u8d26\u6237\u5206\u914d\u7cbe\u786e\u7684\u6743\u9650\u3002<\/p>\n<p>\u9996\u5148&#xff0c;\u4e3a\u5f00\u53d1\u4eba\u5458\u521b\u5efa\u6700\u5c0f\u6743\u9650\u89d2\u8272&#xff1a;<\/p>\n<p><span class=\"token key atrule\">apiVersion<\/span><span class=\"token punctuation\">:<\/span> rbac.authorization.k8s.io\/v1<br \/>\n<span class=\"token key atrule\">kind<\/span><span class=\"token punctuation\">:<\/span> Role<br \/>\n<span class=\"token key atrule\">metadata<\/span><span class=\"token punctuation\">:<\/span><br \/>\n  <span class=\"token key atrule\">namespace<\/span><span class=\"token punctuation\">:<\/span> dev<span class=\"token punctuation\">&#8211;<\/span>namespace<br \/>\n  <span class=\"token key atrule\">name<\/span><span class=\"token punctuation\">:<\/span> dev<span class=\"token punctuation\">&#8211;<\/span>namespace<span class=\"token punctuation\">&#8211;<\/span>role<br \/>\n<span class=\"token key atrule\">rules<\/span><span class=\"token punctuation\">:<\/span><br \/>\n<span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">apiGroups<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n  <span class=\"token key atrule\">resources<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;pods&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;services&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n  <span class=\"token key atrule\">verbs<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;get&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;list&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;create&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;update&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;delete&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n<span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">apiGroups<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;apps&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n  <span class=\"token key atrule\">resources<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;deployments&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n  <span class=\"token key atrule\">verbs<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;get&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;list&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;create&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;update&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;delete&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n<span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">apiGroups<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n  <span class=\"token key atrule\">resources<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;configmaps&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n  <span class=\"token key atrule\">verbs<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;get&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;list&#034;<\/span><span class=\"token punctuation\">]<\/span><\/p>\n<p>\u7136\u540e&#xff0c;\u5c06\u89d2\u8272\u7ed1\u5b9a\u5230\u5f00\u53d1\u4eba\u5458&#xff1a;<\/p>\n<p><span class=\"token key atrule\">apiVersion<\/span><span class=\"token punctuation\">:<\/span> rbac.authorization.k8s.io\/v1<br \/>\n<span class=\"token key atrule\">kind<\/span><span class=\"token punctuation\">:<\/span> RoleBinding<br \/>\n<span class=\"token key atrule\">metadata<\/span><span class=\"token punctuation\">:<\/span><br \/>\n  <span class=\"token key atrule\">name<\/span><span class=\"token punctuation\">:<\/span> dev<span class=\"token punctuation\">&#8211;<\/span>namespace<span class=\"token punctuation\">&#8211;<\/span>binding<br \/>\n  <span class=\"token key atrule\">namespace<\/span><span class=\"token punctuation\">:<\/span> dev<span class=\"token punctuation\">&#8211;<\/span>namespace<br \/>\n<span class=\"token key atrule\">subjects<\/span><span class=\"token punctuation\">:<\/span><br \/>\n<span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">kind<\/span><span class=\"token punctuation\">:<\/span> User<br \/>\n  <span class=\"token key atrule\">name<\/span><span class=\"token punctuation\">:<\/span> dev<span class=\"token punctuation\">&#8211;<\/span>team<br \/>\n  <span class=\"token key atrule\">apiGroup<\/span><span class=\"token punctuation\">:<\/span> rbac.authorization.k8s.io<br \/>\n<span class=\"token key atrule\">roleRef<\/span><span class=\"token punctuation\">:<\/span><br \/>\n  <span class=\"token key atrule\">kind<\/span><span class=\"token punctuation\">:<\/span> Role<br \/>\n  <span class=\"token key atrule\">name<\/span><span class=\"token punctuation\">:<\/span> dev<span class=\"token punctuation\">&#8211;<\/span>namespace<span class=\"token punctuation\">&#8211;<\/span>role<br \/>\n  <span class=\"token key atrule\">apiGroup<\/span><span class=\"token punctuation\">:<\/span> rbac.authorization.k8s.io<\/p>\n<p>\u9650\u5236\u9ed8\u8ba4\u8d26\u6237\u6743\u9650\u662f\u5173\u952e\u5b89\u5168\u63aa\u65bd\u3002\u5bf9\u4e8edefault ServiceAccount&#xff0c;\u53ef\u521b\u5efa\u53ea\u8bfb\u89d2\u8272&#xff1a;<\/p>\n<p><span class=\"token key atrule\">apiVersion<\/span><span class=\"token punctuation\">:<\/span> rbac.authorization.k8s.io\/v1<br \/>\n<span class=\"token key atrule\">kind<\/span><span class=\"token punctuation\">:<\/span> Role<br \/>\n<span class=\"token key atrule\">metadata<\/span><span class=\"token punctuation\">:<\/span><br \/>\n  <span class=\"token key atrule\">namespace<\/span><span class=\"token punctuation\">:<\/span> default<br \/>\n  <span class=\"token key atrule\">name<\/span><span class=\"token punctuation\">:<\/span> pod<span class=\"token punctuation\">&#8211;<\/span>reader<span class=\"token punctuation\">&#8211;<\/span>role<br \/>\n<span class=\"token key atrule\">rules<\/span><span class=\"token punctuation\">:<\/span><br \/>\n<span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">apiGroups<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n  <span class=\"token key atrule\">resources<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;pods&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n  <span class=\"token key atrule\">verbs<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;get&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;watch&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;list&#034;<\/span><span class=\"token punctuation\">]<\/span><\/p>\n<p>\u7136\u540e&#xff0c;\u5c06\u53ea\u8bfb\u89d2\u8272\u7ed1\u5b9a\u5230default ServiceAccount&#xff1a;<\/p>\n<p><span class=\"token key atrule\">apiVersion<\/span><span class=\"token punctuation\">:<\/span> rbac.authorization.k8s.io\/v1<br \/>\n<span class=\"token key atrule\">kind<\/span><span class=\"token punctuation\">:<\/span> RoleBinding<br \/>\n<span class=\"token key atrule\">metadata<\/span><span class=\"token punctuation\">:<\/span><br \/>\n  <span class=\"token key atrule\">name<\/span><span class=\"token punctuation\">:<\/span> read<span class=\"token punctuation\">&#8211;<\/span>pods<br \/>\n  <span class=\"token key atrule\">namespace<\/span><span class=\"token punctuation\">:<\/span> default<br \/>\n<span class=\"token key atrule\">subjects<\/span><span class=\"token punctuation\">:<\/span><br \/>\n<span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">kind<\/span><span class=\"token punctuation\">:<\/span> ServiceAccount<br \/>\n  <span class=\"token key atrule\">name<\/span><span class=\"token punctuation\">:<\/span> default<br \/>\n  <span class=\"token key atrule\">namespace<\/span><span class=\"token punctuation\">:<\/span> default<br \/>\n<span class=\"token key atrule\">roleRef<\/span><span class=\"token punctuation\">:<\/span><br \/>\n  <span class=\"token key atrule\">kind<\/span><span class=\"token punctuation\">:<\/span> Role<br \/>\n  <span class=\"token key atrule\">name<\/span><span class=\"token punctuation\">:<\/span> pod<span class=\"token punctuation\">&#8211;<\/span>reader<span class=\"token punctuation\">&#8211;<\/span>role<br \/>\n  <span class=\"token key atrule\">apiGroup<\/span><span class=\"token punctuation\">:<\/span> rbac.authorization.k8s.io<\/p>\n<p>\u5b9a\u671f\u5ba1\u8ba1\u96c6\u7fa4\u8d44\u6e90\u548c\u65e5\u5fd7\u662f\u5b89\u5168\u8fd0\u7ef4\u7684\u91cd\u8981\u73af\u8282\u3002\u53ef\u901a\u8fc7\u4ee5\u4e0b\u6b65\u9aa4\u542f\u7528API Server\u5ba1\u8ba1\u65e5\u5fd7&#xff1a;<\/p>\n<li>\u521b\u5efa\u5ba1\u8ba1\u7b56\u7565\u6587\u4ef6\/etc\/kubernetes\/audit\/audit-policy.yaml&#xff1a;<\/li>\n<p><span class=\"token key atrule\">apiVersion<\/span><span class=\"token punctuation\">:<\/span> audit.k8s.io\/v1<br \/>\n<span class=\"token key atrule\">kind<\/span><span class=\"token punctuation\">:<\/span> Policy<br \/>\n<span class=\"token key atrule\">omitStages<\/span><span class=\"token punctuation\">:<\/span><br \/>\n<span class=\"token punctuation\">&#8211;<\/span> <span class=\"token string\">&#034;RequestReceived&#034;<\/span><br \/>\n<span class=\"token key atrule\">rules<\/span><span class=\"token punctuation\">:<\/span><br \/>\n<span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">level<\/span><span class=\"token punctuation\">:<\/span> RequestResponse<br \/>\n  <span class=\"token key atrule\">verbs<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;delete&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;deletecollection&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;patch&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;update&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n<span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">level<\/span><span class=\"token punctuation\">:<\/span> Metadata<br \/>\n  <span class=\"token key atrule\">verbs<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;get&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;list&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;watch&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n  <span class=\"token key atrule\">users<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;system:kube-proxy&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n<span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">level<\/span><span class=\"token punctuation\">:<\/span> None<br \/>\n  <span class=\"token key atrule\">verbs<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;watch&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n  <span class=\"token key atrule\">users<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;system:kube-proxy&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n  <span class=\"token key atrule\">resources<\/span><span class=\"token punctuation\">:<\/span><br \/>\n  <span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">group<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token string\">&#034;&#034;<\/span><br \/>\n    <span class=\"token key atrule\">resources<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;endpoints&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;services&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n<span class=\"token punctuation\">&#8211;<\/span> <span class=\"token key atrule\">level<\/span><span class=\"token punctuation\">:<\/span> None<br \/>\n  <span class=\"token key atrule\">userGroups<\/span><span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">&#034;system:authenticated&#034;<\/span><span class=\"token punctuation\">]<\/span><br \/>\n  <span class=\"token key atrule\">nonResourceURLs<\/span><span class=\"token punctuation\">:<\/span><br \/>\n  <span class=\"token punctuation\">&#8211;<\/span> <span class=\"token string\">&#034;\/api*&#034;<\/span><br \/>\n  <span class=\"token punctuation\">&#8211;<\/span> <span class=\"token string\">&#034;\/version&#034;<\/span><\/p>\n<li>\u4fee\u6539kube-apiserver\u914d\u7f6e\u6587\u4ef6&#xff1a;<\/li>\n<p><span class=\"token punctuation\">&#8211;<\/span> <span class=\"token punctuation\">&#8211;<\/span><span class=\"token punctuation\">&#8211;<\/span>audit<span class=\"token punctuation\">&#8211;<\/span>policy<span class=\"token punctuation\">&#8211;<\/span>file&#061;\/etc\/kubernetes\/audit\/audit<span class=\"token punctuation\">&#8211;<\/span>policy.yaml<br \/>\n<span class=\"token punctuation\">&#8211;<\/span> <span class=\"token punctuation\">&#8211;<\/span><span class=\"token punctuation\">&#8211;<\/span>audit<span class=\"token punctuation\">&#8211;<\/span>log<span class=\"token punctuation\">&#8211;<\/span>path&#061;\/var\/log\/kubernetes\/audit.log<br \/>\n<span class=\"token punctuation\">&#8211;<\/span> <span class=\"token punctuation\">&#8211;<\/span><span class=\"token punctuation\">&#8211;<\/span>audit<span class=\"token punctuation\">&#8211;<\/span>log<span class=\"token punctuation\">&#8211;<\/span>maxsize&#061;100<br \/>\n<span class=\"token punctuation\">&#8211;<\/span> <span class=\"token punctuation\">&#8211;<\/span><span class=\"token punctuation\">&#8211;<\/span>audit<span class=\"token punctuation\">&#8211;<\/span>log<span class=\"token punctuation\">&#8211;<\/span>maxbackup&#061;5<br \/>\n<span class=\"token punctuation\">&#8211;<\/span> <span class=\"token punctuation\">&#8211;<\/span><span class=\"token punctuation\">&#8211;<\/span>audit<span class=\"token punctuation\">&#8211;<\/span>log<span class=\"token punctuation\">&#8211;<\/span>maxage&#061;30<\/p>\n<li>\u91cd\u542fkubelet\u670d\u52a1\u4f7f\u914d\u7f6e\u751f\u6548&#xff1a;<\/li>\n<p>systemctl restart kubelet<\/p>\n<p>\u5ba1\u8ba1\u65e5\u5fd7\u6587\u4ef6\u4f4d\u4e8e\/var\/log\/kubernetes\/audit.log&#xff0c;\u53ef\u901a\u8fc7\u4ee5\u4e0b\u547d\u4ee4\u67e5\u770b&#xff1a;<\/p>\n<p>kubectl get &#8211;raw \/api\/v1\/namespaces\/kube-system\/pods\/kube-apiserver-<span class=\"token operator\">&lt;<\/span>\u8282\u70b9\u540d\u79f0<span class=\"token operator\">&gt;<\/span>\/log?container<span class=\"token operator\">&#061;<\/span>kube-apiserver<\/p>\n<p>\u5ba1\u8ba1\u65e5\u5fd7\u5206\u6790\u53ef\u901a\u8fc7kube-audit\u7b49\u5de5\u5177\u5b9e\u73b0\u3002\u9996\u5148\u5b89\u88c5kube-audit&#xff1a;<\/p>\n<p>go get -u github.com\/Shopify\/kube-audit<\/p>\n<p>\u7136\u540e\u5206\u6790\u5ba1\u8ba1\u65e5\u5fd7&#xff1a;<\/p>\n<p>kube-audit -f \/var\/log\/kubernetes\/audit.log<\/p>\n<p>\u5b9a\u671f\u5ba1\u8ba1\u6d41\u7a0b\u5efa\u8bae\u5305\u62ec&#xff1a;<\/p>\n<li>\u6bcf\u5468\u68c0\u67e5\u5ba1\u8ba1\u65e5\u5fd7\u4e2d\u7684\u654f\u611f\u64cd\u4f5c&#xff08;\u5982\u8d44\u6e90\u5220\u9664\u3001\u89d2\u8272\u7ed1\u5b9a\u53d8\u66f4&#xff09;\u3002<\/li>\n<li>\u6bcf\u6708\u5ba1\u67e5RBAC\u6743\u9650\u914d\u7f6e&#xff0c;\u786e\u4fdd\u6240\u6709\u8d26\u6237\u548c\u670d\u52a1\u8d26\u6237\u5747\u9075\u5faa\u6700\u5c0f\u6743\u9650\u539f\u5219\u3002<\/li>\n<li>\u6bcf\u5b63\u5ea6\u8fdb\u884c\u5168\u96c6\u7fa4\u5b89\u5168\u8bc4\u4f30&#xff0c;\u4f7f\u7528\u5de5\u5177\u5982kube-bench\u68c0\u67e5Kubernetes\u5b89\u5168\u914d\u7f6e\u3002<\/li>\n<p>\u901a\u8fc7\u4ee5\u4e0a\u63aa\u65bd&#xff0c;\u53ef\u6709\u6548\u76d1\u63a7\u96c6\u7fa4\u4e2d\u7684\u6743\u9650\u4f7f\u7528\u60c5\u51b5&#xff0c;\u53ca\u65f6\u53d1\u73b0\u5e76\u963b\u6b62\u672a\u6388\u6743\u64cd\u4f5c\u3002<\/p>\n<h4>\u516d\u3001\u5b89\u5168\u52a0\u56fa\u7684\u6700\u4f73\u5b9e\u8df5<\/h4>\n<p>\u5728Ubuntu\u4e0a\u90e8\u7f72Kubernetes\u96c6\u7fa4\u65f6&#xff0c;\u5e94\u9075\u5faa\u4ee5\u4e0b\u6700\u4f73\u5b89\u5168\u5b9e\u8df5&#xff1a;<\/p>\n<li>\n<p>\u4f7f\u7528\u4e13\u7528\u7f51\u7edc&#xff1a;\u5c06\u96c6\u7fa4\u8282\u70b9\u90e8\u7f72\u5728\u4e13\u7528\u7f51\u7edc\u4e0a&#xff0c;\u907f\u514d\u76f4\u63a5\u66b4\u9732\u4e8e\u4e92\u8054\u7f51\u3002\u82e5\u5fc5\u987b\u901a\u8fc7\u5916\u7f51\u8bbf\u95eeAPI Server&#xff0c;\u5e94\u914d\u7f6e\u8d1f\u8f7d\u5747\u8861\u5668\u6216\u53cd\u5411\u4ee3\u7406&#xff0c;\u5e76\u901a\u8fc7IP\u767d\u540d\u5355\u9650\u5236\u8bbf\u95ee\u6765\u6e90\u3002<\/p>\n<\/li>\n<li>\n<p>\u542f\u7528Pod\u5b89\u5168\u7b56\u7565&#xff08;PSP&#xff09;&#xff1a;\u867d\u7136Kubernetes 1.25&#043;\u5df2\u5f03\u7528Pod\u5b89\u5168\u7b56\u7565API&#xff0c;\u4f46\u53ef\u901a\u8fc7\u51c6\u5165\u63a7\u5236\u5668&#xff08;\u5982OPA Gatekeeper&#xff09;\u5b9e\u73b0\u7c7b\u4f3c\u529f\u80fd&#xff0c;\u9650\u5236Pod\u7684\u7279\u6743\u64cd\u4f5c\u3002<\/p>\n<\/li>\n<li>\n<p>\u4f7f\u7528\u52a0\u5bc6\u7684Secret&#xff1a;\u654f\u611f\u4fe1\u606f\u5982\u6570\u636e\u5e93\u5bc6\u7801\u3001API\u5bc6\u94a5\u7b49\u5e94\u4f7f\u7528Kubernetes Secret\u5b58\u50a8&#xff0c;\u5e76\u901a\u8fc7kubectl create secret\u547d\u4ee4\u521b\u5efa\u3002<\/p>\n<\/li>\n<li>\n<p>\u5b9a\u671f\u66f4\u65b0\u7cfb\u7edf&#xff1a;\u4fdd\u6301Ubuntu\u7cfb\u7edf\u548cKubernetes\u7ec4\u4ef6\u7684\u6700\u65b0\u7248\u672c&#xff0c;\u53ca\u65f6\u4fee\u590d\u5df2\u77e5\u6f0f\u6d1e\u3002<\/p>\n<\/li>\n<li>\n<p>\u4f7f\u7528\u5b89\u5168\u7684\u5bb9\u5668\u955c\u50cf&#xff1a;\u4ece\u53ef\u4fe1\u6765\u6e90\u83b7\u53d6\u5bb9\u5668\u955c\u50cf&#xff0c;\u5e76\u901a\u8fc7\u955c\u50cf\u626b\u63cf\u5de5\u5177&#xff08;\u5982Trivy\u3001Clair&#xff09;\u68c0\u67e5\u955c\u50cf\u5b89\u5168\u3002<\/p>\n<\/li>\n<li>\n<p>\u5b9e\u65bd\u5b9a\u671f\u5907\u4efd&#xff1a;\u5bf9\u96c6\u7fa4\u5173\u952e\u6570\u636e&#xff08;\u5982etcd\u3001\u8bc1\u4e66&#xff09;\u8fdb\u884c\u5b9a\u671f\u5907\u4efd&#xff0c;\u786e\u4fdd\u5728\u51fa\u73b0\u5b89\u5168\u4e8b\u4ef6\u65f6\u80fd\u591f\u5feb\u901f\u6062\u590d\u3002<\/p>\n<\/li>\n<li>\n<p>\u914d\u7f6e\u76d1\u63a7\u4e0e\u544a\u8b66&#xff1a;\u4f7f\u7528Prometheus\u548cGrafana\u76d1\u63a7\u96c6\u7fa4\u8fd0\u884c\u72b6\u6001&#xff0c;\u8bbe\u7f6e\u544a\u8b66\u89c4\u5219&#xff08;\u5982\u5f02\u5e38API\u8c03\u7528\u3001\u8d44\u6e90\u4f7f\u7528\u5f02\u5e38&#xff09;\u3002<\/p>\n<\/li>\n<li>\n<p>\u4f7f\u7528\u7f51\u7edc\u7b56\u7565\u63d2\u4ef6&#xff1a;\u9664Calico\u5916&#xff0c;\u8fd8\u53ef\u8003\u8651\u4f7f\u7528Cilium\u7b49\u652f\u6301\u66f4\u590d\u6742\u7f51\u7edc\u7b56\u7565\u7684\u63d2\u4ef6&#xff0c;\u5b9e\u73b0\u4e1c\u897f\u5411\u6d41\u91cf\u63a7\u5236\u548c\u96f6\u4fe1\u4efb\u7f51\u7edc\u67b6\u6784\u3002<\/p>\n<\/li>\n<table>\n<tr>\u5b89\u5168\u63aa\u65bd\u5b9e\u65bd\u6b65\u9aa4\u9884\u671f\u6548\u679c<\/tr>\n<tbody>\n<tr>\n<td>\u9632\u706b\u5899\u914d\u7f6e<\/td>\n<td>\u4f7f\u7528UFW\u9650\u5236\u975e\u5fc5\u8981\u7aef\u53e3\u8bbf\u95ee<\/td>\n<td>\u964d\u4f4e\u5916\u90e8\u653b\u51fb\u9762<\/td>\n<\/tr>\n<tr>\n<td>TLS\u542f\u7528<\/td>\n<td>\u901a\u8fc7kubeadm init\u914d\u7f6e\u8bc1\u4e66<\/td>\n<td>\u786e\u4fdd\u63a7\u5236\u5e73\u9762\u901a\u4fe1\u5b89\u5168<\/td>\n<\/tr>\n<tr>\n<td>\u7f51\u7edc\u7b56\u7565<\/td>\n<td>\u90e8\u7f72Calico\u5e76\u914d\u7f6e\u5168\u5c40\u62d2\u7edd\u7b56\u7565<\/td>\n<td>\u5b9e\u73b0Pod\u95f4\u901a\u4fe1\u9650\u5236\u548c\u547d\u540d\u7a7a\u95f4\u9694\u79bb<\/td>\n<\/tr>\n<tr>\n<td>RBAC\u63a7\u5236<\/td>\n<td>\u521b\u5efa\u6700\u5c0f\u6743\u9650\u89d2\u8272\u5e76\u5b9a\u671f\u5ba1\u8ba1<\/td>\n<td>\u786e\u4fdd\u6743\u9650\u6700\u5c0f\u5316\u548c\u4f7f\u7528\u5408\u89c4<\/td>\n<\/tr>\n<tr>\n<td>\u5ba1\u8ba1\u65e5\u5fd7<\/td>\n<td>\u542f\u7528API Server\u5ba1\u8ba1\u65e5\u5fd7\u5e76\u5206\u6790<\/td>\n<td>\u76d1\u63a7\u96c6\u7fa4\u64cd\u4f5c\u884c\u4e3a&#xff0c;\u53ca\u65f6\u53d1\u73b0\u5f02\u5e38<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>\u5b89\u5168\u52a0\u56fa\u662f\u4e00\u4e2a\u6301\u7eed\u7684\u8fc7\u7a0b&#xff0c;\u800c\u975e\u4e00\u6b21\u6027\u4efb\u52a1\u3002\u5efa\u8bae\u5efa\u7acb\u5b89\u5168\u8fd0\u7ef4\u7684SOP&#xff08;\u6807\u51c6\u64cd\u4f5c\u6d41\u7a0b&#xff09;&#xff0c;\u5b9a\u671f\u66f4\u65b0\u5b89\u5168\u7b56\u7565&#xff0c;\u5e94\u5bf9\u4e0d\u65ad\u53d8\u5316\u7684\u5b89\u5168\u5a01\u80c1\u3002<\/p>\n<h4>\u4e03\u3001\u5b89\u5168\u52a0\u56fa\u540e\u7684\u96c6\u7fa4\u9a8c\u8bc1<\/h4>\n<p>\u5b8c\u6210\u5b89\u5168\u52a0\u56fa\u540e&#xff0c;\u9700\u8fdb\u884c\u4ee5\u4e0b\u9a8c\u8bc1\u4ee5\u786e\u4fdd\u914d\u7f6e\u751f\u6548&#xff1a;<\/p>\n<li>\n<p>\u9632\u706b\u5899\u89c4\u5219\u9a8c\u8bc1&#xff1a;\u4f7f\u7528ufw status\u67e5\u770b\u5f53\u524d\u89c4\u5219&#xff0c;\u786e\u8ba4\u4ec5\u5f00\u653e\u5fc5\u8981\u7aef\u53e3\u3002\u901a\u8fc7nc -zv &lt;\u670d\u52a1\u5668IP&gt; &lt;\u7aef\u53e3&gt;\u6d4b\u8bd5\u7aef\u53e3\u8fde\u901a\u6027&#xff0c;\u786e\u4fdd\u975e\u6388\u6743IP\u65e0\u6cd5\u8bbf\u95ee\u53d7\u9650\u7aef\u53e3\u3002<\/p>\n<\/li>\n<li>\n<p>TLS\u901a\u4fe1\u9a8c\u8bc1&#xff1a;\u4f7f\u7528kubectl cluster-info\u68c0\u67e5API Server\u662f\u5426\u901a\u8fc7HTTPS\u8bbf\u95ee\u3002\u8bbf\u95eehttps:\/\/&lt;API Server IP&gt;:6443\u5e76\u68c0\u67e5\u8bc1\u4e66\u662f\u5426\u6709\u6548\u3002<\/p>\n<\/li>\n<li>\n<p>\u7f51\u7edc\u7b56\u7565\u9a8c\u8bc1&#xff1a;\u521b\u5efa\u4e24\u4e2a\u6d4b\u8bd5Pod&#xff0c;\u5206\u522b\u4f4d\u4e8e\u4e0d\u540c\u547d\u540d\u7a7a\u95f4&#xff0c;\u5c1d\u8bd5\u76f8\u4e92\u8bbf\u95ee\u3002\u901a\u8fc7kubectl exec -it &lt;pod\u540d\u79f0&gt; &#8212; ping &lt;\u76ee\u6807pod IP&gt;\u6d4b\u8bd5\u901a\u4fe1\u662f\u5426\u88ab\u7b56\u7565\u963b\u6b62\u3002<\/p>\n<\/li>\n<li>\n<p>RBAC\u6743\u9650\u9a8c\u8bc1&#xff1a;\u4f7f\u7528\u4e0d\u540c\u8d26\u6237\u5c1d\u8bd5\u6267\u884c\u654f\u611f\u64cd\u4f5c&#xff08;\u5982\u521b\u5efa\u547d\u540d\u7a7a\u95f4\u3001\u5220\u9664\u8d44\u6e90&#xff09;&#xff0c;\u786e\u8ba4\u6743\u9650\u63a7\u5236\u662f\u5426\u751f\u6548\u3002<\/p>\n<\/li>\n<li>\n<p>\u5ba1\u8ba1\u65e5\u5fd7\u9a8c\u8bc1&#xff1a;\u68c0\u67e5\u5ba1\u8ba1\u65e5\u5fd7\u6587\u4ef6\/var\/log\/kubernetes\/audit.log&#xff0c;\u786e\u8ba4\u5ba1\u8ba1\u4e8b\u4ef6\u662f\u5426\u88ab\u6b63\u786e\u8bb0\u5f55&#xff0c;\u5e76\u4f7f\u7528kube-audit\u5206\u6790\u65e5\u5fd7\u5185\u5bb9\u3002<\/p>\n<\/li>\n<p>\u901a\u8fc7\u4ee5\u4e0a\u9a8c\u8bc1\u6b65\u9aa4&#xff0c;\u53ef\u786e\u4fdd\u5b89\u5168\u52a0\u56fa\u63aa\u65bd\u5df2\u6b63\u786e\u5b9e\u65bd&#xff0c;\u5e76\u4e3a\u540e\u7eed\u5b89\u5168\u8fd0\u7ef4\u5960\u5b9a\u57fa\u7840\u3002<\/p>\n<h4>\u516b\u3001\u7ed3\u8bba\u4e0e\u5efa\u8bae<\/h4>\n<p>\u5728Ubuntu\u7cfb\u7edf\u4e0a\u90e8\u7f72Kubernetes\u96c6\u7fa4\u65f6&#xff0c;\u5916\u7f51IP\u7684\u5b58\u5728\u589e\u52a0\u4e86\u5b89\u5168\u98ce\u9669&#xff0c;\u9700\u91c7\u53d6\u591a\u5c42\u6b21\u5b89\u5168\u9632\u62a4\u63aa\u65bd\u3002\u4ece\u7cfb\u7edf\u9632\u706b\u5899\u5230TLS\u901a\u4fe1&#xff0c;\u518d\u5230\u7f51\u7edc\u7b56\u7565\u548cRBAC\u6743\u9650\u63a7\u5236&#xff0c;\u6bcf\u4e00\u5c42\u90fd\u81f3\u5173\u91cd\u8981\u3002\u751f\u4ea7\u73af\u5883\u4e2d\u5e94\u9075\u5faa\u6700\u5c0f\u6743\u9650\u539f\u5219&#xff0c;\u5b9a\u671f\u8fdb\u884c\u5b89\u5168\u5ba1\u8ba1\u4e0e\u76d1\u63a7&#xff0c;\u786e\u4fdd\u96c6\u7fa4\u5b89\u5168\u3002<\/p>\n<p>\u5efa\u8bae\u5728\u90e8\u7f72Kubernetes\u96c6\u7fa4\u524d&#xff0c;\u5148\u5b8c\u6210\u57fa\u7840\u7cfb\u7edf\u5b89\u5168\u52a0\u56fa&#xff0c;\u5305\u62ec\u7981\u7528Swap\u3001\u914d\u7f6eNTP\u540c\u6b65\u65f6\u95f4\u7b49\u3002\u7136\u540e&#xff0c;\u901a\u8fc7UFW\u9632\u706b\u5899\u9650\u5236\u975e\u5fc5\u8981\u7aef\u53e3\u8bbf\u95ee&#xff0c;\u4ec5\u5f00\u653eAPI Server\u7b49\u5fc5\u9700\u7aef\u53e3\u3002\u521d\u59cb\u5316\u96c6\u7fa4\u65f6&#xff0c;\u542f\u7528TLS\u5b89\u5168\u901a\u4fe1&#xff0c;\u5e76\u8bbe\u7f6e\u5f15\u5bfctoken\u6709\u6548\u671f\u3002\u90e8\u7f72\u7f51\u7edc\u7b56\u7565\u63d2\u4ef6\u5982Calico&#xff0c;\u5b9e\u65bdPod\u95f4\u901a\u4fe1\u9650\u5236\u548c\u547d\u540d\u7a7a\u95f4\u9694\u79bb\u3002\u6700\u540e&#xff0c;\u914d\u7f6eRBAC\u6743\u9650\u63a7\u5236&#xff0c;\u9650\u5236\u9ed8\u8ba4\u8d26\u6237\u6743\u9650&#xff0c;\u5efa\u7acb\u5b9a\u671f\u5ba1\u8ba1\u4e0e\u65e5\u5fd7\u5206\u6790\u6d41\u7a0b\u3002<\/p>\n<p>\u5b89\u5168\u9632\u62a4\u4e0d\u5e94\u4ec5\u505c\u7559\u5728\u914d\u7f6e\u5c42\u9762&#xff0c;\u800c\u5e94\u5f62\u6210\u6301\u7eed\u7684\u5b89\u5168\u8fd0\u7ef4\u6587\u5316\u3002\u5efa\u8bae\u5b9a\u671f\u53c2\u52a0\u5b89\u5168\u57f9\u8bad&#xff0c;\u5173\u6ce8Kubernetes\u5b89\u5168\u52a8\u6001&#xff0c;\u53ca\u65f6\u66f4\u65b0\u5b89\u5168\u7b56\u7565\u3002\u540c\u65f6&#xff0c;\u5efa\u7acb\u5b89\u5168\u4e8b\u4ef6\u54cd\u5e94\u673a\u5236&#xff0c;\u786e\u4fdd\u5728\u51fa\u73b0\u5b89\u5168\u95ee\u9898\u65f6\u80fd\u591f\u5feb\u901f\u5e94\u5bf9\u548c\u6062\u590d\u3002<\/p>\n<p>\u8bf4\u660e&#xff1a;\u62a5\u544a\u5185\u5bb9\u7531\u901a\u4e49AI\u751f\u6210&#xff0c;\u4ec5\u4f9b\u53c2\u8003\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u6587\u7ae0\u6d4f\u89c8\u9605\u8bfb546\u6b21\uff0c\u70b9\u8d5e3\u6b21\uff0c\u6536\u85cf6\u6b21\u3002\u5728Ubuntu\u7cfb\u7edf\u4e0a\u90e8\u7f72Kubernetes\u96c6\u7fa4\u65f6\uff0c\u82e5\u670d\u52a1\u5668\u62e5\u6709\u5916\u7f51IP\uff0c\u9700\u91c7\u53d6\u591a\u5c42\u6b21\u5b89\u5168\u9632\u62a4\u63aa\u65bd\u4ee5\u786e\u4fdd\u96c6\u7fa4\u5b89\u5168\u3002\u672c\u65b9\u6848\u901a\u8fc7\u7cfb\u7edf\u9632\u706b\u5899\u914d\u7f6e\u3001TLS\u901a\u4fe1\u542f\u7528\u3001\u7f51\u7edc\u7b56\u7565\u5b9e\u65bd\u548cRBAC\u6743\u9650\u63a7\u5236\u56db\u4e2a\u6838\u5fc3\u5c42\u9762\uff0c\u6784\u5efa\u5b89\u5168\u7684Kubernetes\u73af\u5883\u3002\u5b89\u5168\u9632\u62a4\u4e0d\u5e94\u4ec5\u505c\u7559\u5728\u5355\u70b9\u63aa\u65bd\uff0c\u800c\u5e94\u5f62\u6210\u7eb5\u6df1\u9632\u5fa1\u4f53\u7cfb\uff0c\u4ece\u7269\u7406\u4e3b\u673a\u5230\u96c6\u7fa4\u63a7\u5236\u9762\u518d\u5230\u5e94\u7528\u5c42\u8fdb\u884c\u5168\u9762\u4fdd\u62a4\u3002\u5728\u751f\u4ea7\u73af\u5883\u4e2d\uff0c\u9700\u786e\u4fdd\u6240\u6709\u5b89\u5168\u914d\u7f6e\u5747\u7b26\u5408\u6700\u5c0f\u6743\u9650\u539f\u5219\uff0c\u5e76\u5b9a\u671f\u8fdb\u884c\u5ba1\u8ba1\u4e0e\u76d1\u63a7\u3002Ubuntu\u670d\u52a1\u5668\u4f5c\u4e3aKubernetes\u96c6\u7fa4\u8282\u70b9\uff0c\u5176\u57fa\u7840\u7cfb\u7edf\u5b89\u5168\u81f3\u5173\u91cd\u8981\u3002\u9996\u5148\uff0c\u9700\u786e\u4fdd\u7cfb\u7edf\u65f6\u95f4\u540c\u6b65\uff0c\u8fd9<\/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":[120,103,61],"topic":[],"class_list":["post-33387","post","type-post","status-publish","format-standard","hentry","category-server","tag-kubernetes","tag-ubuntu","tag-61"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v20.3 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>Ubuntu K8s\u96c6\u7fa4\u5b89\u5168\u52a0\u56fa\u65b9\u6848 - \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\/33387.html\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Ubuntu K8s\u96c6\u7fa4\u5b89\u5168\u52a0\u56fa\u65b9\u6848 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"og:description\" content=\"\u6587\u7ae0\u6d4f\u89c8\u9605\u8bfb546\u6b21\uff0c\u70b9\u8d5e3\u6b21\uff0c\u6536\u85cf6\u6b21\u3002\u5728Ubuntu\u7cfb\u7edf\u4e0a\u90e8\u7f72Kubernetes\u96c6\u7fa4\u65f6\uff0c\u82e5\u670d\u52a1\u5668\u62e5\u6709\u5916\u7f51IP\uff0c\u9700\u91c7\u53d6\u591a\u5c42\u6b21\u5b89\u5168\u9632\u62a4\u63aa\u65bd\u4ee5\u786e\u4fdd\u96c6\u7fa4\u5b89\u5168\u3002\u672c\u65b9\u6848\u901a\u8fc7\u7cfb\u7edf\u9632\u706b\u5899\u914d\u7f6e\u3001TLS\u901a\u4fe1\u542f\u7528\u3001\u7f51\u7edc\u7b56\u7565\u5b9e\u65bd\u548cRBAC\u6743\u9650\u63a7\u5236\u56db\u4e2a\u6838\u5fc3\u5c42\u9762\uff0c\u6784\u5efa\u5b89\u5168\u7684Kubernetes\u73af\u5883\u3002\u5b89\u5168\u9632\u62a4\u4e0d\u5e94\u4ec5\u505c\u7559\u5728\u5355\u70b9\u63aa\u65bd\uff0c\u800c\u5e94\u5f62\u6210\u7eb5\u6df1\u9632\u5fa1\u4f53\u7cfb\uff0c\u4ece\u7269\u7406\u4e3b\u673a\u5230\u96c6\u7fa4\u63a7\u5236\u9762\u518d\u5230\u5e94\u7528\u5c42\u8fdb\u884c\u5168\u9762\u4fdd\u62a4\u3002\u5728\u751f\u4ea7\u73af\u5883\u4e2d\uff0c\u9700\u786e\u4fdd\u6240\u6709\u5b89\u5168\u914d\u7f6e\u5747\u7b26\u5408\u6700\u5c0f\u6743\u9650\u539f\u5219\uff0c\u5e76\u5b9a\u671f\u8fdb\u884c\u5ba1\u8ba1\u4e0e\u76d1\u63a7\u3002Ubuntu\u670d\u52a1\u5668\u4f5c\u4e3aKubernetes\u96c6\u7fa4\u8282\u70b9\uff0c\u5176\u57fa\u7840\u7cfb\u7edf\u5b89\u5168\u81f3\u5173\u91cd\u8981\u3002\u9996\u5148\uff0c\u9700\u786e\u4fdd\u7cfb\u7edf\u65f6\u95f4\u540c\u6b65\uff0c\u8fd9\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.wsisp.com\/helps\/33387.html\" \/>\n<meta property=\"og:site_name\" content=\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"article:published_time\" content=\"2025-04-27T03:23:14+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=\"6 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/33387.html\",\"url\":\"https:\/\/www.wsisp.com\/helps\/33387.html\",\"name\":\"Ubuntu K8s\u96c6\u7fa4\u5b89\u5168\u52a0\u56fa\u65b9\u6848 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"isPartOf\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\"},\"datePublished\":\"2025-04-27T03:23:14+00:00\",\"dateModified\":\"2025-04-27T03:23:14+00:00\",\"author\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/33387.html#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.wsisp.com\/helps\/33387.html\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/33387.html#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.wsisp.com\/helps\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Ubuntu K8s\u96c6\u7fa4\u5b89\u5168\u52a0\u56fa\u65b9\u6848\"}]},{\"@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":"Ubuntu K8s\u96c6\u7fa4\u5b89\u5168\u52a0\u56fa\u65b9\u6848 - \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\/33387.html","og_locale":"zh_CN","og_type":"article","og_title":"Ubuntu K8s\u96c6\u7fa4\u5b89\u5168\u52a0\u56fa\u65b9\u6848 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","og_description":"\u6587\u7ae0\u6d4f\u89c8\u9605\u8bfb546\u6b21\uff0c\u70b9\u8d5e3\u6b21\uff0c\u6536\u85cf6\u6b21\u3002\u5728Ubuntu\u7cfb\u7edf\u4e0a\u90e8\u7f72Kubernetes\u96c6\u7fa4\u65f6\uff0c\u82e5\u670d\u52a1\u5668\u62e5\u6709\u5916\u7f51IP\uff0c\u9700\u91c7\u53d6\u591a\u5c42\u6b21\u5b89\u5168\u9632\u62a4\u63aa\u65bd\u4ee5\u786e\u4fdd\u96c6\u7fa4\u5b89\u5168\u3002\u672c\u65b9\u6848\u901a\u8fc7\u7cfb\u7edf\u9632\u706b\u5899\u914d\u7f6e\u3001TLS\u901a\u4fe1\u542f\u7528\u3001\u7f51\u7edc\u7b56\u7565\u5b9e\u65bd\u548cRBAC\u6743\u9650\u63a7\u5236\u56db\u4e2a\u6838\u5fc3\u5c42\u9762\uff0c\u6784\u5efa\u5b89\u5168\u7684Kubernetes\u73af\u5883\u3002\u5b89\u5168\u9632\u62a4\u4e0d\u5e94\u4ec5\u505c\u7559\u5728\u5355\u70b9\u63aa\u65bd\uff0c\u800c\u5e94\u5f62\u6210\u7eb5\u6df1\u9632\u5fa1\u4f53\u7cfb\uff0c\u4ece\u7269\u7406\u4e3b\u673a\u5230\u96c6\u7fa4\u63a7\u5236\u9762\u518d\u5230\u5e94\u7528\u5c42\u8fdb\u884c\u5168\u9762\u4fdd\u62a4\u3002\u5728\u751f\u4ea7\u73af\u5883\u4e2d\uff0c\u9700\u786e\u4fdd\u6240\u6709\u5b89\u5168\u914d\u7f6e\u5747\u7b26\u5408\u6700\u5c0f\u6743\u9650\u539f\u5219\uff0c\u5e76\u5b9a\u671f\u8fdb\u884c\u5ba1\u8ba1\u4e0e\u76d1\u63a7\u3002Ubuntu\u670d\u52a1\u5668\u4f5c\u4e3aKubernetes\u96c6\u7fa4\u8282\u70b9\uff0c\u5176\u57fa\u7840\u7cfb\u7edf\u5b89\u5168\u81f3\u5173\u91cd\u8981\u3002\u9996\u5148\uff0c\u9700\u786e\u4fdd\u7cfb\u7edf\u65f6\u95f4\u540c\u6b65\uff0c\u8fd9","og_url":"https:\/\/www.wsisp.com\/helps\/33387.html","og_site_name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","article_published_time":"2025-04-27T03:23:14+00:00","author":"admin","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"admin","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"6 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.wsisp.com\/helps\/33387.html","url":"https:\/\/www.wsisp.com\/helps\/33387.html","name":"Ubuntu K8s\u96c6\u7fa4\u5b89\u5168\u52a0\u56fa\u65b9\u6848 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","isPartOf":{"@id":"https:\/\/www.wsisp.com\/helps\/#website"},"datePublished":"2025-04-27T03:23:14+00:00","dateModified":"2025-04-27T03:23:14+00:00","author":{"@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41"},"breadcrumb":{"@id":"https:\/\/www.wsisp.com\/helps\/33387.html#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.wsisp.com\/helps\/33387.html"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.wsisp.com\/helps\/33387.html#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.wsisp.com\/helps"},{"@type":"ListItem","position":2,"name":"Ubuntu K8s\u96c6\u7fa4\u5b89\u5168\u52a0\u56fa\u65b9\u6848"}]},{"@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\/33387","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=33387"}],"version-history":[{"count":0,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/33387\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/media?parent=33387"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/categories?post=33387"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/tags?post=33387"},{"taxonomy":"topic","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/topic?post=33387"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}