百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

使用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开发者需要深刻理解这些策略,以便打造稳定且高效的系统。接下来,让我们一起揭开负载均衡的神秘面纱。...

深入对比Nginx、LVS和HAProxy,选择最合适负载均衡方案!

关注...

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双网卡链路聚合叠加负载均衡提升网速解决网卡网速瓶颈!

双网卡链路聚合一种网络配置技术,通过将多个物理网卡绑定在一起,形成一个逻辑上的网络接口,以提高网络的可靠性、可用性和性能。这种技术通常用于服务器和网络设备中,以实现负载均衡、冗余和高可用性。本机环境:...