Knife vSphere 使用与安装指南
1. 安装指南
Knife vSphere 是作为 Chef Workstation 的一部分发布的,因此最简单的方式是安装 Chef Workstation。如果你正在使用 bundler 作为项目的一部分,可以将 knife 和 knife-vSphere 添加到你的 Gemfile 中:
gem 'knife'
gem 'knife-vSphere'
根据你的系统配置,你可能需要以 root 权限运行这个命令。
2. 项目使用说明
Knife vSphere 是一个 Chef Knife 插件,用于与 VMware vSphere 进行交互。该插件目前支持以下功能:
列表:
- 虚拟机 (VMs)
- 文件夹
- 模板
- 数据存储
- VLANs(需要分布式交换机)
- 资源池和集群
- 自定义规范
- 池或集群中的主机
- VM 的网络卡和 VLAN
虚拟机操作:
- 开机/关机
- 克隆(可选的 chef 引导和运行列表)
- 删除
- 添加 VMDK
- 迁移
- 添加网络
- 连接/断开网络
- 删除网络
- 更改网络
- 启用 VNC 远程控制台
克隆特定的自定义选项(对于 Linux 客户机):
- 目标文件夹
- CPU 核心数
- 每个插槽的 CPU 核心数
- 内存大小
- 内存预留
- DNS 设置
- 主机名/域名
- IP 地址/默认网关
- VLAN(需要分布式交换机)
- 数据存储
- 资源池
注意:对于 Windows 客户机,我们可以运行 FIELDS。
3. 项目API使用文档
以下是 knife-vSphere 的一些基本使用示例,帮助你入门。
- 从 VMware 模板克隆并引导 chef。
$ knife vsphere vm clone MACHINENAME --template TEMPLATENAME --bootstrap --cips dhcp
- 从 VMware 模板克隆 VM,并使用自定义引导。
$ knife vsphere vm clone MACHINENAME --template TEMPLATENAME --bootstrap --cips dhcp \
--cspec SPEC --connection-user USER --connection-password PASSWORD
如果你将模板放在了除根文件夹之外的位置,可以添加 -f FOLDERNAME 参数,如果你想将 VM 创建在特定的文件夹中,可以使用 --dest-folder FOLDERNAME。
- 列出可用的 VMware 模板。
$ knife vsphere template list
- 删除虚拟机。
$ knife vsphere vm delete MACHINENAME (-P 将从 chef 服务器中移除)
4. 项目安装方式
该插件提供的 Knife 子命令如下。具体的命令选项可以通过调用子命令并带上 --help 标志来查看。
knife vsphere vm list
枚举目标数据中心的虚拟机。当前只显示名称。
-r, --recursive - 递归地通过子文件夹到指定文件夹
--only-folders - 只打印文件夹名称。意味着递归
knife vsphere vm find
根据条件搜索虚拟机并显示选定字段。
--match-ip IP 匹配 IP
--match-name VMNAME 匹配名称
--match-os OS 匹配操作系统
--match-tools TOOLSSTATE 匹配工具状态
--powered-off 只显示已停止的机器
--powered-on 只显示已启动的机器
字段:
--alarms 显示警报状态
--cpu 显示 CPU
--cpu-hot-add-enabled 显示 CPU 热添加启用标志
--esx-disk 显示 ESX 磁盘
--full-path 显示 VM 的完整路径
--short-path 显示包含文件夹名称
--hostname 显示主机名
--host_name 显示 VM 主机名称
--ip 显示主 IP
--networks 显示所有网络和 IPs
--os 显示操作系统详细信息
--os-disks 显示操作系统磁盘
--ram 显示内存
--memory-hot-add-enabled 显示内存热添加启用标志
--snapshots 显示快照
--tools 显示工具状态
示例:
$ knife vsphere vm find --snapshots --full-path --cpu --ram --esx-disk \
--os-disk --os --match-name my_machine_1 --alarms --tools --ip --ips \
--match-ip 123 --match-tools toolsOk
knife vsphere vm state VMNAME
管理虚拟机的电源状态,即开关机。
-s STATE, --state STATE - 将 VM 转换为指定的电源状态;可以是 on|off|suspend|reboot
-w PORT, --wait-port PORT - 等待 VM 在端口上可访问
-g, --shutdown - 客户端 OS 关机(格式:-s off -g)
-r, --recursive - 递归地通过子文件夹到指定文件夹以找到 VM
knife vsphere pool list
枚举目标数据中心的资源池和集群。
knife vsphere template list
枚举目标数据中心的 VM 模板。当前只显示名称。
-f FOLDER - 在指定文件夹内查找,默认是根文件夹
knife vsphere customization list
枚举目标数据中心的自定义规范。当前只显示名称。
knife vsphere vm clone
从现有的 VM 模板克隆新的 VM 实例,可选地应用现有的自定义规范。如果指定了自定义参数,如 --chost 和 --cdomain,或者考虑了从 vSphere 获取的自定义规范,将尝试默认的自定义规范。
- 对于 Windows,将尝试基于 sysprep 的无人值守自定义,以工作组成员模式运行(除非另外指定,VM 名称为主机名)。
- 对于 Linux,将使用 VM 名称作为主机名的固定名称自定义。
此命令有许多选项来自定义你的 VM。最重要的是初始模板。我们有一些关于如何制作克隆模板的指导:如何制作克隆模板。
Chef 引导选项
这些选项改变了 VM 创建后引导到 Chef 的方式。至少需要 --bootstrap 来进行引导。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust078- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
Kimi-K2.6Kimi K2.6 是一款开源的原生多模态智能体模型,在长程编码、编码驱动设计、主动自主执行以及群体任务编排等实用能力方面实现了显著提升。Python00
Hy3-previewHy3 preview 是由腾讯混元团队研发的2950亿参数混合专家(Mixture-of-Experts, MoE)模型,包含210亿激活参数和38亿MTP层参数。Hy3 preview是在我们重构的基础设施上训练的首款模型,也是目前发布的性能最强的模型。该模型在复杂推理、指令遵循、上下文学习、代码生成及智能体任务等方面均实现了显著提升。Python00