linux怎么查看本机内存大小
294
2022-10-21
vagrant创建k8s集群
Vagrantfile
Vagrant.configure("2") do |config| (1..3).each do |i| config.vm.define "k8s-node#{i}" do |node| # 设置虚拟机的Box node.vm.box = "centos-7" # 设置虚拟机的主机名 node.vm.hostname="k8s-node#{i}" # 设置虚拟机的IP node.vm.network "private_network", ip: "192.168.56.#{99+i}", netmask: "255.255.255.0" # 设置主机与虚拟机的共享目录 # node.vm.synced_folder "~/Documents/vagrant/share", "/home/vagrant/share" # VirtaulBox相关配置 node.vm.provider "virtualbox" do |v| # 设置虚拟机的名称 v.name = "k8s-node#{i}" # 设置虚拟机的内存大小 v.memory = 4096 # 设置虚拟机的CPU个数 v.cpus = 4 end end endend
开启 root 的密码访问权限,以便用SecureCRT访问
vi /etc/ssh/sshd_config
按i进入输入模式
修改 PasswordAuthentication yes
按esc
输入:wq 退出
设置网络
网卡1是k8s用的网卡,记得重新生成mac地址
SecureCRT打开所有主机共用的窗口
重新启动,ping 相互看能否ping 通
关闭防火墙:
systemctl stop firewalld
systemctl disable firewalld
关闭selinux
sed -i ‘s/enforcing/disabled/’ /etc/selinux/config
setenforce 0
查看 cat /etc/selinux/config 都已设置成功
关闭swap(关闭内存交换)
临时
swapoff -a
永久
sed -ri ‘s/.swap./#&/’ /etc/fstab
验证,swap 必须为 0
free -g
查看 cat /etc/fstab 都已设置成功(注释掉以下红框那句)
添加主机名与IP对应关系
查看主机名 hostname
查看ip addr
批量编辑所有虚拟主机的地址 vi /etc/hosts,按i键进入插入模式,复制如下代码黏贴进去
10.0.2.15 k8s-node1 10.0.2.5 k8s-node2 10.0.2.24 k8s-node3
按:wq
将桥接的IPv4流量传递到iptables的链,更精确统计流量
cat > /etc/sysctl.d/k8s.conf << EOF
net.bridge.bridge-nf-call-ip6tables=1
net.bridge.bridge-nf-call-iptables=1
EOF
sysctl --system 查看应用成功
备份主机
后期有问题,可以停机 恢复备份
安装docker
docker 官方文档 -y install gccyum -y install gcc-c++
卸载旧版本
sudo yum remove docker \ docker-client \ docker-client-latest \ docker-common \ docker-latest \ docker-latest-logrotate \ docker-logrotate \ docker-engine
安装所需软件
sudo yum install -y yum-utils
设置仓库
国外
sudo yum-config-manager \ --add-repo \ yum-config-manager \ --add-repo \ yum install -y docker-ce docker-ce-cli containerd.io
配置阿里云镜像加速
找到 “容器镜像服务”–>“镜像加速器” 菜单
enable docker
启动docker
service docker start
添加阿里云 yum 源
$ cat > /etc/yum.repos.d/kubernetes.repo << EOF[kubernetes]name=Kubernetesbaseurl=kubeadm,kubelet 和 kubectl
yum install -y kubelet-1.17.3 kubeadm-1.17.3 kubectl-1.17.3systemctl enable kubelet systemctl start kubelet
先下载镜像,编写master_images.sh文件
#!/bin/bashimages=( kube-apiserver:v1.17.3 kube-proxy:v1.17.3 kube-controller-manager:v1.17.3 kube-scheduler:v1.17.3 coredns:1.6.5 etcd:3.4.3-0 pause:3.1)for imageName in ${images[@]} ; do docker pull registry.cn-hangzhou.aliyuncs.com/google_containers/$imageName# docker tag registry.cn-hangzhou.aliyuncs.com/google_containers/$imageName k8s.gcr.io/$imageNamedone
注:此文件是master所需的所有镜像,下面遍历循环下载所有镜像
把此文件上传到master节点
如下图master_images.sh文件没有执行权限
改变权限,可读可写可执行 rwx
chmod 700 master_images.sh
执行master_images.sh
./master_images.sh
检查镜像,如下已经都下载成功
docker images
k8s master 初始化
kubeadm init \--apiserver-advertise-address=10.0.2.15 \--image-repository registry.cn-hangzhou.aliyuncs.com/google_containers \--kubernetes-version v1.17.3 \--service-cidr=10.96.0.0/16 \--pod-network-cidr=10.244.0.0/16
1,apiserver-advertise-address 是master的IP,一定要对应自己master的IP
2,image-repository 默认镜像地址 k8s.gcr.io 国内无法访问,指定阿里云镜像仓库地址registry.aliyuncs.com/google_containers
3,service-cidr 无类别域间路由(Classless Inter-Domain Routing、CIDR)是一个用于给用户分配 IP 地址以及在互联网上有效地路由 IP 数据包的对 IP 地址进行归类的方法。 多个pod通过service对外提供服务,相当于对pod的负载均衡
如下提示成功
按照提示,先执行如下代码,启动一个普通用户
mkdir -p $HOME/.kubesudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/configsudo chown $(id -u):$(id -g) $HOME/.kube/config
获取所有节点
kubectl get nodes
注:master 状态为 notready。等待网络加入完成即可。
查看 kubelet 日志
journalctl -u kubelet
准备网络
pod 网络插件安装,我们使用Flannel,apply 是应用kube-flannel.yml中的规定
kubectl apply -f \apply -f kube-flannel.yml
kube-flannel.yml中的flannel:v0.11.0-arm如果下载不了,建议到中找可以用的包,复制,把所有
加入网络
官网网络介绍
join 10.0.2.15:6443 --token knjtlv.pb2ukbpiulht5lbf --discovery-token-ca-cert-hash sha256:ff000d775d41f22b052941dfc07943c2f479f69956faee72e13bc6bbcb41f61a
token 过期怎么办,以下方法生成永久性token
kubeadm token create --print-join-commandkubeadm token create --ttl 0 --print-join-command
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~