使用GoVC批量创建虚拟机 vsphere批量创建虚拟机
haoteby 2024-12-18 14:13 5 浏览
之前的文章中,我介绍Govc工具和使用Govc批量关闭vSAN集群虚拟机的场景,那么Govc还能做哪些对我们平时工作有帮助的事情呢,相信大家最常见使用vCenter来部署虚拟机,当部署单个虚拟机时很简单,但,一个项目需要很多虚拟机的时候,WebUI操作就会比较麻烦,用时也比较长,那我们是否可以使用Govc来批量部署虚拟机呢?答案是肯定的。 本文章,将向大家展示如何使用Govc批量部署虚拟机,提高您的工作效率。
相关工具介绍
工具名称 | 说明文档 | 备注 |
govc | https://github.com/vmware/govmomi/blob/main/govc/USAGE.md | 基于govmomi构建的vSphere命令行工具 |
jq | https://jqlang.github.io/jq/ | 用于脚本处理Json数据(多个虚拟机) |
虚拟机模版 | 用于部署的虚拟机的源模版 | 根据需要准备 |
vCenter虚拟机自定义规范 | 根据操作系统创建不同的自定义规范 | 自定义虚拟机时需要使用 |
示例代码 | https://github.com/6547709/packer-hcl/tree/main/govc-vsphere | 推荐直接下载源代码使用 |
相关文件说明
GOVC是VMware官方提供的简单易用的CLI工具,直接运行命令就可以完成vCenter的操作,也可以融入到脚本中,为了能够适应企业内部多个vCenter环境和不同的VM配置需求,把脚本做了规范化,create-vm.sh至少需要2个输入参数,第一个参数为vCenter的配置定义,第二个参数为VM的配置定义,第三个参数为删除专用参数(destroy)。
- create-vm.sh:用于调用govc在vCenter中批量创建虚拟机或批量删除已创建的虚拟机(destroy)。
- mgmt-vc:用于定义vCenter的连接信息。
- vms:用于定义要创建的虚拟机信息,包含:虚拟机名,IP地址等。 注意:请直接使用源代码包,不要使用下面的文件,下面文件仅为说明每个配置的用途。
create-vm.sh文件说明
此脚本为了适配不同的vCenter和虚拟机需求,提供多个输入参数(实际上就是变量声明),可以基于不同的需求修改变量和脚本代码,注意,生产环境使用,需进行严格测试。
#此部分代码应用为脚本提供帮助和输入参数不足的提示信息。
#!/bin/sh
case "$1" in
-h|--help|?)
echo "Usage: This script uses GOVC to perform virtual machine creation and requires 2 input parameters."
echo "1st arg: vCenter server address, user and password."
echo "2st arg: Information to create virtual machines and source templates."
echo "3st arg: destroy vms ,only support input "destroy""
exit 0
;;
esac
if [ ! -n "$1" ]; then
echo "Please enter the first parameter: used to refer to the vCenter variable."
exit
fi
if [ ! -n "$2" ]; then
echo "Please enter the second parameter: used to refer to the virtual machine and template information variables"
exit
fi
#导入变量到环境,$1代表第一个参数,$2代表第二个参数
source $1
source $2
#判断是否安装了jq和govc程序
if ! [ `command -v jq` ];then
echo "jq is not installed, please use "dnf install jq" to install it."
fi
if ! [ `command -v govc` ];then
echo "govc is not installed,please installit."
fi
VM_NUM=$(echo $VMS |jq '.|length')
#判断是否有第三个参数,如果没有第三个参数,直接执行虚拟机创建任务
if [ -z $3 ]; then
echo "Start deploying the target virtual machine in $GOVC_URL"
for((i=0;i<$VM_NUM;i++)); do
{ NEW_VM_NAME=$(echo $VMS |jq -r .[$i].vm_name)
CPU=$(echo $VMS |jq -r .[$i].vm_cpu)
MEM=$(echo $VMS |jq -r .[$i].vm_mem)
IP=$(echo $VMS |jq -r .[$i].vm_ip)
MASK=$(echo $VMS |jq -r .[$i].vm_mask)
GATE=$(echo $VMS |jq -r .[$i].vm_gateway)
DNS=$(echo $VMS |jq -r .[$i].vm_dns)
#从模版克隆虚拟机,并保持关机状态
govc vm.clone -vm "$TEMP_VM_NAME" -ds="$DS" -cluster="$CLUSTER_NAME" -pool="$RESOURCE_POOL" -c=$CPU -m=$MEM -on=false -annotation="$DESC" "$NEW_VM_NAME"
#为虚拟机配置“客户机操作系统自定义”,用于配置主机名、IP地址等
govc vm.customize -vm $NEW_VM_NAME -ip $IP -netmask $MASK -gateway $GATE -dns-server "$DNS" "$SPEC"
#打开虚拟机电源,执行“客户机操作系统自定义”
govc vm.power -on "$NEW_VM_NAME"
}&
done
echo "All vms has deploy."
else
#判断第三个输入参数等于“destroy”时,开始删除所有虚拟机
if [ $3 == 'destroy' ]; then
echo "Start destroy the target virtual machine in $GOVC_URL"
for((i=0;i<$VM_NUM;i++)); do
{ NEW_VM_NAME=$(echo $VMS |jq -r .[$i].vm_name)
govc vm.destroy "$NEW_VM_NAME"
}&
done
echo "All vms has destroy."
#如果第三个输入参数不是“destroy”时,不执行任何动作。
else
echo "The third parameter only supports "destroy"."
fi
fi
mgmt-vc文件说明
此文件用于定义vCenter的连接信息,可以根据环境需求准备多个vCenter。
# vCenter info
GOVC_URL=mgmt-vc.corp.local
GOVC_USER_NAME=Administrator@vsphere.local
GOVC_PASSWORD=VMware1!
GOVC_INSECURE=true
vms文件说明
虚拟机的配置定义采用JSON格式,这样便于为每个虚拟机声明不同的配置,包括:vCPU、内存、网络和IP地址等信息。
#模版虚拟机名称,需提前准备好
TEMP_VM_NAME="Rhel84-GUI-100G-latest"
#vCenter中“客户端操作系统自定义”名字,需要提前在vCenter中创建
SPEC="linux"
#虚拟机目标存储名称
DS="LUN0-10T"
#虚拟机部署到目标集群名称
#CLUSTER_NAME="Cluster"
#虚拟机目标资源池名称,需要提前在vCenter中创建;如果不指定资源池名称,将部署到集群中
RESOURCE_POOL="govc"
#虚拟机目标文件夹,需要提前在vCenter中创建
FOLDER="govc"
#定义虚拟机的配置信息和网络信息
VMS='[
{
"vm_name": "cc-test-01",
"vm_cpu": "4",
"vm_mem": "8192",
"vm_ip": "192.168.100.51",
"vm_mask": "255.255.255.0",
"vm_gateway": "192.168.100.254",
"vm_dns": "192.168.100.10",
"vm_network": "vlan4043"
},
{
"vm_name": "cc-test-02",
"vm_cpu": "4",
"vm_mem": "8192",
"vm_ip": "192.168.100.52",
"vm_mask": "255.255.255.0",
"vm_gateway": "192.168.100.254",
"vm_dns": "192.168.100.10",
"vm_network": "vlan4043"
}
]'
脚本执行示例
打印脚本帮助信息:
执行脚本后,并发创建2台虚拟机,并完成客户机操作系统自定义:
执行带“destroy”参数的脚本后,并发删除2台虚拟机:
完毕
通过以上的脚本,我们就可以批量部署虚拟机,并完成虚拟机的初始化配置(IP地址);相信大家看了脚本后不仅可以加深对GoVC的理解,更发现VMware产品的可编程性和生态是如此强大。当然,如果您不会写脚本,也可以借助AI工具协助脚本的编写,例如:ChatGPT。
相关推荐
- 单点登录(SSO)解决方案介绍(单点登录概念)
-
一、单点登录的介绍单点登录(SingleSignOn),简称为SSO,是目前比较流行的企业业务整合的解决方案之一。SSO的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系...
- 系统登录的三种方式,哪一种更安全?
-
登录是一个高频的动作,笔者抓住这一个小点,分析了系统登录的几种方式和对应的场景。今天谈谈登录。登录即用户输入用户名和密码登录进系统中。B端系统,对于登录的业务场景有两种(可能不止,目前遇到过这两种):...
- 到底什么是单点登录(SSO)?(什么叫做单点登录)
-
什么是单点登录?单点登录(SingleSign-On,简称SSO)是一种集中式的身份验证和授权机制,用户只需在一处输入一次凭证(例如用户名和密码)就可以访问多个相关但独立的软件系统。在数字化时代,...
- 5年稳如老狗的单点登录系统,到底是怎么搞出来的?
-
说到单点登录(SingleSign-On,简称SSO),大家的第一反应可能是——啊不就是登录一次,能到处串门儿嘛?别说,还真差不多,就是这么个意思。但真要搭一套好用、耐造、还能扛住公司里各种奇奇怪...
- 这些负载均衡都解决哪些问题?服务、网关、NGINX?
-
在微服务项目中,有服务的负载均衡、网关的负载均衡、Nginx的负载均衡,这几个负载均衡分别用来解决什么问题呢?一、服务的负载均衡先抛出一个问题:...
- Nginx负载均衡最全详解(4大算法原理机制)
-
Nginx在大型网站架构很重要,也是大厂重点考察方向,今天我就重点来详解Nginx负载均衡@mikechen本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集》里面。Nginx负载均衡N...
- 负载均衡 Nginx Session 一致性(nginx 负载均衡 会话保持)
-
HTTPS请求跳转...
- 监控Oracle Cloud负载均衡器:Applications Manager释放最佳性能
-
设想你正在运营一个受欢迎的在线学习平台,在考试前的高峰期,平台流量激增。全球的学生同时登录,观看视频、提交作业和参加测试。如果OracleCloud负载均衡器不能高效地分配流量,或者后端服务器难...
- Nginx负载均衡:nginx.conf配置文件说明!
-
大家好,欢迎来到程序视点!我是你们的老朋友.小二!在此记录下Nginx服务器nginx.conf负载均衡的配置文件说明,部分注释收集与网络.关于nginx.conf基本的配置,请查看上一篇文章!Ng...
- Java高可用系统架构中的负载均衡策略
-
Java高可用系统架构中的负载均衡策略在现代的分布式系统中,负载均衡策略是构建高可用系统的基石。Java开发者需要深刻理解这些策略,以便打造稳定且高效的系统。接下来,让我们一起揭开负载均衡的神秘面纱。...
- Spring Boot3 客户端负载均衡全解析:从原理到实战
-
在当今互联网大厂后端技术开发的激烈竞争环境中,构建高效、稳定的微服务架构是核心诉求。其中,SpringBoot3作为热门开发框架,其客户端负载均衡功能对于提升系统性能、保障服务稳定性起着关键作用。...
- MySql高可用集群MySQL Router负载均衡读写分离
-
名词解释MGR:MysqlGroupReplication组复制,多台MySQL服务器在同一组中会自动保持同步状态,当某台服务器故障时,整个复制组依然可以保持正常并对外提供服务。...
- 性能测试之tomcat+nginx负载均衡(nginx tomcat)
-
nginxtomcat配置准备工作:两个tomcat执行命令cp-rapache-tomcat-8.5.56apache-tomcat-8.5.56_2修改被复制的tomcat2下con...
- win10/11双网卡链路聚合叠加负载均衡提升网速解决网卡网速瓶颈!
-
双网卡链路聚合一种网络配置技术,通过将多个物理网卡绑定在一起,形成一个逻辑上的网络接口,以提高网络的可靠性、可用性和性能。这种技术通常用于服务器和网络设备中,以实现负载均衡、冗余和高可用性。本机环境:...