KubeVirt 进阶:设置超卖比、CPU/MEM 升降配、在线磁盘扩容

前两篇文章,我们分别介绍 Kubevirt 的安装、基本使用 以及 将 oVirt 虚拟机迁移到 KubeVirt,我们留了两个ToDo,一个是本地磁盘的动态分配,一个是固定 IP 的需求,本期我们先解决第一个,本地磁盘的动态分配。

使用 OpenEBS-LVM 替换 local-storage

OpenEBS-LVM 对比 local-storage,主要新增了容量限额、动态分配PV、resize 功能,本文不做过多介绍,后面会单独讲 。

创建 sc 时,注意两个点,开启卷扩展,allowVolumeExpansion: true,卷绑定方式选择延迟绑定,volumeBindingMode: WaitForFirstConsumer

进阶功能介绍

设置超卖比[1]

kubectl -n kubevirt edit kubevirts.kubevirt.io kubevirt

...
spec:configuration:developerConfiguration:cpuAllocationRatio: 2 # CPU 超卖2倍memoryOvercommit: 200 # 内存超卖2倍
...

示例,设置虚拟机规格为 8c16g,不声明 Request

...spec:domain:cpu:cores: 8memory:guest: 16Gi
...

创建成功后, 查看 Pod 的 Request 值,发现是设置值的1/2 ,符合预期

      requests:cpu: "4"devices.kubevirt.io/kvm: "1"devices.kubevirt.io/tun: "1"devices.kubevirt.io/vhost-net: "1"ephemeral-storage: 50Mmemory: 8506Mi

登录虚拟机查看,为 8c16g,符合预期

如果声明了 Request 值,则优先走 Request 值

CPU/MEM 升配

修改 CPU/MEM 值, 重启 VM 即可

virtctl restart <vmi>

Kubevirt 也支持热升配[2],不停机,但有些限制,比如内核版本,存储读写模式等,后续实践后分享

磁盘在线扩容[3]

开启磁盘扩容功能

kubectl -n kubevirt edit kubevirts.kubevirt.io kubevirt

spec:configuration:developerConfiguration:featureGates:- ExpandDisks

查看当前数据盘大小,为500Gi

在线扩容到 600G 步骤, 手动修改关联 PVC 的大小即可, openebs-lvm 会自动扩容

...
spec:resources:requests:storage: "600Gi"

登录服务器,扩容文件系统

resize2fs /dev/vdb # ext4 文件系统,数据盘为 vdb

固定 IP、设置亲和性[4]

因为暂时还没实现固定 IP, 但是担心 虚拟机重启, IP 发生改变,对业务产生影响,所以暂时,指定 Node 进行分配 VM

从指定 的 Node 上选择 VMI IP:

# 查看 Node 分配的 block
kubectl  get blockaffinities.crd.projectcalico.org
# 挑选一个 没有分配的 IP 
calicoctl ipam show --ip=$(ip_addr)
# 指定 Pod IP
...
spec:template:metadata:annotations:cni.projectcalico.org/ipAddrs: '["pod-ip"]'

指定 Node 亲和性

...spec:nodeSelector:kubernetes.io/hostname: "nodename"
...

VM 完整 Yaml 文件如下:

apiVersion: kubevirt.io/v1
kind: VirtualMachine
metadata:labels:kubevirt.io/vm: <vmi-name>name: <vmi-name>
spec:running: falsetemplate:metadata:labels:kubevirt.io/vm: <vmi-name>annotations:cni.projectcalico.org/ipAddrs: '["pod-ip"]'spec:nodeSelector:kubernetes.io/hostname: "nodename"domain:cpu:cores: 8memory:guest: 16Gidevices:disks:- disk:bus: virtioname: datavolumedisk1-sys- disk:bus: virtioname: datavolumedisk1-datainterfaces:- name: defaultbridge: {}#resources:#  requests:#    memory: 8Ginetworks:- name: defaultpod: {}volumes:- dataVolume:name: demo-1-sysname: datavolumedisk1-sys- dataVolume:name: demo-1-dataname: datavolumedisk1-datadataVolumeTemplates:- metadata:name: demo-1-sysspec:storage:storageClassName: openebs-lvmaccessModes:- ReadWriteOnceresources:requests:storage: 80Gisource:http:url: <img_url>- metadata:name: demo-1-dataspec:storage:storageClassName: openebs-lvmaccessModes:- ReadWriteOnceresources:requests:storage: 500Gisource:blank: {}

参考链接:

[1] Node overcommit:https://kubevirt.io/user-guide/compute/node_overcommit/#node-overcommit

[2] CPU Hotplug:https://kubevirt.io/user-guide/compute/cpu_hotplug/#cpu-hotplug

​ Memory Hotplug:https://kubevirt.io/user-guide/compute/memory_hotplug/#memory-hotplug

[3] disk expansion https://kubevirt.io/user-guide/storage/disks_and_volumes/#disk-expansion

[4] Node assignment https://kubevirt.io/user-guide/compute/node_assignment/#node-assignment

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/66706.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

自动化脚本本地可执行但是Jenkins上各种报错怎么解决

作者碎碎念&#xff1a; 测试环境 Jenkinsdockerpythonunittest&#xff0c; 测试问题&#xff1a;本人在写关于SAP4Me网站的自动化脚本时遇到一个问题 本地怎么都跑的通 但是一上Jenkins会出现各种各样的问题 因为在Jenkins里面脚本是放在docker环境里面跑的 所以环境的差异…

TaskBuilder前端组件简介

3.3.3.1前端组件的分类 前端页面是由众多组件层层嵌套构成的&#xff0c;这些组件是任讯信息自主研发的一套前端UI组件&#xff0c;称为tfp组件&#xff0c;这些组件根据其功能和特点又分为几大类&#xff0c;它们的继承关系如下图所示&#xff1a; 从图中可知&#xff0c;所…

linux下shell中使用上下键翻出历史命名时出现^[[A^[[A^[[A^[[B^[[B的问题解决

前言 今天在使用linux的时候&#xff0c;使用上下键想翻出历史命令时&#xff0c;却出现[[A[[A[[A[[B^[[B这种东东&#xff0c;而tab键补全命令的功能也无法使用。最终发现是由于当前用户使用的shell是/bin/sh的原因。 解决方法 运行以下命令&#xff0c;将默认 shell 设置为…

Kafka优势剖析-幂等性和事务

目录 1. 幂等性&#xff08;Idempotence&#xff09; 1.1 什么是幂等性&#xff1f; 1.2 幂等性的实现 1.2.1 生产者 ID 和序列号 1.2.2 重复消息检测 1.2.3 幂等性的优势 1.3 幂等性的配置 2. 事务支持&#xff08;Transactions&#xff09; 2.1 什么是事务支持&…

FPGA的 基本结构(Xilinx 公司Virtex-II 系列FPGA )

以Xilinx 公司Virtex-II 系列FPGA 为例&#xff0c;其基本结构由下图所示。它是主要由两大部分组成&#xff1a;可编程输入/输出&#xff08;Programmable I/Os&#xff09;部分和内部可配置&#xff08;Configurable Logic&#xff09;部分。 可编程输入/输出&#xff08;I/Os…

《零基础Go语言算法实战》【题目 1-11】格式化字符串

《零基础Go语言算法实战》 【题目 1-11】格式化字符串 在 Go 语言中&#xff0c;找到使用变量格式化字符串而不打印值的简单方法。 【解答】 在 Go 语言中&#xff0c;在不打印值的情况下进行格式化的最简单方法是使用 fmt.Sprintf() 函数&#xff0c; 它返回一个格式化的…

Virtualbox7.1.4安装Proxmox

准备工作 有以下两个大步骤&#xff1a; 第一步、安装Virtualbox 最新版本安装过程遇到问题参考&#xff1a; VirtualBox新版本报错 Invalid installation directory解决方案_virtualbox invalid installation directory-CSDN博客 第二步、下载Proxmox 官网下载地址&…

Apache JMeter 压力测试使用说明

文章目录 一、 安装步骤步骤一 下载相关的包步骤二 安装 Jmeter步骤三 设置 Jmeter 工具语言类型为中文 二、使用工具2.1 创建测试任务步骤一 创建线程组步骤二 创建 HTTP 请求 2.2 配置 HTTP 默认参数添加 HTTP消息头管理器HTTP请求默认值 2.3 添加 查看结果监听器2.4 查看结果…

yum换源

背景描述 源&#xff1a;阿里云&#xff1a; 系统&#xff1a;centos7 https://developer.aliyun.com/mirror/其他参考地址&#xff1a; https://developer.aliyun.com/mirror/centos?spma2c6h.13651102.0.0.3e221b11UchtP5https://developer.aliyun.com/mirror/centos-vau…

vivado时序约束和优化

相关资料 参考视频 基础篇&#xff1a; 05如何科学设计FPGA:VIVADO中的时序约束和分析以及进阶技巧_哔哩哔哩_bilibili 升级篇&#xff1a; 05如何科学设计FPGA:VIVADO中的时序约束和分析以及进阶技巧_哔哩哔哩_bilibili 参考文章 csdn写的很好的文章目录&#xff1a; …

《跟我学Spring Boot开发》系列文章索引❤(2025.01.09更新)

章节文章名备注第1节Spring Boot&#xff08;1&#xff09;基于Eclipse搭建Spring Boot开发环境环境搭建第2节Spring Boot&#xff08;2&#xff09;解决Maven下载依赖缓慢的问题给火车头提提速第3节Spring Boot&#xff08;3&#xff09;教你手工搭建Spring Boot项目纯手工玩法…

从Linux本地软件存储库安装MySQL

许多Linux发行版在其本机软件存储库中包含MySQL服务器、客户端工具和开发组件的版本&#xff0c;并且可以与平台的标准包管理系统一起安装。本节提供使用这些包管理系统安装MySQL的基本说明。 本机软件包通常比当前可用的版本落后几个版本。您通常也无法安装开发里程碑版本&am…

[数据结构]倒排索引介绍

倒排索引详解 1. 原理 倒排索引&#xff08;Inverted Index&#xff09;是一种数据结构&#xff0c;用于存储在文档集合中出现的单词&#xff0c;以及这些单词出现的文档列表。这种索引方式常用于全文搜索引擎&#xff0c;如Elasticsearch和Solr&#xff0c;以快速进行文本搜…

AIDD-人工智能药物设计-人工智能破解酶稳定性定向进化中的多个突变位点高效重组问题

mLife | 人工智能破解酶稳定性定向进化中的多个突变位点高效重组问题 优化酶的热稳定性对于蛋白质科学和工业应用至关重要。目前&#xff0c;通过&#xff08;半&#xff09;理性设计和随机诱变方法可以较为准确地设计多个增强酶热稳定性的单点突变。但当组合多个突变时&#…

Qt仿音乐播放器:媒体类

一、铺垫 我暂时只会音频系列的操作&#xff0c;我只能演示音频部分&#xff1b;但是QMediaPlayer是一个可以播放视频、音频的类&#xff1b;请同学们细读官方文档&#xff1b; 二、头文件 #include<QMediaPlayer> 头文件 #include<QMediaPlaylist> 三、演…

java随机数Random类

在 Java 中&#xff0c;Random 类用于生成随机数。它是 java.util 包的一部分&#xff0c;可以生成不同类型的随机数&#xff0c;例如整数、浮点数、布尔值等。Random 类的实例可以用来产生各种随机数据&#xff0c;广泛应用于游戏、测试、加密、数据模拟等场景。 1. 创建 Ran…

解决cursor50次使用限制问题并恢复账号次数

视频内容&#xff1a; 在这个视频教程中&#xff0c;我们将演示如何解决科sir软件50次使用限制的问题&#xff0c;具体步骤包括删除和注销账号、重新登录并刷新次数。教程详细展示了如何使用官网操作将账号的剩余次数恢复到250次&#xff0c;并进行软件功能测试。通过简单的操…

js监测页面可见性

监测切换页面 检测页面的可见性状态document.visibilityState:document.hiddenvisibilitychange 事件 js 检测页面切换至别的应用 检测页面的可见性状态 在JavaScript中&#xff0c;你可以使用Page Visibility API来检测页面的可见性状态。这个API提供了一组接口&#xff0c;允…

微信小程序开发设置支持scss文件

在微信小程序开发中&#xff0c;默认是不支持scss文件的&#xff0c;创建文件的时候&#xff0c;css文件默认创建的是wxss后缀结尾的&#xff0c;但是用习惯了scss的怎么办呢&#xff1f; 首先找到project.config.json文件&#xff0c;打开文件在setting下设置useCompilerPlug…

Matlab Steger提取条纹中心(非极大值抑制)

文章目录 一、简介二、实现代码三、实现效果一、简介 由于在确定条纹的ROI区域之后,会计算出多个条纹中心坐标,因此这里就需要对其进行则优选择,毕竟条纹只有一条,这最简单的方式就是使用非极大值抑制,即选择每一行/列最好的条纹中心。 二、实现代码 Hessian2D.m function…