{"id":2452,"date":"2022-10-25T17:44:46","date_gmt":"2022-10-25T09:44:46","guid":{"rendered":"https:\/\/199604.com\/?p=2452"},"modified":"2022-10-25T17:44:46","modified_gmt":"2022-10-25T09:44:46","slug":"rke%e6%90%ad%e5%bb%bak8s%e9%9b%86%e7%be%a4helm3%e9%83%a8%e7%bd%b2rancher%e9%ab%98%e5%8f%af%e7%94%a8","status":"publish","type":"post","link":"https:\/\/199604.com\/2452","title":{"rendered":"RKE\u642d\u5efak8s\u96c6\u7fa4&#038;Helm3\u90e8\u7f72Rancher\u9ad8\u53ef\u7528"},"content":{"rendered":"<h1>RKE\u642d\u5efak8s\u96c6\u7fa4&amp;Helm3\u90e8\u7f72Rancher\u9ad8\u53ef\u7528<\/h1>\n<p>\u6b64\u6b21\u662f\uff1a<strong>RKE\u7684\u65b9\u5f0f\u5feb\u901f\u90e8\u7f72K8S\u96c6\u7fa4<\/strong>\uff08https:\/\/199604.com\/2400\uff09\u7684\u8fdb\u4e00\u6b65\u6587\u7ae0<\/p>\n<h2>\u8fd0\u884c\u73af\u5883<\/h2>\n<p>\u673a\u5668\u9700\u8981\u6ee1\u8db3\u4ee5\u4e0b\u51e0\u4e2a\u6761\u4ef6\uff1a<\/p>\n<ol>\n<li>\u4e00\u53f0\u6216\u591a\u53f0\u673a\u5668\uff0c\u64cd\u4f5c\u7cfb\u7edfCentOS7.x-86_64\uff08\u4e2a\u4eba\u9009\u62e9CentOS7.9\uff09<\/li>\n<li>\u786c\u4ef6\u914d\u7f6e\uff1a2GB\u6216\u66f4\u591aRAM\uff0c2\u4e2aCPU\u6216\u66f4\u591aCPU\uff0c\u786c\u76d830GB\u6216\u66f4\u591a<\/li>\n<li>\u96c6\u7fa4\u4e2d\u6240\u6709\u673a\u5668\u4e4b\u95f4\u7f51\u7edc\u4e92\u901a<\/li>\n<li>\u53ef\u4ee5\u8bbf\u95ee\u5916\u7f51\uff0c\u9700\u8981\u62c9\u53d6\u955c\u50cf\uff0c\u5982\u679c\u670d\u52a1\u5668\u4e0d\u80fd\u4e0a\u7f51\uff0c\u9700\u8981\u63d0\u524d\u4e0b\u8f7d\u955c\u50cf\u5e76\u5bfc\u5165\u8282\u70b9<\/li>\n<li>\u7981\u6b62swap\u5206\u533a\uff0c\u53ef\u53c2\u8003\u4e4b\u524d\u4e8c\u8fdb\u5236\u90e8\u7f72k8s\u7684\u524d\u63d0\u73af\u5883<\/li>\n<\/ol>\n<h3>\u670d\u52a1\u5668\u6574\u4f53\u89c4\u5212<\/h3>\n<table>\n<thead>\n<tr>\n<th>\u540d\u79f0<\/th>\n<th>IP<\/th>\n<th>\u7ec4\u4ef6<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>srs103<\/td>\n<td>10.80.210.103<\/td>\n<td>controlplane\u3001worker\u3001etcd\u3001rancher\u3001rke\u3001kubectl<\/td>\n<\/tr>\n<tr>\n<td>srs104<\/td>\n<td>10.80.210.104<\/td>\n<td>controlplane\u3001worker\u3001etcd<\/td>\n<\/tr>\n<tr>\n<td>srs105<\/td>\n<td>10.80.210.105<\/td>\n<td>controlplane\u3001worker\u3001etcd<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h3>\u8f6f\u4ef6\u73af\u5883<\/h3>\n<table>\n<thead>\n<tr>\n<th>\u8f6f\u4ef6<\/th>\n<th>\u7248\u672c<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>docker<\/td>\n<td>20.10.18<\/td>\n<\/tr>\n<tr>\n<td>\u64cd\u4f5c\u7cfb\u7edf<\/td>\n<td>centos 7.9<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h2><strong>\u521d\u59cb\u5316\u73af\u5883\u51c6\u5907<\/strong><\/h2>\n<h3>\u6240\u6709\u673a\u5668\u6267\u884c<\/h3>\n<pre><code class=\"language-shell \">#\u6839\u636e\u89c4\u5212\u8bbe\u7f6e\u4e3b\u673a\u540d\nhostnamectl set-hostname &lt;hostname&gt; #\u5206\u522b\u8bbe\u7f6e\u4e3a srs103\u3001srs104\u3001srs105\nhostname #\u786e\u8ba4\u662f\u5426\u914d\u7f6e\u751f\u6548\n\n# \u5173\u95ed\u9632\u706b\u5899 \u5982\u679c\u662fminimal\u5b89\u88c5\uff0c\u9ed8\u8ba4\u6ca1\u6709\u88c5 firewalld\nsystemctl stop firewalld\nsystemctl disable firewalld\n\n#\u5173\u95edselinux\nsetenforce 0 &amp;&amp; sed -i 's\/^SELINUX=.*\/SELINUX=disabled\/' \/etc\/selinux\/config\n\n#\u5173\u95edswap\nswapoff -a &amp;&amp; sed -i '\/ swap \/ s\/^\\(.*\\)$\/#\\1\/g' \/etc\/fstab\n\n#\u6587\u4ef6\u6570\u8bbe\u7f6e\nulimit -SHn 65535\ncat &gt;&gt; \/etc\/security\/limits.conf &lt;&lt;EOF\n* soft nofile 655360\n* hard nofile 131072\n* soft nproc 655350\n* hard nproc 655350\n* seft memlock unlimited\n* hard memlock unlimitedd\nEOF\n\n#\u5728master\u6dfb\u52a0hosts\ncat &gt;&gt; \/etc\/hosts &lt;&lt; EOF\n10.80.210.103 srs103\n10.80.210.104 srs104\n10.80.210.105 srs105\nEOF\n\n\n#\u5c06\u6865\u63a5\u7684IPv4\u6d41\u91cf\u4f20\u9012\u5230iptables\u7684\u94fe\ncat &gt; \/etc\/sysctl.d\/k8s.conf &lt;&lt; EOF\n#\u5f00\u542f\u7f51\u6865\u6a21\u5f0f\u3010\u91cd\u8981\u3011\nnet.bridge.bridge-nf-call-iptables=1\n#\u5f00\u542f\u7f51\u6865\u6a21\u5f0f\u3010\u91cd\u8981\u3011\nnet.bridge.bridge-nf-call-ip6tables=1\nnet.ipv4.ip_forward=1\nnet.ipv4.tcp_tw_recycle=0\n# \u7981\u6b62\u4f7f\u7528 swap \u7a7a\u95f4\uff0c\u53ea\u6709\u5f53\u7cfb\u7edf OOM \u65f6\u624d\u5141\u8bb8\u4f7f\u7528\u5b83\nvm.swappiness=0\n# \u4e0d\u68c0\u67e5\u7269\u7406\u5185\u5b58\u662f\u5426\u591f\u7528\nvm.overcommit_memory=1\n# \u5f00\u542f OOM\nvm.panic_on_oom=0\nfs.inotify.max_user_instances=8192\nfs.inotify.max_user_watches=1048576\nfs.file-max=52706963\nfs.nr_open=52706963\n#\u5173\u95edipv6\u3010\u91cd\u8981\u3011\nnet.ipv6.conf.all.disable_ipv6=1\nnet.netfilter.nf_conntrack_max=2310720\nEOF\n\n# \u52a0\u8f7d\u7f51\u6865\u8fc7\u6ee4\u6a21\u5757\nmodprobe br_netfilter\n# \u67e5\u770b\u7f51\u6865\u8fc7\u6ee4\u6a21\u5757\u662f\u5426\u6210\u529f\u52a0\u8f7d\nlsmod | grep br_netfilter\n# \u91cd\u65b0\u5237\u65b0\u914d\u7f6e\nsysctl -p \/etc\/sysctl.d\/k8s.conf\n\n\n#\u65f6\u95f4\u540c\u6b65\nyum install ntpdate -y\nntpdate time.windows.com\n#\u6216\u8005\u914d\u7f6ecrontab\u6267\u884c:\n`crontab -e`\n0 *\/1 * * * \/usr\/sbin\/ntpdate ntp1.aliyun.com\n\necho \"0 *\/1 * * * \/usr\/sbin\/ntpdate ntp1.aliyun.com\" &gt;&gt; \/var\/spool\/cron\/root\n\n#\u5173\u95ed\u53ca\u7981\u7528\u90ae\u4ef6\u670d\u52a1\nsystemctl stop postfix &amp;&amp; systemctl disable postfix\n<\/code><\/pre>\n<h2>\u5b89\u88c5Docker<\/h2>\n<p>\u6b65\u9aa4\u5ffd\u7565\uff1a\u53c2\u8003\u4e4b\u524d\u81ea\u5df1\u7684\u90e8\u7f72\u7b14\u8bb0<\/p>\n<p>Docker:https:\/\/199604.com\/2011<\/p>\n<p>Docker-compose(\u4e0d\u9700\u8981\u53ef\u5ffd\u7565):https:\/\/199604.com\/2039<\/p>\n<h2>\u6dfb\u52a0\u521b\u5efa\u666e\u901a\u7528\u6237<\/h2>\n<p>\u4e3a\u4e86\u5b89\u5168\u8d77\u89c1\uff0c\u80fd\u4e0d\u4f7f\u7528 root \u8d26\u53f7\u64cd\u4f5c\u5c31\u4e0d\u4f7f\u7528\uff0c\u56e0\u6b64\u8981\u6dfb\u52a0\u4e13\u7528\u7684\u8d26\u53f7\u8fdb\u884c docker \u64cd\u4f5c\u3002<\/p>\n<p>\u9700\u8981\u5728\u6bcf\u4e2a\u8282\u70b9\u91cd\u590d\u8be5\u64cd\u4f5c\u6dfb\u52a0\u8d26\u53f7<\/p>\n<h3>\u521b\u5efa rancher \u7528\u6237\uff0c\u6dfb\u52a0\u5230 docker \u7ec4<\/h3>\n<pre><code class=\"language-shell \">useradd rancher\n\nusermod -aG docker rancher\n\npasswd rancher\n<\/code><\/pre>\n<h2>RKE\u6240\u5728\u4e3b\u673a\u4e0a\u521b\u5efa\u5bc6\u94a5<\/h2>\n<p>RKE\u6240\u5728\u4e3b\u673a<code>srs103<\/code>\u521b\u5efassh-key,\u6267\u884c<\/p>\n<pre><code class=\"language-shell \">#\u751f\u6210\u7684\u5bc6\u94a5\nssh-keygen\n\n#\u5c06\u6240\u751f\u6210\u7684\u5bc6\u94a5\u7684\u516c\u94a5\u5206\u53d1\u5230\u5404\u4e2a\u8282\u70b9\nssh-copy-id rancher@srs103\nssh-copy-id rancher@srs104\nssh-copy-id rancher@srs105\n<\/code><\/pre>\n<h2>\u91cd\u542f\u6bcf\u53f0\u673a\u5668<\/h2>\n<p>\u6700\u597d\u91cd\u542f\u4e00\u4e0b\u673a\u5668\u3002\u4ee5\u514d\u5e26\u6765\u4e0d\u5fc5\u8981\u7684\u9ebb\u70e6\uff08\u5982\u679c\u65e0\u6cd5\u91cd\u542f\uff0c\u53ef\u5ffd\u7565\uff09<\/p>\n<h2><strong>RKE\u5de5\u5177\u4e0b\u8f7d<\/strong><\/h2>\n<p><strong>srs101\u670d\u52a1\u5668\u6267\u884c<\/strong><\/p>\n<p>\u5177\u4f53\u6700\u65b0\u7248\u672c\u53ef\u770bgithub<\/p>\n<pre><code class=\"language-shell \">curl -L \"https:\/\/github.com\/rancher\/rke\/releases\/download\/v1.3.14\/rke_linux-amd64\" -o \/usr\/local\/bin\/rke\nchmod +x \/usr\/local\/bin\/rke\nln -s \/usr\/local\/bin\/rke \/usr\/bin\/rke\nrke -v\n#rke version v1.3.14\n<\/code><\/pre>\n<h2>\u521d\u59cb\u5316\u914d\u7f6e\u6587\u4ef6\uff08\u7f16\u5199\u914d\u7f6e\u6587\u4ef6\uff09<\/h2>\n<p><strong>srs101\u670d\u52a1\u5668\u6267\u884c<\/strong><\/p>\n<p>\u7f16\u5199<code>rancher-cluster.yml<\/code>\uff08\u6267\u884c\u670d\u52a1\u5668ip:X.X.140.17 \uff09\uff1a<\/p>\n<pre><code class=\"language-yaml \">nodes:\n  - address: 10.80.210.103\n    internal_address: 10.80.210.103\n    user: rancher\n    role: [controlplane,worker,etcd]\n    docker_socket: \/var\/run\/docker.sock\n    ssh_key_path: ~\/.ssh\/id_rsa\n  - address: 10.80.210.104\n    internal_address: 10.80.210.104\n    user: rancher\n    role: [controlplane,worker,etcd]\n    docker_socket: \/var\/run\/docker.sock\n    ssh_key_path: ~\/.ssh\/id_rsa\n  - address: 10.80.210.105\n    internal_address: 10.80.210.105\n    user: rancher\n    role: [controlplane,worker,etcd]\n    docker_socket: \/var\/run\/docker.sock\n    ssh_key_path: ~\/.ssh\/id_rsa\n\nservices:\n  etcd:\n    backup_config:\n      # \u8bbe\u7f6etrue\u542f\u7528ETCD\u81ea\u52a8\u5907\u4efd\uff0c\u8bbe\u7f6efalse\u7981\u7528\n      enabled: true\n      # \u5feb\u7167\u521b\u5efa\u95f4\u9694\u65f6\u95f4\uff0c\u5355\u4f4d\u5c0f\u65f6\n      interval_hours: 6\n      # \u5feb\u7167\u4fdd\u7559\u5929\u6570(\u4ee5\u5929\u4e3a\u5355\u4f4d)\n      retention: 30\n  kubelet:\n    extra_args:\n      max-pods: \"250\"\nkubernetes_version: v1.24.4-rancher1-1\n<\/code><\/pre>\n<blockquote><p>\n  \u8bf7\u53c2\u8003<a class=\"wp-editor-md-post-content-link\" href=\"https:\/\/github.com\/rancher\/rke\/releases\">RKE \u7248\u672c\u8bf4\u660e<\/a>\uff0c\u83b7\u53d6\u60a8\u5f53\u524d\u4f7f\u7528\u7684 RKE \u652f\u6301\u7684 Kubernetes \u7248\u672c\u53f7\u3002<\/p>\n<p>  \u4e5f\u53ef\u4ee5\u8f93\u5165\uff1a<code>rke config --list-version --all<\/code>\uff0c\u5feb\u901f\u83b7\u53d6\u652f\u6301\u7684\u7248\u672c\u53f7\n<\/p><\/blockquote>\n<h2>\u90e8\u7f72\u96c6\u7fa4<\/h2>\n<h3>\u6267\u884c\u547d\u4ee4<\/h3>\n<p><strong>srs101\u670d\u52a1\u5668\u6267\u884c<\/strong><\/p>\n<p><code>rke up<\/code><\/p>\n<pre><code class=\"language-shel \"># rke up\n.....\nINFO[0699] [ingress] ingress controller nginx deployed successfully\nINFO[0699] [addons] Setting up user addons\nINFO[0699] [addons] no user addons defined\nINFO[0699] Finished building Kubernetes cluster successfully\n<\/code><\/pre>\n<p>\u5982\u679c\u62a5\u9519\u5219\u8fdb\u4e00\u6b65\u6392\u67e5\u3002\u53ef\u4ee5\u5f80\u4e0b\u62c9\u9519\u8bef\u96c6\u90a3\u6709\u6ca1\u6709\u548c\u6211\u9047\u5230\u7684\u9519\u8bef\u4e00\u81f4<\/p>\n<p>\u6267\u884c\u6210\u529f\u540e\u5f53\u524d\u76ee\u5f55\u4e0b\u5c06\u4f1a\u591a\u51fa\u4ee5\u4e0b\u6587\u4ef6<\/p>\n<pre><code class=\"language-shell \">[root@srs103 rancher]# tree\n.\n\u251c\u2500\u2500 kube_config_rancher-cluster.yml\n\u251c\u2500\u2500 rancher-cluster.rkestate\n\u2514\u2500\u2500 rancher-cluster.yml\n<\/code><\/pre>\n<ul>\n<li><code>rancher-cluster.yml<\/code>\uff1aRKE \u96c6\u7fa4\u7684\u914d\u7f6e\u6587\u4ef6\u3002<\/li>\n<li><code>kube_config_cluster.yml<\/code>\uff1a\u8be5\u96c6\u7fa4\u7684<a class=\"wp-editor-md-post-content-link\" href=\"https:\/\/docs.rancher.cn\/docs\/rke\/kubeconfig\/_index\">Kubeconfig \u6587\u4ef6<\/a>\u5305\u542b\u4e86\u83b7\u53d6\u8be5\u96c6\u7fa4\u6240\u6709\u6743\u9650\u7684\u8ba4\u8bc1\u51ed\u636e\u3002<\/li>\n<li><code>rancher-cluster.rkestate<\/code>\uff1a<a class=\"wp-editor-md-post-content-link\" href=\"https:\/\/docs.rancher.cn\/docs\/rke\/installation\/_index#Kubernetes-\u96c6\u7fa4\u72b6\u6001\u6587\u4ef6\">Kubernetes \u96c6\u7fa4\u72b6\u6001\u6587\u4ef6<\/a>\uff0c\u5305\u542b\u4e86\u83b7\u53d6\u8be5\u96c6\u7fa4\u6240\u6709\u6743\u9650\u7684\u8ba4\u8bc1\u51ed\u636e\uff0c\u4f7f\u7528 RKE v0.2.0 \u65f6\u624d\u4f1a\u521b\u5efa\u8fd9\u4e2a\u6587\u4ef6\u3002<\/li>\n<\/ul>\n<h2>\u4f7f\u7528kubectl\u547d\u4ee4\u67e5\u770b\u96c6\u7fa4<\/h2>\n<p><strong>srs101\u670d\u52a1\u5668\u6267\u884c<\/strong><\/p>\n<h3>\u4e0b\u8f7dkubectl\u547d\u4ee4\u5de5\u5177<\/h3>\n<p><strong>kubectl\u7248\u672c\u9700\u8981\u4e0ek8s\u7248\u672c\u4e00\u81f4<\/strong><\/p>\n<pre><code class=\"language-shell \">curl -L \"https:\/\/storage.googleapis.com\/kubernetes-release\/release\/v1.24.4\/bin\/linux\/amd64\/kubectl\" -o \/usr\/local\/bin\/kubectl\nchmod +x \/usr\/local\/bin\/kubectl\nln -s \/usr\/local\/bin\/kubectl \/usr\/bin\/kubectl\nkubectl version --client\n<\/code><\/pre>\n<h3>\u914d\u7f6e\u8fde\u63a5\u6587\u4ef6<\/h3>\n<pre><code class=\"language-shell \">mkdir ~\/.kube\ncd \/data\/rancher\ncp kube_config_cluster.yml \/root\/.kube\/\nmv \/root\/.kube\/kube_config_cluster.yml \/root\/.kube\/config\n<\/code><\/pre>\n<h3>\u67e5\u770b\u96c6\u7fa4\u72b6\u6001<\/h3>\n<pre><code class=\"language-shell \">[root@srs103 rancher]# kubectl get nodes -o wide\nNAME            STATUS   ROLES                      AGE   VERSION   INTERNAL-IP     EXTERNAL-IP   OS-IMAGE                KERNEL-VERSION           CONTAINER-RUNTIME\n10.80.210.103   Ready    controlplane,etcd,worker   22h   v1.24.4   10.80.210.103   &lt;none&gt;        CentOS Linux 7 (Core)   3.10.0-1160.el7.x86_64   docker:\/\/20.10.18\n10.80.210.104   Ready    controlplane,etcd,worker   22h   v1.24.4   10.80.210.104   &lt;none&gt;        CentOS Linux 7 (Core)   3.10.0-1160.el7.x86_64   docker:\/\/20.10.18\n10.80.210.105   Ready    controlplane,etcd,worker   22h   v1.24.4   10.80.210.105   &lt;none&gt;        CentOS Linux 7 (Core)   3.10.0-1160.el7.x86_64   docker:\/\/20.10.18\n\n\n[root@srs103 rancher]# kubectl get cs -o wide\nWarning: v1 ComponentStatus is deprecated in v1.19+\nNAME                 STATUS    MESSAGE                         ERROR\netcd-0               Healthy   {\"health\":\"true\",\"reason\":\"\"}\netcd-2               Healthy   {\"health\":\"true\",\"reason\":\"\"}\netcd-1               Healthy   {\"health\":\"true\",\"reason\":\"\"}\nscheduler            Healthy   ok\ncontroller-manager   Healthy   ok\n\n<\/code><\/pre>\n<h2>Helm3\u5b89\u88c5Rancher\u9ad8\u53ef\u7528<\/h2>\n<h3>\u5b89\u88c5Helm3<\/h3>\n<h4>\u4e0b\u8f7d\u5b89\u88c5helm3<\/h4>\n<p><strong>srs101\u670d\u52a1\u5668\u6267\u884c<\/strong><\/p>\n<pre><code class=\"language-shell \">curl -L https:\/\/get.helm.sh\/helm-v3.10.0-linux-amd64.tar.gz -o \/usr\/local\/src\/helm-v3.10.0-linux-amd64.tar.gz\ncd \/usr\/local\/src &amp;&amp; tar -zxvf helm-v3.10.0-linux-amd64.tar.gz\nmv .\/linux-amd64\/helm \/usr\/local\/bin\/helm &amp;&amp; chmod +x \/usr\/local\/bin\/helm\nln -s \/usr\/local\/bin\/helm \/usr\/bin\/helm\nhelm version\n<\/code><\/pre>\n<h3>Helm3\u5b89\u88c5Rancher\u96c6\u7fa4<\/h3>\n<p>\u53c2\u8003\u5b98\u7f51\u6b65\u9aa4\uff1a<code>https:\/\/docs.rancher.cn\/docs\/rancher2\/installation\/install-rancher-on-k8s\/_index<\/code><\/p>\n<p><strong>srs101\u670d\u52a1\u5668\u6267\u884c<\/strong><\/p>\n<h4>\u4f7f\u7528helm repo add\u547d\u4ee4\u6dfb\u52a0Rancher chart\u4ed3\u5e93\u5730\u5740<\/h4>\n<pre><code class=\"language-shell \"># \u56fd\u5185\u7528\u6237\uff0c\u53ef\u4ee5\u4f7f\u7528\u653e\u5728\u56fd\u5185\u7684 Rancher Chart \u52a0\u901f\u5b89\u88c5\nhelm repo add rancher-stable http:\/\/rancher-mirror.oss-cn-beijing.aliyuncs.com\/server-charts\/stable\n# \u5b98\u7f51\u5730\u5740\nhelm repo add rancher-stable https:\/\/releases.rancher.com\/server-charts\/stable\n<\/code><\/pre>\n<h4>\u4e3a Rancher \u521b\u5efa Namespace<\/h4>\n<p>\u6211\u4eec\u9700\u8981\u5b9a\u4e49\u4e00\u4e2a Kubernetes Namespace\uff0c\u5728 Namespace \u4e2d\u5b89\u88c5\u7531 Chart \u521b\u5efa\u7684\u8d44\u6e90\u3002\u8fd9\u4e2a\u547d\u540d\u7a7a\u95f4\u7684\u540d\u79f0\u4e3a<code>cattle-system<\/code>\uff1a<\/p>\n<p><code>kubectl create namespace cattle-system<\/code><\/p>\n<h4>\u9009\u62e9\u60a8\u7684 SSL \u9009\u9879<\/h4>\n<p>\u53c2\u8003\u5b98\u7f51\uff0c\u6709\u4ee5\u4e0b\u4e09\u79cd\uff1a<\/p>\n<ol>\n<li><strong>Rancher \u751f\u6210\u7684\u81ea\u7b7e\u540d\u8bc1\u4e66<\/strong><\/li>\n<li><strong>Let&#8217;s Encrypt<\/strong><\/li>\n<li>\u81ea\u7b7e\u8bc1\u4e66<\/li>\n<\/ol>\n<p>\u56e0\u4e2d\u56fd\u6280\u672f\u56e2\u961f\u5efa\u8bae\u4f7f\u7528<code>\u81ea\u7b7e\u8bc1\u4e66<\/code>,\u6240\u4ee5\u4e5f\u624d\u6709\u6b64\u65b9\u5f0f\u3002\u5176\u4ed6\u4e24\u79cd\u53ef\u53c2\u8003\u5b98\u7f51\u6b65\u9aa4<\/p>\n<h4>\u751f\u6210\u81ea\u7b7e\u8bc1\u4e66<\/h4>\n<p>\u81ea\u7b7e\u8bc1\u4e66\u811a\u672c-\u5b98\u65b9\u751f\u6210\u811a\u672c\uff1a<code>https:\/\/docs.rancher.cn\/docs\/rancher2.5\/installation\/resources\/advanced\/self-signed-ssl\/_index\/#41-%E4%B8%80%E9%94%AE%E7%94%9F%E6%88%90-ssl-%E8%87%AA%E7%AD%BE%E5%90%8D%E8%AF%81%E4%B9%A6%E8%84%9A%E6%9C%AC<\/code><\/p>\n<pre><code class=\"language-shell \">mkdir -p \/data\/rancher\/ca &amp;&amp; cd \/data\/rancher\/ca\n\n.\/create_self-signed-cert.sh --ssl-domain=www.rancher.local --ssl-size=2048 --ssl-date=3650\n<\/code><\/pre>\n<h4>\u6dfb\u52a0 \u81ea\u7b7e\u8bc1\u4e66<\/h4>\n<p>\u4f7f\u7528 <code>kubectl<\/code> \u521b\u5efa <code>tls<\/code> \u7c7b\u578b\u7684\u5bc6\u6587\u3002<\/p>\n<pre><code class=\"language-shell \">kubectl -n cattle-system create secret tls tls-rancher-ingress \\\n  --cert=tls.crt \\\n  --key=tls.key\n<\/code><\/pre>\n<p>\u62f7\u8d1d CA \u8bc1\u4e66\u5230\u540d\u4e3a <code>cacerts.pem<\/code> \u7684\u6587\u4ef6\uff0c\u4f7f\u7528 <code>kubectl<\/code> \u547d\u4ee4\u5728 <code>cattle-system<\/code> \u547d\u540d\u7a7a\u95f4\u4e2d\u521b\u5efa\u540d\u4e3a <code>tls-ca<\/code> \u7684\u5bc6\u6587\u3002<\/p>\n<pre><code class=\"language-shell \">kubectl -n cattle-system create secret generic tls-ca \\\n  --from-file=cacerts.pem=.\/cacerts.pem\n<\/code><\/pre>\n<h4>helm\u5b89\u88c5rancher<\/h4>\n<pre><code class=\"language-shell \">helm install rancher rancher-stable\/rancher \\\n  --namespace cattle-system \\\n  --set hostname=www.rancher.local \\\n  --set bootstrapPassword=\"rancher\" \\\n  --set ingress.tls.source=secret \\\n  --set privateCA=true \\\n  --set replicas=2\n<\/code><\/pre>\n<h4>\u68c0\u67e5\u5b89\u88c5\u8fdb\u5ea6\uff1a<\/h4>\n<pre><code class=\"language-shell \">[root@srs103 ca]# kubectl -n cattle-system get all\nNAME                                   READY   STATUS    RESTARTS        AGE\npod\/rancher-7cdf6968fd-86ph7           1\/1     Running   1 (5h20m ago)   7h6m\npod\/rancher-7cdf6968fd-vdspc           1\/1     Running   4 (5h15m ago)   7h7m\npod\/rancher-webhook-66dcd7db66-strqs   1\/1     Running   0               6h52m\n\nNAME                      TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)          AGE\nservice\/rancher           ClusterIP   10.43.19.253    &lt;none&gt;        80\/TCP,443\/TCP   7h11m\nservice\/rancher-webhook   ClusterIP   10.43.2.238     &lt;none&gt;        443\/TCP          6h52m\nservice\/webhook-service   ClusterIP   10.43.193.244   &lt;none&gt;        443\/TCP          6h52m\n\nNAME                              READY   UP-TO-DATE   AVAILABLE   AGE\ndeployment.apps\/rancher           2\/2     2            2           7h11m\ndeployment.apps\/rancher-webhook   1\/1     1            1           6h52m\n\nNAME                                         DESIRED   CURRENT   READY   AGE\nreplicaset.apps\/rancher-7cdf6968fd           2         2         2       7h11m\nreplicaset.apps\/rancher-webhook-66dcd7db66   1         1         1       6h52m\n\n<\/code><\/pre>\n<p>\u5230\u6b64\uff0c\u6211\u4eec\u5df2\u7ecf\u5b89\u88c5\u5b8c\u4e86\uff01<\/p>\n<p>\u7531\u4e8e\u57df\u540d\u662f\u81ea\u5b9a\u4e49\u7684\uff0c\u6211\u4eec\u9700\u8981\u5728\u81ea\u5df1\u7684windows\u4e0a\u914d\u7f6ehosts\uff1a<\/p>\n<p><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/qn.199604.com\/typoraImg\/image-20221025172854914.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  decoding=\"async\" data-original=\"https:\/\/qn.199604.com\/typoraImg\/image-20221025172854914.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"image-20221025172854914\" \/><\/div><\/p>\n<h2>\u9047\u5230\u95ee\u9898<\/h2>\n<h3>1.\u9047\u5230\u544a\u8b66<code>Warning: networking.k8s.io\/v1beta1 Ingress is deprecated in v1.19+, unavailable in v1.22+; use networking.k8s.io\/v1 Ingress<\/code><\/h3>\n<p>\u6700\u521d\u4f7f\u7528k8s\u7248\u672c\u662f1.20+\uff0c\u9047\u5230ingress\u65e0\u6cd5\u8d1f\u8f7d\u5747\u8861\u7684\u95ee\u9898<\/p>\n<p>\u4e8e\u662f\u6d4b\u8bd5demo\u53d1\u73b0\u662f\u65b0\u7248\u672c\u7684\u8bed\u6cd5\u9519\u8bef\u5bfc\u81f4\u7684<\/p>\n<p><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/qn.199604.com\/typoraImg\/image-20221025173254017.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  decoding=\"async\" data-original=\"https:\/\/qn.199604.com\/typoraImg\/image-20221025173254017.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"image-20221025173254017\" \/><\/div><\/p>\n<p><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/qn.199604.com\/typoraImg\/image-20221025173322633.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  decoding=\"async\" data-original=\"https:\/\/qn.199604.com\/typoraImg\/image-20221025173322633.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"image-20221025173322633\" \/><\/div><\/p>\n<p><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/qn.199604.com\/typoraImg\/image-20221025173331712.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  decoding=\"async\" data-original=\"https:\/\/qn.199604.com\/typoraImg\/image-20221025173331712.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"image-20221025173331712\" \/><\/div><\/p>\n<p>\u4fee\u6539\u6587\u4ef6\u8bf7\u53c2\u8003\u5b98\u65b9\u6587\u6863\uff1a<\/p>\n<blockquote><p>\n  Kubernetes version 1.20+ introduces the networking.k8s.io API version as stable. If you have ingresses that predate K3S 1.20, you have until Kubernetes 1.22 to update them. Until then, if you use old-style ingress definitions, you will receive a warning like Warning: networking.k8s.io\/v1beta1 Ingress is deprecated in v1.19+, unavailable in v1.22+; use networking.k8s.io\/v1 Ingress when you apply the ingress to a cluster.\n<\/p><\/blockquote>\n<p>\u90e8\u7f72\u8fc7\u7a0b\u53c2\u8003\uff1a<\/p>\n<ol>\n<li><code>https:\/\/docs.rancher.cn\/docs\/rancher2.5\/installation\/install-rancher-on-k8s\/_index<\/code><\/li>\n<li><code>https:\/\/www.cnblogs.com\/zoujiaojiao\/p\/15011469.html<\/code><\/li>\n<\/ol>\n","protected":false},"excerpt":{"rendered":"<p>RKE\u642d\u5efak8s\u96c6\u7fa4&amp;Helm3\u90e8\u7f72Rancher\u9ad8\u53ef\u7528 \u6b64\u6b21\u662f\uff1aRKE\u7684\u65b9\u5f0f\u5feb\u901f\u90e8\u7f72K8S\u96c6\u7fa4\uff08ht [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[332,353,260],"tags":[440,352,351,418],"class_list":["post-2452","post","type-post","status-publish","format-standard","hentry","category-docker","category-kubernetes","category-linux","tag-helm","tag-k8s","tag-kubernetes","tag-rke"],"_links":{"self":[{"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/posts\/2452","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/comments?post=2452"}],"version-history":[{"count":1,"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/posts\/2452\/revisions"}],"predecessor-version":[{"id":2453,"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/posts\/2452\/revisions\/2453"}],"wp:attachment":[{"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/media?parent=2452"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/categories?post=2452"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/tags?post=2452"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}