热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

CentOS7中怎么搭建kubernetes集群环境

这篇文章给大家介绍CentOS7中怎么搭建kubernetes集群环境,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、服务器环境准备192.

这篇文章给大家介绍CentOS7中怎么搭建kubernetes集群环境,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

一、服务器环境准备

CentOS7中怎么搭建kubernetes集群环境

192.168.247.128 : k8s-master、etcd、registry

192.168.247.129 : k8s-nodeA

192.168.247.130 : k8s-nodeB

CentOS7中怎么搭建kubernetes集群环境

注:安装lsb_release命令:yum install redhat-lsb -y

三台机器配置相同

安装好相同版本的docker:

[root@localhost ~]# docker -v
Docker version 1.12.6, build 85d7426/1.12.6

三台机器上分别修改hostname:

master上运行:

[root@localhost ~]#  hostnamectl --static set-hostname  k8s-master

nodeA上运行:

[root@localhost ~]# hostnamectl --static set-hostname  k8s-nodeA

nodeB上运行:

[root@localhost ~]# hostnamectl --static set-hostname  k8s-nodeB

三台机器上分别配置hosts, 执行如下命令修改hosts文件:

echo '192.168.247.128  k8s-master
192.168.247.128   etcd
192.168.247.128   registry
192.168.247.129   k8s-nodeA
192.168.247.130   k8s-nodeB' >> /etc/hosts

关闭三台机器的防火墙, 三台机器上分别执行:

[root@localhost ~]# systemctl stop firewalld

注:防火墙相关命令:

查看防火墙状态: systemctl status firewalld 

关闭防火墙:systemctl stop firewalld

开启防火墙:systemctl start firewalld

关闭前:

关闭后:

CentOS7中怎么搭建kubernetes集群环境

二、安装etcd

k8s运行依赖etcd,需要先安装etcd, yum方式安装etcd:

在k8s-master上运行:

yum install etcd -y

安装完成后编辑配置文件 , yum安装的etcd默认配置文件在/etc/etcd/etcd.conf

修改如下三个参数值:

CentOS7中怎么搭建kubernetes集群环境

执行如下命令,启动etcd, 并验证状态是否正确 :

[root@localhost ~]# systemctl start etcd

[root@localhost ~]# etcdctl set developer xiejunbo
xiejunbo
[root@localhost ~]# etcdctl get developer
xiejunbo
[root@localhost ~]# etcdctl -C http://etcd:4001 cluster-health
member 8e9e05c52164694d is healthy: got healthy result from http://etcd:2379
cluster is healthy
[root@localhost ~]# etcdctl -C http://etcd:2379 cluster-health
member 8e9e05c52164694d is healthy: got healthy result from http://etcd:2379
cluster is healthy

说明ectd状态健康,可以正常使用。

三、部署k8s-master

安装docker:

yum install docker

修改docker配置文件:vi /etc/sysconfig/docker

CentOS7中怎么搭建kubernetes集群环境

设置docker开机自启动,然后开启docker服务:

[root@localhost ~]# chkconfig docker on

[root@localhost ~]# service docker start

CentOS7中怎么搭建kubernetes集群环境

安装kubernetes : 

使用yum方式安装kubernetes:  yum install kubernetes

CentOS7中怎么搭建kubernetes集群环境

CentOS7中怎么搭建kubernetes集群环境

CentOS7中怎么搭建kubernetes集群环境

kubernetes安装成功后, 配置并启动kubernetes :

在kubernetes master 上运行需要以下组件:

1.kubernetes api server

2.kubernetes controller manager

3.kubernetes scheduler

需要修改相对应的配置文件 :

/etc/kubernetes/apiserver: 修改四个参数:

CentOS7中怎么搭建kubernetes集群环境

/etc/kubernetes/config: 修改一个参数:

CentOS7中怎么搭建kubernetes集群环境

修改完成后,启动服务,然后设置开机自启动:

CentOS7中怎么搭建kubernetes集群环境

[root@localhost ~]# systemctl enable kube-apiserver.service
Created symlink from /etc/systemd/system/multi-user.target.wants/kube-apiserver.service to /usr/lib/systemd/system/kube-apiserver.service.
[root@localhost ~]# systemctl start kube-apiserver.service
[root@localhost ~]# systemctl enable kube-controller-manager.service
Created symlink from /etc/systemd/system/multi-user.target.wants/kube-controller-manager.service to /usr/lib/systemd/system/kube-controller-manager.service.
[root@localhost ~]# systemctl start kube-controller-manager.service
[root@localhost ~]# systemctl enable kube-scheduler.service
Created symlink from /etc/systemd/system/multi-user.target.wants/kube-scheduler.service to /usr/lib/systemd/system/kube-scheduler.service.
[root@localhost ~]# systemctl start kube-scheduler.service

四、部署k8s-node

1.安装docker略

2.nodeA节点安装kubernetes: yum install kubernetes

CentOS7中怎么搭建kubernetes集群环境

CentOS7中怎么搭建kubernetes集群环境

配置并启动kubernetes:

在k8s-node上需要运行以下组件:

1.kubelet

 2.kubernetes proxy

需要对应修改两个配置文件 :

修改/etc/kubernetes/config中的kube_master地址参数:

CentOS7中怎么搭建kubernetes集群环境

修改/etc/kubernetes/kubelet中的三个参数:

CentOS7中怎么搭建kubernetes集群环境

修改完成后,启动服务并设置开机自动启动:

CentOS7中怎么搭建kubernetes集群环境

[root@localhost ~]# systemctl enable kubelet.service
Created symlink from /etc/systemd/system/multi-user.target.wants/kubelet.service to /usr/lib/systemd/system/kubelet.service.
[root@localhost ~]# systemctl start kubelet.service
[root@localhost ~]# systemctl enable kube-proxy.service
Created symlink from /etc/systemd/system/multi-user.target.wants/kube-proxy.service to /usr/lib/systemd/system/kube-proxy.service.
[root@localhost ~]# systemctl start kube-proxy.service

节点启动后,在master上查看状态是否正常:

[root@localhost ~]# kubectl -s http://k8s-master:8080 get node
NAME        STATUS    AGE
k8s-nodea   Ready     2m
[root@localhost ~]# kubectl get nodes
NAME        STATUS    AGE
k8s-nodea   Ready     7m

CentOS7中怎么搭建kubernetes集群环境

在节点k8s-nodeB上按nodeA操作,同样安装kubernetes:

CentOS7中怎么搭建kubernetes集群环境

CentOS7中怎么搭建kubernetes集群环境

安装kubernetes 成功后, 按k8s-nodeA修改配置:

CentOS7中怎么搭建kubernetes集群环境

CentOS7中怎么搭建kubernetes集群环境

修改完配置后,启动服务并设置开机自启动:

[root@localhost ~]# systemctl enable kubelet.service
Created symlink from /etc/systemd/system/multi-user.target.wants/kubelet.service to /usr/lib/systemd/system/kubelet.service.
[root@localhost ~]# systemctl start kubelet.service
[root@localhost ~]# systemctl enable kube-proxy.service
Created symlink from /etc/systemd/system/multi-user.target.wants/kube-proxy.service to /usr/lib/systemd/system/kube-proxy.service.
[root@localhost ~]# systemctl start kube-proxy.service

CentOS7中怎么搭建kubernetes集群环境

在master上查看集群中节点及节点状态:

CentOS7中怎么搭建kubernetes集群环境

五、创建Flannel网络

在k8s-master、k8s-nodeA、k8s-nodeB上均安装Flannel, 执行命令:

yum install flannel

CentOS7中怎么搭建kubernetes集群环境

安装成功后,k8s-master、k8s-nodeA、k8s-nodeB上均修改配置文件为 :/etc/sysconfig/flanneld

CentOS7中怎么搭建kubernetes集群环境

k8s-master中配置etcd中关于flannel的key:

[root@localhost ~]# etcdctl mk /atomic.io/network/config '{"Network":"192.0.0.0/16"}'
{"Network":"192.0.0.0/16"}

特别注意:Flannel使用Etcd进行配置,来保证多个Flannel实例之间的配置一致性,所以需要在etcd上进行如下配置:(‘/atomic.io/network/config’这个key与上文/etc/sysconfig/flannel中的配置项FLANNEL_ETCD_PREFIX是相对应的,错误的话启动就会出错)

CentOS7中怎么搭建kubernetes集群环境

启动Flannel之后,需要依次重启docker、kubernete:

 在master执行:

systemctl enable flanneld.service 
systemctl start flanneld.service 
service docker restart
systemctl restart kube-apiserver.service
systemctl restart kube-controller-manager.service
systemctl restart kube-scheduler.service

在node上执行:

systemctl enable flanneld.service 
systemctl start flanneld.service 
service docker restart
systemctl restart kubelet.service
systemctl restart kube-proxy.service

安装配置完成

===========================================================

检查K8S版本:

CentOS7中怎么搭建kubernetes集群环境

关于CentOS7中怎么搭建kubernetes集群环境就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。


推荐阅读
  • Nginx 反向代理与负载均衡实验
    本实验旨在通过配置 Nginx 实现反向代理和负载均衡,确保从北京本地代理服务器访问上海的 Web 服务器时,能够依次显示红、黄、绿三种颜色页面以验证负载均衡效果。 ... [详细]
  • CentOS系统安装与配置常见问题及解决方案
    本文详细介绍了在CentOS系统安装过程中遇到的常见问题及其解决方案,包括Vi编辑器的操作、图形界面的安装、网络连接故障排除等。通过本文,读者可以更好地理解和解决这些常见问题。 ... [详细]
  • CentOS 7.4 KVM虚拟化平台搭建指南
    本文详细介绍了如何在CentOS 7.4系统上搭建KVM虚拟化平台,包括环境准备、网络配置、KVM安装与管理等步骤,适用于希望利用KVM进行虚拟化部署的技术人员。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 在现代网络环境中,两台计算机之间的文件传输需求日益增长。传统的FTP和SSH方式虽然有效,但其配置复杂、步骤繁琐,难以满足快速且安全的传输需求。本文将介绍一种基于Go语言开发的新一代文件传输工具——Croc,它不仅简化了操作流程,还提供了强大的加密和跨平台支持。 ... [详细]
  • 本文详细介绍了Linux系统中init进程的作用及其启动过程,解释了运行级别的概念,并提供了调整服务启动顺序的具体步骤和实例。通过了解这些内容,用户可以更好地管理系统的启动流程和服务配置。 ... [详细]
  • 本文介绍如何在现有网络中部署基于Linux系统的透明防火墙(网桥模式),以实现灵活的时间段控制、流量限制等功能。通过详细的步骤和配置说明,确保内部网络的安全性和稳定性。 ... [详细]
  • 选择适合生产环境的Docker存储驱动
    本文旨在探讨如何在生产环境中选择合适的Docker存储驱动,并详细介绍不同Linux发行版下的配置方法。通过参考官方文档和兼容性矩阵,提供实用的操作指南。 ... [详细]
  • 本文详细介绍了如何通过RPM包在Linux系统(如CentOS)上安装MySQL 5.6。涵盖了检查现有安装、下载和安装RPM包、配置MySQL以及设置远程访问和开机自启动等步骤。 ... [详细]
  • CentOS 6.5 上安装 MySQL 5.7.23 的详细步骤
    本文详细介绍如何在 CentOS 6.5 系统上成功安装 MySQL 5.7.23,包括卸载旧版本、下载安装包、配置文件修改及启动服务等关键步骤。 ... [详细]
  • 离线安装Grafana Cloudera Manager插件并监控CDH集群
    本文详细介绍如何离线安装Cloudera Manager (CM) 插件,并通过Grafana监控CDH集群的健康状况和资源使用情况。该插件利用CM提供的API接口进行数据获取和展示。 ... [详细]
author-avatar
吖鸟集团总公司
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有