data:image/s3,"s3://crabby-images/c1e83/c1e8325a2761cfd3fb7685a2c491d1f8ff18315b" alt=""
【前言】本文介绍了Kubernetes基于Centos7构建基础环境,作者:姜新灿(同创永益架构总监)。
环境准备
准备三台虚拟机,每台虚机请参照Kubernetes基于Centos7构建基础环境(一)、Kubernetes基于Centos7构建基础环境(二)进行安装构建
一、 三台虚拟机配置表
1. 服务器配置
data:image/s3,"s3://crabby-images/c9a5c/c9a5c875ffc9a9a87af1e044c46e4c9d6505274f" alt=""
2. 工具版本
docker version: v19.03.11
Kubernetes version: v1.18.2
参考地址kubernetes监控中级方案:kubernetes监控终极方案-kube-promethues - skyflask - 博客园
二、 修改虚机域名
依次修改各个虚拟机域名为master55.xincan.cn、 slave56.xincan.cn、 slave57.xincan.cn
data:image/s3,"s3://crabby-images/61b16/61b1612032ca036552707a013b58207d470d1bdd" alt=""
三、 配置三台机器互相用域名、别名访问
修改/etc/hosts文件设置,3台服务器同时增加如下代码
192.168.1.55 master55.xincan.cn master55
192.168.1.56 slave56.xincan.cn slave56
192.168.1.57 slave57.xincan.cn slave57
data:image/s3,"s3://crabby-images/b1991/b199110bee78bf7d1db7e60c0d07bd0fb0c61c14" alt=""
四、 重启三台虚拟机,执行reboot
分别链接3台服务器,由之前的localhost已经改成服务器别名
data:image/s3,"s3://crabby-images/fcd0c/fcd0c54666adcb2a0a511a9f8fd5a46d695b94d6" alt=""
五、 三台服务器时间同步
1. 3台服务器都安装ntp,提示Complete!则安装成功
data:image/s3,"s3://crabby-images/62ae5/62ae5d4edbcdd77bc8e56abc76a941b765d3c084" alt=""
2. 3台服务器同时设置,查看当前系统时间、并设置当前时间为上海
data:image/s3,"s3://crabby-images/8873f/8873ffe2cb9ef763811cfbaf90872c9a97db8708" alt=""
3. master55配置server ntp.aliyun.com iburst,然后通过sudo systemctl start ntpd启动服
务,稍等一会执行ntpq -p查看是否同步,如果出现前面的*则,同步成功
systemctl start ntpd 启动ntp
systemctl restart ntpd 重启ntp
systemctl enable ntpd.service 开机启动
ntpdc -c loopinfo 查看与时间同步服务器的时间差
data:image/s3,"s3://crabby-images/604d5/604d568f9c4330ae7e2f8568d346b91b316b189a" alt=""
4. slave56、slave57配置master55域名地址server master55.xincan.cn iburst,然后通过sudo
systemctl start ntpd启动服务,稍等一会执行ntpq -p查看是否同步,如果出现前面的*则,同步成功
slave56设置
data:image/s3,"s3://crabby-images/09bd1/09bd10bf6df4a3198929a232998a0cbafaef453c" alt=""
slave57设置
data:image/s3,"s3://crabby-images/f25dd/f25dd49e13651cc8fc629a04a40ef2268bfc40e6" alt=""
六、 三台服务器同时配置kubernetes网桥
设置网桥为值为1
1. master55设置
data:image/s3,"s3://crabby-images/b607a/b607a19c36f478ef384b0a47338d7a5d6b727396" alt=""
2. slave56设置
data:image/s3,"s3://crabby-images/d5d53/d5d53e52e8c5057a8d141f11de1f01eb2b60c545" alt=""
3. slave57设置
data:image/s3,"s3://crabby-images/542a2/542a2635ffa982e9a635a4a78474009bd3551998" alt=""
七、 三台服务器同时配置kubernetes下载源,关闭SELinux
1. master55设置
data:image/s3,"s3://crabby-images/5de8f/5de8f31e1c3b14b3aad69f56d7f9e1d4acbd6c27" alt=""
2. slave56设置
data:image/s3,"s3://crabby-images/a2230/a223016c19c3a4d318d7c3af20bac2fa67fa7774" alt=""
3. slave57设置
data:image/s3,"s3://crabby-images/6e381/6e381a8c91e2029eb3af7c69d5cdab979f81e978" alt=""
八、 查看三台服务器下载源列表,如下成功
data:image/s3,"s3://crabby-images/7cec2/7cec2ad4b1f213b2998317f6b3c86849cb136a58" alt=""
九、 三台服务器设置免密登录
1:manager节点执行:ssh-keygen -t rsa 一路回车到结束,在/root/.ssh/下面会生成一个公钥文件id_rsa.pub
data:image/s3,"s3://crabby-images/0bd14/0bd14556c4698d62ee260ab45ec188ad626bd622" alt=""
2. 将公钥追加到authorized_keys
data:image/s3,"s3://crabby-images/23710/23710454e9ae5e2c45521caff9cf594291727861" alt=""
3. 修改authorized_keys权限:
data:image/s3,"s3://crabby-images/9d433/9d433c46eb52c6cb5ee1dd89337dc2c35023f60d" alt=""
4. 将~/.ssh从master55节点分发到slave56、slave57节点,执行:scp -r ~/.ssh/ root@slave56:~/.ssh/ scp -r ~/.ssh/ root@slave57:~/.ssh/ 过程中需要填写yes,然后提示输入slave56、slave57两个节点的登录密码
data:image/s3,"s3://crabby-images/a7ac4/a7ac433eba55b018bc632e8e4d50beb493e36f11" alt=""
5. 验证master55、slave56、slave57三个节点免密登录
master55节点验证
data:image/s3,"s3://crabby-images/ee58b/ee58b1d5361373f8896a99723b0c5566e1869063" alt=""
slave56节点验证,第一次链接需要输入目标服务密码,后续则不用
data:image/s3,"s3://crabby-images/35dba/35dba29ea31e29cf2767ab731f321093697a17ea" alt=""
slave57节点验证,第一次链接需要输入目标服务密码,后续则不用
data:image/s3,"s3://crabby-images/4b467/4b467df414b42c4e438693f7d3de1140f40747d7" alt=""
十、 三台服务器同时安装kubelet kubeadm kubectl
安装完成之后,启动,并设置开机启动
data:image/s3,"s3://crabby-images/cf3ae/cf3aeb2cfe80f92a588573e2a4c17cca313540e8" alt=""
十一、以master55为Kubernetes主节点进行Kubernetes初始化
1. 执行命令进行初始化
sudo kubeadm init −−image-repository registry.aliyuncs.com/google_containers − −kubernetes-version v1.18.2 −−apiserver-advertise-address 192.168.1.55 −−pod-network−cidr=10.244.0.0/16 −−token-ttl 0
data:image/s3,"s3://crabby-images/9d34e/9d34e97903141fd54cd4745266d908e4a8bcacf4" alt=""
2. 根据初始化提示,在master55节点上执行如下命令
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
data:image/s3,"s3://crabby-images/2b68f/2b68f31c25d4f91028edff66193365042008213d" alt=""
3. 根据初始化提示,在slave56、slave57节点上分别执行如下命令
kubeadm join 192.168.1.55:6443 −−token 991hr9.scqkkyphn1cjjcl7 −−discovery-token-ca�
cert-hash
sha256:1dcf2607e09f83160ce9bc99a941d9a6bd74e99b6b8d3adb63af800ffee19baf
data:image/s3,"s3://crabby-images/9da58/9da58e32ce65234b4fdb390d08e4dce348e7e846" alt=""
十二、Kubernetes命令自动补全(墙裂建议)
data:image/s3,"s3://crabby-images/1bab3/1bab371148f0d23781d106f5655fab58a1a97672" alt=""
十三、k8s查看所有节点
master55节点查看所有节点,当前三台服务器的状态都是NotReady
data:image/s3,"s3://crabby-images/45dfb/45dfbf4ce8a9cdabf6bc6dd71457123a3872d82f" alt=""
十四、k8s查看所有命名空间下所有pod
发现coredns一直处在pending状态,需要安装k8s网络插件
data:image/s3,"s3://crabby-images/623ec/623ec72df285bc312a213ed59b4957c7a73989d4" alt=""
十五、k8s安装网络插件
我们这里选取calico网络插件(提供企业级支持)
1. 在master55节点上创建文件夹,用于存放下载的网络插件,我这里下载的是calico-3.13.1.yaml
data:image/s3,"s3://crabby-images/49034/49034605ddeb2d110a48409bed5cd7773503a2f7" alt=""
2. 安装calico-3.13.1.yaml
data:image/s3,"s3://crabby-images/74d2e/74d2eab0840c5a0aa94f5a5c4fb4bd52754514c1" alt=""
十六、再次查看node和pod
需要等待一会时间
1. 查看nodes,发现状态已经为Ready
data:image/s3,"s3://crabby-images/824ec/824ec7efec7fcd9f38e0e5cfdaf70aaf15bb78e6" alt=""
2. 查看pods,发现状态都为Running
data:image/s3,"s3://crabby-images/e90a3/e90a306bc2b0c9fc8d1e507dd7f6196fe29274e5" alt=""
十七、安装git
data:image/s3,"s3://crabby-images/514d7/514d77e6b376d6a9528a6b0388f9351f1a7952ab" alt=""
十八、kube-promethues部署
1. 下载安装源码,切换到上述创建的k8s目录下,进行git clone https://github.com/coreos/kube-prometheus.git拉取
2. 安装文件都在kube-prometheus/manifests/ 目录下,切换到此目录
data:image/s3,"s3://crabby-images/696fd/696fd3f3212c59abb5df8953b5974074ef21ea11" alt=""
3. 官方把所有文件都放在一起,这里我复制了然后分类下,切换到k8s目录下进行操作
data:image/s3,"s3://crabby-images/ad455/ad4554633ca468d071254c5e8e05c1704b31431b" alt=""
4. 将kube-prometheus/manifests/setup下的文件都复制到/prometheus/operator/下
data:image/s3,"s3://crabby-images/9157e/9157e9000f556b0008d310367c8052596c148f30" alt=""
5. 将prometheus/operator/下0namespace-namespace.yaml文件移动到/k8s/prometheus/下
data:image/s3,"s3://crabby-images/edcae/edcaebc38a5f8200234fd25d024f00a9f766cbcf" alt=""
6. 切换到prometheus/目录下,进行文件归置
data:image/s3,"s3://crabby-images/25d40/25d408e2da2c59495764280e4984943a4592539f" alt=""
7. 注意:新版本的默认label变了,需要修改选择器为beta.kubernetes.io/os,不然安装的时候会卡住,修改选择器
data:image/s3,"s3://crabby-images/dfc7c/dfc7c7527dbfb465e9a7b62e7a889c2c89528d03" alt=""
8. 注意:镜像使用dockerhub上的
data:image/s3,"s3://crabby-images/e2264/e22641e7b1784ac7a91e0fd2678883febe36883f" alt=""
data:image/s3,"s3://crabby-images/b204f/b204f34592f2f4353bf808222e0e2fa27fcd5dcb" alt=""
9. 生成namespace
data:image/s3,"s3://crabby-images/ab247/ab247c7894812b905701a9d7bc9fccc212ad41fb" alt=""
10. 安装operater
data:image/s3,"s3://crabby-images/07af5/07af58ec789e7cebd3bd6a7d001c6cb3b643ec14" alt=""
11. 依次安装其他组件
data:image/s3,"s3://crabby-images/1f778/1f778822222dcc1bae7c978b81bc107856bae881" alt=""
12. 查看整体状态
data:image/s3,"s3://crabby-images/f5aad/f5aada6b76fc5d0dff1935c6328dea1ee8eb9488" alt=""
13. k8s查看所有svc
data:image/s3,"s3://crabby-images/271cd/271cd5d2c994391fcf3923809eb0ddd9c3dbf16a" alt=""
14. k8s暴露grafana外网访问端口
修改type: ClusterIP为 type: NodePort ,默认外网端口NodePort对应的是31533,找到如下代码
data:image/s3,"s3://crabby-images/1aceb/1aceb091071c0e39e2e5d409a90d3a4f0f608db3" alt=""
15. 最终效果图(部分效果图)
data:image/s3,"s3://crabby-images/d1773/d1773ca6e679c6fd6c486553eae32c424403e362" alt=""
data:image/s3,"s3://crabby-images/cb48e/cb48eef19f1f45bf159d76e007dd6d1cbf416791" alt=""
data:image/s3,"s3://crabby-images/b8336/b8336fcd35dce52fa4c0cbf887ffa688ba7c81a8" alt=""
十九、 安装kubernetes-dashboard
下载dashboard所需资源
git clone https://github.com/xincan/kubernetes.git
data:image/s3,"s3://crabby-images/0a4ba/0a4bab9a6adef88d31b37a80ea6352cfe7f41d39" alt=""
二十、 Token令牌登录
data:image/s3,"s3://crabby-images/10868/10868b864529649657a413083fa4ff91e63b0998" alt=""
二十、 KubeConfig登录
data:image/s3,"s3://crabby-images/79d8d/79d8df99eaa648178d8900d07322b184ccf4a291" alt=""
data:image/s3,"s3://crabby-images/aafd1/aafd15d038bbd91ea1f316c38f517966617f46f2" alt=""
data:image/s3,"s3://crabby-images/854b0/854b076735d12b69daab2fef87bfc2ce1a916696" alt=""
网友评论