搭建Kubernetes具体流程(下)

Kubernetes(k8s)是自动化容器操作的开源平台,这些操作包括部署,调度和节点集群间扩展。如果你曾经用过Docker容器技术部署容器,那么可以将Docker看成Kubernetes内部使用的低级别组件。Kubernetes不仅仅支持Docker,还支持Rocket,这是另一种容器技术。

安装

yum安装需要的组件,我这里指定了具体的版本,我用的版本比较老,不过如果你是第一次用,问题不是很大,如果是大佬的话就不要喷我了~~~

yum -y install kubeadm-1.11.1  
yum -y install kubectl-1.11.1
yum -y install kubelet-1.11.1
yum -y install kubernetes-cni-0.6.0
yum -y install docker-ce-17.03.0.ce-1.el7.centos

设置docker启动

systemctl enable docker
systemctl start docker
systemctl enable kubelet.service
systemctl start kubelet

这里就是比较艰难的部分了,网上的处理办法大同小异在这里给大家写一下我用的。

kubernetes是Google的,他的镜像托管在Google云上,国内下载比较坎坷,到这个地址去下载https://github.com/anjia0532/gcr.io_mirror 脚本在这里

vim pullimages.sh #这里指定了具体的版本,如果你不是这个版本的需要修改脚本呀~~#!/bin/bash
images=(kube-proxy-amd64:v1.11.1 kube-scheduler-amd64:v1.11.1 kube-controller-manager-amd64:v1.11.1
kube-apiserver-amd64:v1.11.1 etcd-amd64:3.2.18 coredns:1.1.3 pause:3.1 )
for imageName in ${images[@]} ; do
docker pull anjia0532/google-containers.$imageName
docker tag anjia0532/google-containers.$imageName k8s.gcr.io/$imageName
docker rmi anjia0532/google-containers.$imageNamedone

其实呢kubeadm是可以一键部署Master节点的,不过呢为了给大家演示一下集群的搭建,我在这里写了一个kubeadm.yaml

apiVersion: kubeadm.k8s.io/v1alpha1
kind: MasterConfiguration
controllerManagerExtraArgs:
 horizontal-pod-autoscaler-use-rest-clients: "true"
 horizontal-pod-autoscaler-sync-period: "10s"
 node-monitor-grace-period: "10s"
apiServerExtraArgs:
 runtime-config: "api/all=true"
kubernetesVersion: "v1.11.1"

这里将horizontal-pod-autoscaler-use-rest-clients: “true”,这意味者,将来部署的kube-controlller-manger能够使用自定义资源进行自动水平拓展。

部署kunernetes Master节点

kubeadm init --config kubeadm.yaml

这里会生成一大串代码,我摘录一部分放在这里供大家参考

[init] using Kubernetes version: v1.11.1
[preflight] running pre-flight checks
.................
.................
.................
Your Kubernetes master has initialized successfully!

To start using your cluster, you need to run the following as a regular user:

 mkdir -p $HOME/.kube
 sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
 sudo chown $(id -u):$(id -g) $HOME/.kube/config

You should now deploy a pod network to the cluster.
Run "kubectl apply -f [podnetwork].yaml" with one of the options listed at:
 https://kubernetes.io/docs/concepts/cluster-administration/addons/

You can now join any number of machines by running the following on each node
as root:

 kubeadm join 192.168.72.132:6443 --token q1nck1.4znr09ayrj6xpsdw --discovery-token-ca-cert-hash sha256:095e199243fad6ee350beb9869942f54ee4074cd5bcef1222a2cca712b8b4878

这个kubeadm join命令是来给Master节点添加工作节点的命令,当然我这里是单节点肯定是用不上了,不过我还是想给大家解释一下,你们知道就好。

配置安全配置文件的存放目录,这个在上述的代码中有提到,各位可以详细看一下

mkdir -p $HOME/.kube
cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
chown $(id -u):$(id -g) $HOME/.kube/config

为啥要写这个呢?原因是kubernetes集群默认需要加密方式访问,这几条命令的作用在于将刚部署集群的配置文件放在当前用户的.kube目录下啊,kubectl默认使用这个目录下的授权信息访问kubernetes集群。

查看节点状态

[root@localhost yum.repos.d]# kubectl get nodes
NAME                    STATUS     ROLES    AGE   VERSION
localhost.localdomain   NotReady   master   6m    v1.11.1

我这里部署的状态是NotReady,是因为我没有安装网络组件

安装网络插件

kubectl apply -f https://git.io/weave-kube-1.6

部署完成后我们可以通过kubectl重新检查Pod状态

[root@localhost yum.repos.d]# kubectl get pods -n kube-system
NAME                                            READY   STATUS              RESTARTS   AGE
coredns-78fcdf6894-8w8dx                        1/1     Running             0          11m
coredns-78fcdf6894-w9sk2                        1/1     Running             0          11m
etcd-localhost.localdomain                      1/1     Running             0          10m
kube-apiserver-localhost.localdomain            1/1     Running             0          10m
kube-controller-manager-localhost.localdomain   1/1     Running             0          10m
kube-proxy-cpxmx                                1/1     Running             0          11m
kube-scheduler-localhost.localdomain            1/1     Running             0          10m
weave-net-pt2l7                                 2/2     Running             0          23s

这里可以看到我部署的Pod都启动成功了,如果你也能看到这些,那么恭喜你,至此kubernetes Master节点部署完成咯

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/209876.html<

(0)
运维的头像运维
上一篇2025-04-09 16:23
下一篇 2025-04-09 16:24

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注