节点基于Libvirt on KVM的openshift4集群创建

怎么创建群  时间:2021-03-20  阅读:()

基于Libvirt on KVM的openshift4集群创建

概览

本文主要介绍了利用开源github社区的Openshift 4的l ibvirt实现来安装一个可以使用的openshift集群以及其中启动、控制和工作节点相关步骤的详细介绍。 [X1]

Openshift分为开源版本和商业版本出于技术交流的目的本文所讨论的都是开源版本主要的代码都在这里。

对比openshift3/4的安装和后续节点管理的工作最重要的区别是针对云的概念的引入从而极大程度的减轻管理员安装配置的负担之前的openshift3所针对的安装环境都是以机器(machine)为对象通过ansible来安装这样不仅复杂而且极易出错而openshift4的Instal ler Provisioned Infrastructure(IPI)所针对的安装环境主要是云所有所需要的资源

例如虚拟机/裸金属机存储网络负载均衡都通过访问云API从而动态获得极大的增加了安装的健壮性和弹性。 目前所支持的cloud列表可以参考支持列表。

Libvirt with KVM instal ler作为一个单机开发的工具可以提供方便的开发环境给开发者同时分析l ibvirt的安装过程也有助于读者深入浅出的理解openshift 4的安装过程以及openshift4内部组件的启动等内容。

基本概念

CoreOS是一个基于Linux内核的轻量级操作系统面向云和集群为主其主要的优势是一致、 安全、 可靠。关于CoreOS具体可以参考官方文档,CoreOS又分为fedora CoreOS 社区版和RHEL CoreOS(商业版)  CoreOS作为云原生操作系统 ignition是其很有特色以及和普通Linux不一样的地方下面这个ignition的实例主要的目的就是将生成的公钥注入部署出的虚拟机里这样当coreos启动之后可以通过公钥对应的私钥ssh登录。 Openshift4中控制节点(master)必须是CoreOS 工作节点(worker)可以是CoreOS。

{

"ignition": {

"config": {},

"timeouts": {},

"version": "2.1 .0"

},

"networkd": {},

"passwd": {

"users": [

{

"sshAuthorizedKeys": [

"ssh-rsa ABCD. . ."

]

}

]

},

….

}

Operator:简化应用程序部署和生命周期管理——自动化的执行应用程序维护扩展故障转移等工作,openshift 4的控制面几乎都建立在operator之上关于operator可以参考概念介绍如果读者对Operater的概念不是很理解也可以参考这里的实验教程。Cluster API :ClusterAPI是一个Kubernetes之上的可选项目 它使用Kuber ne tes的扩展机制(Custom Resource Definition)来创建、配置和管理集群(Cluster) 。关于ClusterAPI的用况范围等内容可以参考这篇和这篇文章 Cluster API作为通用的Kubernetes集群管理框架有许多不同种类的云提供商都以ClusterAPI为基础您可从此处获取云提供商的完整列表。 Openshift instal ler基于Cluster API的Kubernetes版本做了一定修改来创建工作节点。

Terraform:一种构建、更改和版本控制基础设施的工具(Infrastructure as code) 针对业界几乎所有的云平台都有自己的实现例如aws,openstack; l ibvirt等也有自己的provider实现 l ibvirt的实现一般只是拿来作为开发和测试使用的  openshift instal ler的l ibvirt安装方法现在使用terraform的l ibvirt实现来完成基于l ibvirt集群的控制面创建(bootstrap节点 master节点) 而worker节点则是通过Cluster API l ibvirt来安装的。从开发和测试的角度来说如果本地有机器通过l ibvirt创建开发环境是最经济和方便的。

环境准备

笔者使用的是RHEL7.6 请准备好基本和扩展的yum源以备安装时使用  另外默认的l ibvirt会创建至少三个虚拟机 bootstrap启动节点 master节点工作节点 而每个虚拟机的内存默认为6G 所以主机至少配置24G内存以上保证工作。

安装和更新必要的软件

首先[X2] 需要安装必要的文件这些包作为编译的依赖如果不安装在编译过程中会出现错误

# yum -y install gcc gcc-c++ automake libtool zlib-devel glib2-devel bzip2-devel libuuid-devel spice-protocol spice-server-devel usbredir-devel libaio-devel golang-bin

如果找不到golang-bin 可以考虑从golang官网直接搜索golang的可执行文件并把golang可执行文件放在目录。

qemu更新

笔者的RHEL7.6环境下默认的qemu版本是1 .5.3 然而由于openshift 4 l ibvirt使用了fw_cfg设备来完成ingition的初始化而该版本的qemu是不支持fw_cfg的 如果不更新q e m u的话在安装过程中由于不能创建fw_cfg设备会遇到错误所以需要通过使能kvm-common这个源来更新qemu-kvm,具体请参考这里。

编译**openshift-instal ler**

从github下载openshift-instal l er 编译openshift-instal ler 由于l ibvirt是开发和测试使用的所以默认编译之后所支持的安装列表是不支持l ibvirt的需要加入TAGS=l ibvirt这个tag从而在编译过程来加入l ibvirt支持。

[root@jj-instal ler instal ler]#TAGS=l ibvirt hack/bui ld.sh

• minimum_go_version=1 .12

++go version

++cut -d' ' -f 3

• current_go_version=go1 .12.9

++version 1 .12.9

++IFS=.

++printf'%03d%03d%03dn' 1 129

++unset IFS

++version 1 .12

++IFS=.

++printf'%03d%03d%03dn' 1 12

++unset IFS

• '['001012009-lt 001012000']'

• LAUNCH_PATH=/root/go/src/github.com/openshift/instal ler

++dirname hack/bui ld.sh

• cd hack/. .

++go l ist -e-f'{{.Dir}}'github.com/openshift/instal ler

• PACKAGE_PATH=/root/go/src/github.com/openshift/instal ler

• test -z/root/go/src/github.com/openshift/instal ler

• LOCAL_PATH=/root/go/src/github.com/openshift/instal ler

• test /root/go/src/github.com/openshift/instal ler ' !='

/root/go/src/github.com/openshift/instal ler

• MODE=release

++git rev-parse--verify'HEAD^{commit}'

• GIT_COMMIT=d70ea3ee878a6c09ae309d614746107f05f207b5

++git describe--always--abbrev=40--dirty

• GIT_TAG=unreleased-master-2274-gd70ea3ee878a6c09ae309d614746107f05f207b5

• LDFLAGS=' -X github.com/openshift/instal ler/pkg/version.Raw=unreleased-master-2274-gd70ea3ee878a6c09ae309d614746107f05f207b5-Xgithub.com/openshift/instal ler/pkg/version.Commit=d70ea3ee878a6c09ae309d614746107f05f207b5'

• TAGS=l ibvirt

• OUTPUT=bin/openshift-instal l

• export CGO_ENABLED=0

• CGO_ENABLED=0

• case"${MODE}" in

• LDFLAGS=' -X github.com/openshift/instal ler/pkg/version.Raw=unreleased-master-2274-gd70ea3ee878a6c09ae309d614746107f05f207b5-Xgithub.com/openshift/instal ler/pkg/version.Commit=d70ea3ee878a6c09ae309d614746107f05f207b5-s-w'

• TAGS=' l ibvirt release'

• test

• go generate./datawriting assets_vfsdata.go

• echo' l ibvirt release'

• grep-q l ibvirt

• export CGO_ENABLED=1

• CGO_ENABLED=1

• go bui ld-ldflags' -X github.com/openshift/instal ler/pkg/version.Raw=unreleased-master-2274-gd70ea3ee878a6c09ae309d614746107f05f207b5-Xgithub.com/openshift/instal ler/pkg/version.Commit=d70ea3ee878a6c09ae309d614746107f05f207b5-s-w' -tags' l ibvirt release' -o bin/openshift-instal l ./cmd/openshift-instal l

修改**l ibvirt**配置

由于默认l ibvirt的tcp端口没有打开因此需要通过修改l ibvirt daemon的配置来打开TCP连接端口(16509) 。

需要修改如下文件

/etc/l ibvirt/l ibvirtd.conf l isten_tls=0l isten_tcp=1auth_tcp="none"tc p_po rt="16509"

/etc/sysconfig/l ibvirtd LIBVIRTD_ARGS="--l isten"

重启l ibvirtd服务systemctl restart l ibvirtd确认l ibvirtd在16509端口上监听tcp请求 [root@jj-instal lerinstal ler]#netstat -tlunp|grep l ibvirttcp 000.0.0.0:165090.0.0.0:*LISTEN 3696/l ibvirtd

安装集群

到现在为止我们已经完成了所有的安装准备下面可以开始安装openshift集群了:使用如下命令我们会被要求提供一定的输入具体的参数选择如下:

[root@jj-instal ler instal ler]#bin/openshift-instal l create cluster

?SSH Publ ic Key/root/.ssh/id_rsa.pub

?Platform l ibvirt

?Libvirt Connection URI qemu+tcp://192.168.122.1/system

?Base Domain tt.testing

?Cluster Name test1

?Pul l Secret [?for help

INFO Fetching OS image: rhcos-42.80.20190827.1-qemu.qcow2***

INFO Creating infrastructure resources. . .

INFO Waiting up to 30m0s for the Kubernetes API at https://api .test1 .aa.testing:6443. . .Ssh publ ic key:如果选择了某个公钥(publ ic key)文件该公钥文件会通过Ignition被注入部署出来的CoreOS机器这样当遇到需要登录CoreOS的时候例如调试等可以通过ssh的方式来登录该Co reOS,该方法主要是开发测试中使用。

Platform:选择l ibvirt平台 如果前面编译的时候没有增加TAGS=l ibvirt 这里就不会出现l ibvirt的选项。

Libvirt connection URI :Libvirt连接URI 默认是qemu+tcp://192.168.122.1/system,除非运行instal ler的节点和运行l ibvirtd 也就是集群运行的节点不同 这个参数我们可以选择默认参数如果存在不同节点的情况例如instal ler是x86平台而l ibvirtd是I BMsystem z平台 可以调整该参数。

Base Domain:基本域名。

Cluster Name:集群名字 Base Domain和Cluster Name会在集群的Ingress/Router中使用。

Pul l Secret:请使用‘?’搜索如果没有的话需要访问这里并获取一个令牌(Token) 。集群安装过程分析

首先openshift instal ler会使用terraform 通过terraform l ibvirt provider 通过l ibvirt来创建两台虚拟机其中一个是启动节点 bootstrap  另一个是控制节点(master) 而terraform在创建虚拟机过程中的参数是根据上述准备过程用户输入生成的当然也可以根据实际需要修改很多默认值例如默认工作节点数量是1  本文不再赘述。当虚拟机创建完成之后可以观察到虚拟机情况如下所示在笔者的环境中使用了test1作为集群的名字 bootstrap代表启动节点 master代表控制节点。

[root@jj-instal ler~]#virsh l ist --al l

Id Name State

1 1 test1-gbvhv-bootstrap running

13 test1-gbvhv-master-0 running

虚拟机创建完成之后我们可以通过virsh console命令登入bootstrap和master节点在bootstrap和master的启动阶段会执行ignition从而完成所有的配置和初始化工作。[X3]

首先进入Bootstrap节点请注意这个IP 192.168.126.10是固定的 并且由于在笔者的环境中选择了注

入ssh publ ic key 这样当ingition完成之后我们可以通过私钥(private key)无密码访问bootstrap节点。

[root@jj-instal ler~]#ssh core@192.168.126.10

Warning:Permanently added'192.168.126.10' (ECDSA) to the l ist of known hosts.Red Hat Enterprise Linux CoreOS 42.80.20190827.1

WARNING:Direct SSH access to machines is not recommended.

This is the bootstrap node; itwi l l be destroyed when the master is ful ly up.

The primary service is"bootkube.service".To watch its status, run e.g.journalctl -b-f-u bootkube.service

[core@test1-vrq ms-bootstrap~]$

Bootstrap节点启动日志节选 通过journalctl -b-f-u bootkube.service查看 。Sep 0308:30:36 test1-gbvhv-bootstrap systemd[1]:Started Bootstrap a Kubernetescluster.

Sep 0308:31 :06 test1-gbvhv-bootstrap bootkube.sh[1624]:Rendering Cluster VersionOperator Manifests. . .

Sep 0308:31 :28 test1-gbvhv-bootstrap bootkube.sh[1624]:Rendering cluster configmanifests. . .

Sep 0308:31 :36 test1-gbvhv-bootstrap bootkube.sh[1624]:Rendering Kubernetes APIserver core manifests. . .

GigsGigsCloud:$16/月KVM-1GB/30GB/1TB/1.6T高防/洛杉矶CN2 GIA+AS9929

GigsGigsCloud是一家成立于2015年老牌国外主机商,提供VPS主机和独立服务器租用,数据中心包括美国洛杉矶、中国香港、新加坡、马来西亚和日本等。商家VPS主机基于KVM架构,绝大部分系列产品中国访问速度不错,比如洛杉矶机房有CN2 GIA、AS9929及高防线路等。目前Los Angeles - SimpleCloud with Premium China DDOS Protectio...

A400:36元/季,16.8/月kvm架构,线路优质,延迟低

A400互联是一家成立于2020年的商家,主要推行洛杉矶服务器采用kvm架构,线路优质,延迟低,稳定性高!全场产品对标腾讯云轻量,服务器线路有有美国洛杉矶cn2_gia、香港cn2+cmi,目前推行的vps服务器均为精心挑选的优质线路机房,A400互联推出了夏季优惠洛杉矶5折、香港7折促销活动,质量可靠,价格实惠!二:优惠码洛杉矶五折优惠码:20210620香港cn2七折优惠码:0710三、优惠方...

DiyVM:香港VPS五折月付50元起,2核/2G内存/50G硬盘/2M带宽/CN2线路

diyvm怎么样?diyvm这是一家低调国人VPS主机商,成立于2009年,提供的产品包括VPS主机和独立服务器租用等,数据中心包括香港沙田、美国洛杉矶、日本大阪等,VPS主机基于XEN架构,均为国内直连线路,主机支持异地备份与自定义镜像,可提供内网IP。最近,DiyVM商家对香港机房VPS提供5折优惠码,最低2GB内存起优惠后仅需50元/月。点击进入:diyvm官方网站地址DiyVM香港机房CN...

怎么创建群为你推荐
internalservererrorinternal server errorcisco2960cisco 2960 和3560字节跳动回应TikTok易主#北京字节跳动科技有限公司#小说审核有三面么?我面试了两轮就叫我回家等消息了 要是刷下来了也该告美要求解锁iPhone美版解锁的iphone在大陆怎么用filezilla_serverFileZilla无法连接服务器怎么解决flashfxp注册码求一个flashfxp v3.0.2的注册码温州商标注册温州注册商标需要注册公司吗网站制作套餐做一个网站要多少钱zencart模板求zen-cart 模板结构无忧登陆无忧登录好吗?
.net虚拟主机 美国主机排名 新加坡服务器 256m内存 老左博客 68.168.16.150 警告本网站 国内加速器 免费ddos防火墙 商家促销 台湾谷歌地址 毫秒英文 谁的qq空间最好看 me空间社区 183是联通还是移动 新家坡 免费美国空间 100mbps drupal安装 双线asp空间 更多