{"id":7959,"date":"2019-12-06T09:41:43","date_gmt":"2019-12-06T09:41:43","guid":{"rendered":"https:\/\/www.devopsschool.com\/blog\/?p=7959"},"modified":"2021-11-15T09:45:07","modified_gmt":"2021-11-15T09:45:07","slug":"detailed-explaination-of-joining-kubernetes-nodes-aka-workers-in-kubernetes-master","status":"publish","type":"post","link":"https:\/\/www.devopsschool.com\/blog\/detailed-explaination-of-joining-kubernetes-nodes-aka-workers-in-kubernetes-master\/","title":{"rendered":"Detailed explaination of joining Kubernetes Nodes aka workers in Kubernetes master?"},"content":{"rendered":"\n<p><strong>Step 1 &#8211; Install Docker <\/strong><br> https:\/\/www.devopsschool.com\/tutorial\/docker\/install-config\/<br> https:\/\/www.devopsschool.com\/tutorial\/docker\/install-config\/docker-install-commuityedition-centos-rhel.html<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-1\" data-shcb-language-name=\"HTML, XML\" data-shcb-language-slug=\"xml\"><span><code class=\"hljs language-xml\">Here\u2019s the skeleton of a kubeadm join command for a control plane node:\nkubeadm join <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">endpoint-ip-or-dns<\/span>&gt;<\/span>:<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">port<\/span>&gt;<\/span> \\\n--token <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">valid-bootstrap-token<\/span>&gt;<\/span> \\\n--discovery-token-ca-cert-hash <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">ca-cert-sha256-hash<\/span>&gt;<\/span> \\\n--control-plane \\\n--certificate-key <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">certificate-key<\/span>&gt;<\/span>\n\nAnd here\u2019s the skeleton of a kubeadm join command for a worker node:\nkubeadm join <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">endpoint-ip-or-dns<\/span>&gt;<\/span>:<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">port<\/span>&gt;<\/span> \\\n--token <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">valid-bootstrap-token<\/span>&gt;<\/span> \\\n--discovery-token-ca-cert-hash <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">ca-cert-sha256-hash<\/span>&gt;<\/span> \\<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-1\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">HTML, XML<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">xml<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p><strong>Step 2 &#8211; How to find discovery-token-ca-cert-has in kubernetes master node?<\/strong><\/p>\n\n\n\n<p><strong>Mehtod 1 &#8211; Using openssl<\/strong><\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-2\" data-shcb-language-name=\"JavaScript\" data-shcb-language-slug=\"javascript\"><span><code class=\"hljs language-javascript\">\n\nopenssl x509 -<span class=\"hljs-keyword\">in<\/span> \/etc\/kubernetes\/pki\/ca.crt -pubkey -noout | openssl pkey -pubin -outform DER | openssl dgst -sha256\nor\nopenssl x509 -pubkey -<span class=\"hljs-keyword\">in<\/span> \/etc\/kubernetes\/pki\/ca.crt | openssl rsa -pubin -outform der <span class=\"hljs-number\">2<\/span>&gt;<span class=\"hljs-regexp\">\/dev\/<\/span><span class=\"hljs-literal\">null<\/span> | openssl dgst -sha256 -hex | sed <span class=\"hljs-string\">'s\/^.* \/\/'<\/span><\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-2\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">JavaScript<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">javascript<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p><strong>Method 2 &#8211; Using Ansible Python Filter<\/strong><\/p>\n\n\n\n<p>Reference &#8211; https:\/\/gist.github.com\/randomvariable\/e4c43f89afec52fec0dbef6c08621249<\/p>\n\n\n\n<p><strong>Step 3 &#8211; How to Gererate kubeadm join &#8220;kubeadm token&#8221; using kubeadm in master nodes?<\/strong><\/p>\n\n\n\n<p>Bootstrap tokens are used for establishing bidirectional trust between a node joining the cluster and a control-plane node, as described in authenticating with bootstrap tokens. The duration before the token is automatically deleted (e.g. 1s, 2m, 3h). If set to &#8216;0&#8217;, the token will never expire (default 24h0m0s)<\/p>\n\n\n\n<p>Differenece between kubeadm token create and kubeadm token generate<br> &#8220;kubeadm token create&#8221; would Create bootstrap tokens on the server but &#8220;kubeadm token generate&#8221; would Generate and print a bootstrap token, but do not create it on the server. <\/p>\n\n\n\n<p><strong>kubeadm token generate<\/strong><br> This command will print out a randomly-generated bootstrap token that can be used with the \u201cinit\u201d and \u201cjoin\u201d commands. You can also use \u201ckubeadm init\u201d without specifying a token and it will generate and print one for you. The duration before the token is automatically deleted (e.g. 1s, 2m, 3h). If set to &#8216;0&#8217;, the token will never expire (default 24h0m0s)<\/p>\n\n\n\n<p><strong>Create a kubeadm token for 200 hours?<\/strong><br> $ kubeadm token create &#8211;ttl 24h0m0s<\/p>\n\n\n\n<p><strong>Generate a kubeadm token for life time?<\/strong><br> $ kubeadm token create &#8211;ttl 0<\/p>\n\n\n\n<p><strong>Step 4 &#8211; Replace &#8220;172.31.14.69:6443&#8221; with API server.  &#8211;token with kubeadm token and  &#8211;discovery-token-ca-cert-hash and run following.<\/strong><\/p>\n\n\n<pre class=\"wp-block-code\"><span><code class=\"hljs\">\n$ kubeadm join 172.31.14.69:6443 --token w82oxl.jglf7o8s7c2k4u8x --discovery-token-ca-cert-hash sha256:25d17cb97848f19c5ff6a097d5c18d410d41bff9a4b69cb9885be1ad26caeb16\n<\/code><\/span><\/pre>\n\n<div class=\"epyt-gallery\" data-currpage=\"1\" id=\"epyt_gallery_49528\"><iframe loading=\"lazy\"  id=\"_ytid_40649\"  width=\"760\" height=\"427\"  data-origwidth=\"760\" data-origheight=\"427\" src=\"https:\/\/www.youtube.com\/embed\/?enablejsapi=1&#038;autoplay=0&#038;cc_load_policy=0&#038;cc_lang_pref=&#038;iv_load_policy=1&#038;loop=0&#038;rel=1&#038;fs=1&#038;playsinline=0&#038;autohide=2&#038;theme=dark&#038;color=red&#038;controls=1&#038;disablekb=0&#038;\" class=\"__youtube_prefs__  no-lazyload\" title=\"YouTube player\"  data-epytgalleryid=\"epyt_gallery_49528\"  allow=\"fullscreen; accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share\" referrerpolicy=\"strict-origin-when-cross-origin\" allowfullscreen data-no-lazy=\"1\" data-skipgform_ajax_framebjll=\"\"><\/iframe><div class=\"epyt-gallery-list\"><div>Sorry, there was a YouTube error.<\/div><\/div><\/div>","protected":false},"excerpt":{"rendered":"<p>Step 1 &#8211; Install Docker https:\/\/www.devopsschool.com\/tutorial\/docker\/install-config\/ https:\/\/www.devopsschool.com\/tutorial\/docker\/install-config\/docker-install-commuityedition-centos-rhel.html Step 2 &#8211; How to find discovery-token-ca-cert-has in kubernetes master node? Mehtod 1 &#8211; Using openssl Method 2 &#8211; Using Ansible Python Filter&#8230; <\/p>\n","protected":false},"author":1,"featured_media":8204,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_joinchat":[],"footnotes":""},"categories":[4859],"tags":[],"class_list":["post-7959","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-kubernetes"],"_links":{"self":[{"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/posts\/7959","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/comments?post=7959"}],"version-history":[{"count":4,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/posts\/7959\/revisions"}],"predecessor-version":[{"id":25295,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/posts\/7959\/revisions\/25295"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/media\/8204"}],"wp:attachment":[{"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/media?parent=7959"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/categories?post=7959"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/tags?post=7959"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}