Kubevirt

简介: Kubevirt

目录

Kubevirt部署

KubeVirt官网地址

1. 简介

KubeVirt 是一个用于在 Kubernetes 集群中运行和管理虚拟机(VM)的开源项目。它将虚拟机的管理与 Kubernetes 的容器编排功能结合起来,使得用户可以在统一的环境中管理容器和虚拟机。KubeVirt 是由 Red Hat 和社区合作开发的,目的是将虚拟机管理与 Kubernetes 的强大功能相结合。

2. 核心概念

  • 虚拟机(VM):与 Kubernetes Pod 类似,但运行的是虚拟机而不是容器。
  • 虚拟机实例(VMInstance):一个运行中的虚拟机。与 Pod 的概念类似。
  • 虚拟机配置(VM):定义虚拟机的规格和配置,包括 CPU、内存、磁盘等。
  • 虚拟机映像(VMImage):虚拟机使用的操作系统和应用程序的镜像。
  • 存储卷(Volume):虚拟机所需的存储,例如磁盘、云存储等。

3. 部署kubevirt

官方提供了好几种部署的方式,我这里使用部署operateor的方式,不使用helm

3.1 部署kubevirt operator

[root@master ~]# export VERSION=$(curl -s https://storage.googleapis.com/kubevirt-prow/release/kubevirt/kubevirt/stable.txt)
[root@master ~]# echo $VERSION
[root@master ~]# kubectl create -f https://github.com/kubevirt/kubevirt/releases/download/${VERSION}/kubevirt-operator.yaml

网络不好可以先使用浏览器进去到这个地址然后将文件内容复制下来

3.2 开启嵌套虚拟机

我是跑在虚拟机里的,所以需要开启嵌套虚拟化功能

要先去虚拟机设置里面将CPU的虚拟化功能给勾选

3.2.1 intel

[root@master ~]# cat /sys/module/kvm_intel/parameters/nested
1

如果这里返回1或者是Y,那么就没问题了,如果是0或者N,那么接着往下来

[root@master ~]# modprobe -r kvm_intel
[root@master ~]# modprobe kvm_intel nested=1

这2个命令执行完毕之后再去执行第一条命令

[root@master ~]# cat /sys/module/kvm_intel/parameters/nested
1

这个时候就应该返回1或者是Y了

嵌套虚拟机永久生效

[root@master ~]# vim /etc/modprobe.d/kvm.conf
options kvm_intel nested=1

3.2.2 AMD

[root@master ~]# modprobe -r kvm_amd
[root@master ~]# modprobe kvm_amd nested=1

配置永久生效

[root@master ~]# vim /etc/modprobe.d/kvm.conf
options kvm_amd nested=1

3.3 继续部署kubevirt

[root@master ~]# kubectl create -f https://github.com/kubevirt/kubevirt/releases/download/${VERSION}/kubevirt-cr.yaml

等待所有的pods启动完毕,启动之后会有6个Pod正常运行

[root@master ~]# kubectl get pods -n kubevirt 
NAME                               READY   STATUS    RESTARTS      AGE
virt-api-77876557d6-clv2m          1/1     Running   0             39m
virt-controller-788fcb6fd7-bvzw9   1/1     Running   0             32m
virt-controller-788fcb6fd7-jcjzh   1/1     Running   0             37m
virt-handler-xwgw6                 1/1     Running   0             37m
virt-operator-5b86ff4db8-6vhkr     1/1     Running   1 (47m ago)   57m
virt-operator-5b86ff4db8-p4tqv     1/1     Running   2 (44m ago)   57m

3.4 安装virtctl

KubeVirt 提供了一个名为virtctl的附加二进制文件,用于快速访问 VM 的串行和图形端口,并处理启动/停止操作。

[root@master ~]# VERSION=$(kubectl get kubevirt.kubevirt.io/kubevirt -n kubevirt -o=jsonpath="{.status.observedKubeVirtVersion}")
[root@master ~]# ARCH=$(uname -s | tr A-Z a-z)-$(uname -m | sed 's/x86_64/amd64/') || windows-amd64.exe
[root@master ~]# echo ${ARCH}
[root@master ~]# curl -L -o virtctl https://github.com/kubevirt/kubevirt/releases/download/${VERSION}/virtctl-${VERSION}-${ARCH}
[root@master ~]# chmod +x virtctl
[root@master ~]# sudo install virtctl /usr/local/bin

4. 运行第一个虚拟机

先下载虚拟机文件

[root@master ~]# wget https://kubevirt.io/labs/manifests/vm.yaml
[root@master ~]# kubectl apply -f vm.yaml

查看虚拟机

[root@master ~]# kubectl get vms
NAME     AGE   STATUS    READY
testvm   24s   Stopped   True

此时的虚拟机是出于停止状态,我们可以使用virtctl命令将他启动

[root@master ~]# virtctl start  testvm
[root@master ~]# kubectl get vms
NAME     AGE   STATUS    READY
testvm   40s   Running   True

虚拟机现在已经正常运行了,如果我们想要连接的话也可以使用virtctl

[root@master ~]# virtctl console testvm
Successfully connected to testvm console. The escape sequence is ^]
login as 'cirros' user. default password: 'gocubsgo'. use 'sudo' for root.
testvm login: cirros
Password: 
$

这样我们就登录到虚拟机了,想要推出的话按Ctrl + ]就可以退出虚拟机了

本文来自博客园,作者:FuShudi,转载请注明原文链接:https://www.cnblogs.com/fsdstudy/p/18316979

分类: Euler / HCIE / k8s , Euler

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
Kubernetes Linux API
[没接触过kubevirt?]15分钟快速入门kubevirt
什么是kubevirt? kubevirt是一个容器方式运行虚拟机的项目。`kubevirt`是附加`kubernetes`集群上的,它是通过 `CustomResourceDefinition(CRD)`部署到`Kubernetes API`变成资源对象。使用方式类似创建`deploy、pod`......这些资源清单。
4477 0
[没接触过kubevirt?]15分钟快速入门kubevirt
|
6月前
|
Kubernetes 搜索推荐 应用服务中间件
制作KubeVirt镜像
制作KubeVirt镜像
161 13
|
8月前
|
Ubuntu Linux 网络安全
云计算|OpenStack|社区版OpenStack(实务操作---cloud-init的使用)
云计算|OpenStack|社区版OpenStack(实务操作---cloud-init的使用)
510 0
|
Ubuntu Linux KVM
分享一些OpenStack的qcow2格式实例镜像
分享一些OpenStack的qcow2格式实例镜像
10175 0
分享一些OpenStack的qcow2格式实例镜像
|
JSON Kubernetes 数据格式
K8S client-go Patch example
我在本文中主要会介绍使用client-go的Patch方式,主要包括strategic merge patch和json-patch
|
3月前
|
自然语言处理 JavaScript 开发者
通义灵码插件:VSCode 的智能编程助手
通义灵码插件:VSCode 的智能编程助手
832 3
|
5月前
|
Kubernetes Perl 容器
在K8S中,Pod的重启策略是什么?
在K8S中,Pod的重启策略是什么?
|
6月前
|
存储 缓存 Linux
GlusterFs分布式文件系统
GlusterFs分布式文件系统
101 8
|
8月前
|
弹性计算 安全 微服务
【阿里云云原生专栏】容器网络技术前沿:阿里云Terway网络方案详解
【5月更文挑战第26天】阿里云Terway是高性能的容器网络方案,基于ECS的ENI实现,提供低延迟高吞吐的网络服务。它简化网络管理,实现安全隔离,并与阿里云服务无缝集成。Terway由CNI、Node和Controller组成,适用于微服务、混合云和多租户环境,为企业数字化转型中的复杂网络需求提供强大支持。
418 1
|
8月前
|
存储 Kubernetes 容器
【开源推荐】k8s备份神器--Velero
【5月更文挑战第2天】
282 0