节点基于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. . .

raksmart:年中大促,美国物理机$30/月甩卖;爆款VPS仅月付$1.99;洛杉矶/日本/中国香港多IP站群$177/月

RAKsmart怎么样?RAKsmart发布了2021年中促销,促销时间,7月1日~7月31日!,具体促销优惠整理如下:1)美国西海岸的圣何塞、洛杉矶独立物理服务器低至$30/月(续费不涨价)!2)中国香港大带宽物理机,新品热卖!!!,$269.23 美元/月,3)站群服务器、香港站群、日本站群、美国站群,低至177美元/月,4)美国圣何塞,洛杉矶10G口服务器,不限流量,惊爆价:$999.00,...

ZJI-全场八折优惠,香港服务器 600元起,还有日本/美国/韩国服务器

月付/年付优惠码:zji  下物理服务器/VDS/虚拟主机空间订单八折终身优惠(长期有效)一、ZJI官网点击直达ZJI官方网站二、特惠香港日本服务器香港大埔:http://hkdb.speedtest.zji.net/香港葵湾:http://hkkw.speedtest.zji.net/日本大阪:http://jpsk.speedtest.zji.net/日本大阪一型 ...

GigsGigsCloud(年付26美元)国际线路美国VPS主机

已经有一段时间没有听到Gigsgigscloud服务商的信息,这不今天看到商家有新增一款国际版线路的美国VPS主机,年付也是比较便宜的只需要26美元。线路上是接入Cogentco、NTT、AN2YIX以及其他亚洲Peering。这款方案的VPS主机默认的配置是1Gbps带宽,比较神奇的需要等待手工人工开通激活,不是立即开通的。我们看看这款服务器在哪里选择看到套餐。内存CPUSSD流量价格购买地址1...

怎么创建群为你推荐
操作httpdell服务器bios设置dell R410服务器 bios设置参数如何恢复出厂设置?美要求解锁iPhone美版解锁的iphone在大陆怎么用灌水机谁知道哪个好点的灌水机的地址?独立访客访客数(UV)是什么意思discuz下载谁给我发下Discuz-x2.5安装教程邮件管理系统什么邮箱管理软件好用?系统错误微信显示系统错误请重试,怎么办?空间导航自定义名称帮忙想个好听QQ空间自定义导航名字w3c验证“W3C代码校验”的作用
100m虚拟主机 com域名注册1元 移动服务器租用 星星海 css样式大全 国外免费空间 linux空间 数字域名 cdn加速原理 美国在线代理服务器 免费高速空间 最好的qq空间 hkt 个人免费主页 中国电信网络测速 监控服务器 电信网络测速器 小夜博客 聚惠网 bwg 更多