K8s入门篇---centos7下的k8s搭建部署

前言:相信很多的小伙伴想学习k8s,但是都被第一步难住了,那就是k8s的搭建。看了很多的blog,都是要求翻墙,相信痛点不用我讲,大家也都深有感触,那么笔者就不翻墙的环境下,提供一套k8s集群搭建的方案及脚本。(PS:心急的小伙伴,可以直接跳到附录,拿脚本直接一键搭建)

环境要求:centos7系统

1、关闭防火墙及关闭selinux

systemctl disable firewalld
systemctl stop firewalld
setenforce 0

2、配置阿里源

cat >> /etc/yum.repos.d/kubernetes.repo << EOF
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
enabled=1
gpgcheck=0
EOF

3、安装kubernetes

yum install -y docker kubelet-1.11.0-0 kubeadm-1.11.0-0 kubectl-1.11.0-0  kubernetes-cni

4、开启服务

systemctl enable docker && systemctl start docker
systemctl enable kubelet && systemctl start kubelet

5、docker镜像加速

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://43jugwwr.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

6、下载镜像

vi my.sh

新建一个sh文件,内容如下(下载k8s相关镜像,下载后将镜像名改为k8s.gcr.io/开头的名字,以便kubeadm识别使用)

#!/bin/bash
images=(kube-proxy-amd64:v1.11.0 kube-scheduler-amd64:v1.11.0 kube-controller-manager-amd64:v1.11.0 kube-apiserver-amd64:v1.11.0
etcd-amd64:3.2.18 pause-amd64:3.1 kubernetes-dashboard-amd64:v1.8.3 k8s-dns-sidecar-amd64:1.14.8 k8s-dns-kube-dns-amd64:1.14.8
k8s-dns-dnsmasq-nanny-amd64:1.14.8 coredns:1.1.3)
for imageName in ${images[@]} ; do
  docker pull keveon/$imageName
  docker tag keveon/$imageName k8s.gcr.io/$imageName
  docker rmi keveon/$imageName
done
docker tag  k8s.gcr.io/pause-amd64:3.1 k8s.gcr.io/pause:3.1

给权限,并运行

chmod 777 my.sh
./my.sh

7、设置内核参数和禁用swap等

sysctl net.bridge.bridge-nf-call-iptables=1
sysctl net.bridge.bridge-nf-call-ip6tables=1
sudo swapoff -a
rm -rf /var/lib/etcd/

8、初始化master

 kubeadm init --pod-network-cidr=10.244.0.0/16 --kubernetes-version=v1.11.0

9、执行初始化cluster

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

10、cluster机器安装网络(这里我们选择flannel方案,希望使用其他网络支持的小伙伴可以另行选择)

kubectl create -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml

 

至此k8s的master节点创建ok了。worker节点请执行1-7的步骤,然后执行8步骤输出的加入集群命令(如下图)即可。

可通过执行kubectl get nodes命令,查看当前集群node及节点状态。

 

 

附:

按如下脚本创建sh文件,然后赋执行权限,执行即可。(worker节点加入master管理命令不要忘记噢)

1、k8s_master.sh

#!/bin/bash
#关闭防火墙及关闭selinux
systemctl disable firewalld
systemctl stop firewalld
setenforce 0

#配置阿里源
cat >> /etc/yum.repos.d/kubernetes.repo << EOF
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
enabled=1
gpgcheck=0
EOF

#安装kubernetes
yum install -y docker kubelet-1.11.0-0 kubeadm-1.11.0-0 kubectl-1.11.0-0  kubernetes-cni

#开启服务
systemctl enable docker && systemctl start docker
systemctl enable kubelet && systemctl start kubelet

#docker加速
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://43jugwwr.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

#下载镜像
images=(kube-proxy-amd64:v1.11.0 kube-scheduler-amd64:v1.11.0 kube-controller-manager-amd64:v1.11.0 kube-apiserver-amd64:v1.11.0
etcd-amd64:3.2.18 pause-amd64:3.1 kubernetes-dashboard-amd64:v1.8.3 k8s-dns-sidecar-amd64:1.14.8 k8s-dns-kube-dns-amd64:1.14.8
k8s-dns-dnsmasq-nanny-amd64:1.14.8 coredns:1.1.3)
for imageName in ${images[@]} ; do
  docker pull keveon/$imageName
  docker tag keveon/$imageName k8s.gcr.io/$imageName
  docker rmi keveon/$imageName
done
docker tag  k8s.gcr.io/pause-amd64:3.1 k8s.gcr.io/pause:3.1


#设置内核参数
sysctl net.bridge.bridge-nf-call-iptables=1
sysctl net.bridge.bridge-nf-call-ip6tables=1

#禁用swap(虚拟内存)和移除etcd
sudo swapoff -a
yum remove -y etcd
rm -rf /var/lib/etcd/

#初始化master
kubeadm init --pod-network-cidr=10.244.0.0/16 --kubernetes-version=v1.11.0
 
#执行初始化cluster
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config

#cluster机器安装网络
kubectl create -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml










 

 

2、k8s_worker.sh

#!/bin/bash
#关闭防火墙及关闭selinux
systemctl disable firewalld
systemctl stop firewalld
setenforce 0

#配置阿里源
cat >> /etc/yum.repos.d/kubernetes.repo << EOF
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
enabled=1
gpgcheck=0
EOF

#安装kubernetes
yum install -y docker kubelet-1.11.0-0 kubeadm-1.11.0-0 kubectl-1.11.0-0  kubernetes-cni

#开启服务
systemctl enable docker && systemctl start docker
systemctl enable kubelet && systemctl start kubelet

#docker加速
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://43jugwwr.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

#下载镜像
images=(kube-proxy-amd64:v1.11.0 kube-scheduler-amd64:v1.11.0 kube-controller-manager-amd64:v1.11.0 kube-apiserver-amd64:v1.11.0
etcd-amd64:3.2.18 pause-amd64:3.1 kubernetes-dashboard-amd64:v1.8.3 k8s-dns-sidecar-amd64:1.14.8 k8s-dns-kube-dns-amd64:1.14.8
k8s-dns-dnsmasq-nanny-amd64:1.14.8 coredns:1.1.3)
for imageName in ${images[@]} ; do
  docker pull keveon/$imageName
  docker tag keveon/$imageName k8s.gcr.io/$imageName
  docker rmi keveon/$imageName
done
docker tag  k8s.gcr.io/pause-amd64:3.1 k8s.gcr.io/pause:3.1


#设置内核参数
sysctl net.bridge.bridge-nf-call-iptables=1
sysctl net.bridge.bridge-nf-call-ip6tables=1

#禁用swap(虚拟内存)和移除etcd
sudo swapoff -a
yum remove -y etcd
rm -rf /var/lib/etcd/





 

  • 14
    点赞
  • 73
    收藏
    觉得还不错? 一键收藏
  • 14
    评论
要在CentOS 7上部署Kubernetes(K8S),你可以按照以下步骤进行操作: 1. 首先,升级你的CentOS 7系统的内核。你可以参考引用中的链接,了解如何升级内核。 2. 接下来,你需要安装Docker。你可以使用以下命令在CentOS 7上安装Docker: ``` yum install docker -y systemctl start docker systemctl enable docker ``` 3. 安装Kubernetes。你可以使用以下命令在CentOS 7上安装Kubernetes: ``` curl https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg -o /etc/pki/rpm-gpg/RPM-GPG-KEY-kubernetes yum install -y kubelet kubeadm kubectl --disableexcludes=kubernetes systemctl enable kubelet systemctl start kubelet ``` 4. 初始化Kubernetes Master节点。你可以使用以下命令来初始化Kubernetes Master节点: ``` kubeadm init --apiserver-advertise-address=<master节点的IP> ``` 5. 在初始化完成后,会输出一个加入集群的命令,你可以将该命令保存下来,以便后续加入Worker节点。 6. 安装网络插件。在Kubernetes集群中,你需要安装网络插件来实现Pod之间的通信。常用的网络插件有Flannel、Calico等,你可以根据自己的需求选择合适的插件进行安装。 7. 加入Worker节点。在Worker节点上执行1-7步骤,然后使用在第4步中输出的加入集群的命令将Worker节点加入到Kubernetes集群中。 请注意,这只是一个基本的部署过程,具体的操作步骤可能因为不同的环境和需求而有所差异。你可以参考引用和引用中的链接,了解更详细的部署步骤和脚本示例。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值