vmware-mcp
MCP server for controlling VMware Fusion/Workstation virtual machines via vmrun CLI, providing 32 tools for VM lifecycle, guest execution, and file operations without requiring a REST API daemon.
README
vmware-mcp
MCP server for controlling VMware Fusion/Workstation virtual machines via the vmrun CLI.
Unlike existing VMware MCP servers that depend on the REST API (vmrest), this server calls vmrun directly — no additional daemon required.
npx vmware-mcp
Quick Start
Add to your MCP client config — the agent gets 32 tools for full VM control.
Credentials can be passed as CLI args, or omitted if stored in config file, env vars, or OS secret store.
For tool usage workflows and known limitations, see AGENT_GUIDE.md.
<details> <summary><b>opencode</b></summary>
~/.config/opencode/opencode.json:
{
"mcp": {
"vmware": {
"type": "local",
"command": ["npx", "-y", "vmware-mcp",
"--guest-user", "my-vm:admin",
"--guest-pass", "my-vm:password",
"--encryption-pass", "my-vm:encpass"
],
"timeout": 300000
}
}
}
</details>
<details> <summary><b>Claude Desktop</b></summary>
~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"vmware": {
"command": "npx",
"args": ["-y", "vmware-mcp",
"--guest-user", "my-vm:admin",
"--guest-pass", "my-vm:password"
]
}
}
}
</details>
<details> <summary><b>Claude Code (CLI)</b></summary>
claude mcp add --transport stdio vmware -- npx -y vmware-mcp \
--guest-user my-vm:admin --guest-pass my-vm:password
Or manually in ~/.claude.json or .mcp.json (project-level):
{
"mcpServers": {
"vmware": {
"command": "npx",
"args": ["-y", "vmware-mcp", "--guest-user", "my-vm:admin", "--guest-pass", "my-vm:password"]
}
}
}
</details>
<details> <summary><b>Cursor</b></summary>
~/.cursor/mcp.json (global) or .cursor/mcp.json (project):
{
"mcpServers": {
"vmware": {
"command": "npx",
"args": ["-y", "vmware-mcp",
"--guest-user", "my-vm:admin",
"--guest-pass", "my-vm:password"
]
}
}
}
</details>
<details> <summary><b>Windsurf (Codeium)</b></summary>
~/.codeium/windsurf/mcp_config.json:
{
"mcpServers": {
"vmware": {
"command": "npx",
"args": ["-y", "vmware-mcp",
"--guest-user", "my-vm:admin",
"--guest-pass", "my-vm:password"
]
}
}
}
</details>
<details> <summary><b>GitHub Copilot (VS Code)</b></summary>
.vscode/mcp.json (workspace):
{
"servers": {
"vmware": {
"command": "npx",
"args": ["-y", "vmware-mcp",
"--guest-user", "my-vm:admin",
"--guest-pass", "my-vm:password"
]
}
}
}
Note: uses servers key, not mcpServers.
</details>
<details> <summary><b>Cline (VS Code Extension)</b></summary>
Configure via Cline sidebar → MCP Servers, or manually:
macOS: ~/Library/Application Support/Code/User/globalStorage/saoudrizwan.claude-dev/settings/cline_mcp_settings.json
{
"mcpServers": {
"vmware": {
"command": "npx",
"args": ["-y", "vmware-mcp",
"--guest-user", "my-vm:admin",
"--guest-pass", "my-vm:password"
],
"disabled": false
}
}
}
</details>
<details> <summary><b>Roo Code (VS Code Extension)</b></summary>
~/.roo/mcp_settings.json (global) or .roo/mcp.json (project):
{
"mcpServers": {
"vmware": {
"command": "npx",
"args": ["-y", "vmware-mcp",
"--guest-user", "my-vm:admin",
"--guest-pass", "my-vm:password"
]
}
}
}
</details>
<details> <summary><b>Amazon Q Developer</b></summary>
~/.aws/amazonq/mcp.json (global) or .amazonq/mcp.json (project):
{
"mcpServers": {
"vmware": {
"command": "npx",
"args": ["-y", "vmware-mcp",
"--guest-user", "my-vm:admin",
"--guest-pass", "my-vm:password"
]
}
}
}
</details>
<details> <summary><b>Zed</b></summary>
~/.config/zed/settings.json — note: uses context_servers key with different structure:
{
"context_servers": {
"vmware": {
"command": {
"path": "npx",
"args": ["-y", "vmware-mcp",
"--guest-user", "my-vm:admin",
"--guest-pass", "my-vm:password"
]
}
}
}
}
</details>
<details> <summary><b>Continue.dev</b></summary>
~/.continue/config.json:
{
"mcpServers": {
"vmware": {
"command": "npx",
"args": ["-y", "vmware-mcp",
"--guest-user", "my-vm:admin",
"--guest-pass", "my-vm:password"
]
}
}
}
</details>
<details> <summary><b>Sourcegraph Cody</b></summary>
~/.config/cody/mcp_servers.json:
{
"mcpServers": {
"vmware": {
"command": "npx",
"args": ["-y", "vmware-mcp",
"--guest-user", "my-vm:admin",
"--guest-pass", "my-vm:password"
]
}
}
}
</details>
<details> <summary><b>JetBrains AI Assistant</b></summary>
Settings → Tools → AI Assistant → Model Context Protocol (MCP) → Add:
{
"mcpServers": {
"vmware": {
"command": "npx",
"args": ["-y", "vmware-mcp",
"--guest-user", "my-vm:admin",
"--guest-pass", "my-vm:password"
]
}
}
}
</details>
Manual / Global Install
npm install -g vmware-mcp
vmware-mcp
Configuration
Create ~/.config/vmware-mcp/config.json:
{
"vmrun_path": "/Applications/VMware Fusion.app/Contents/Public/vmrun",
"default_vm": "my-vm",
"vms": {
"my-vm": {
"vmx_path": "/path/to/VM.vmwarevm/VM.vmx",
"os_type": "windows",
"guest_user": "admin",
"guest_password": "password"
},
"linux-vm": {
"vmx_path": "/path/to/Ubuntu.vmwarevm/Ubuntu.vmx",
"os_type": "linux",
"guest_user": "ubuntu",
"guest_password": "password"
}
}
}
The config file is optional. VMs can also be specified by full .vmx path, and credentials can come from other sources.
vmrun Path Defaults
| Platform | Default Path |
|---|---|
| macOS | /Applications/VMware Fusion.app/Contents/Public/vmrun |
| Windows | C:\Program Files (x86)\VMware\VMware Workstation\vmrun.exe |
| Linux | /usr/bin/vmrun |
Credential Resolution
Credentials are resolved in this order (first match wins):
| Priority | Source | Platforms |
|---|---|---|
| 1 | Config file | All |
| 2 | CLI arguments | All |
| 3 | Environment variables | All |
| 4 | OS secret store | macOS Keychain, Linux libsecret, Windows PasswordVault |
If credentials exist in config or OS secret store, no CLI args or env vars are needed.
CLI Arguments
vmware-mcp --guest-user my-vm:admin --guest-pass my-vm:password --encryption-pass my-vm:encpass
Note: Passwords with
!,$, or other shell special characters may be mangled by bash history expansion. Use single quotes in bash ('my-vm:p@ss!word'), or prefer config file / OS secret store for passwords with special characters.
Environment Variables
| Variable | Description |
|---|---|
VMWARE_MCP_<VM>_USER |
Guest OS username |
VMWARE_MCP_<VM>_PASS |
Guest OS password |
VMWARE_MCP_<VM>_ENCRYPTION_PASS |
VM encryption password |
<VM> is the uppercase VM name from config (e.g., VMWARE_MCP_MY-VM_USER).
OS Secret Store
Store credentials securely — no plaintext files. The server reads from the native store automatically.
macOS (Keychain)
security add-generic-password -s vmware-mcp -a "my-vm/guest_user" -w "admin"
security add-generic-password -s vmware-mcp -a "my-vm/guest_password" -w "password"
security add-generic-password -s vmware-mcp -a "my-vm/encryption_password" -w "encpass"
Linux (libsecret — GNOME Keyring / KDE Wallet)
secret-tool store --label="vmware-mcp" service vmware-mcp account "my-vm/guest_user" <<< "admin"
secret-tool store --label="vmware-mcp" service vmware-mcp account "my-vm/guest_password" <<< "password"
secret-tool store --label="vmware-mcp" service vmware-mcp account "my-vm/encryption_password" <<< "encpass"
Windows (Credential Locker / PasswordVault)
$vault = New-Object Windows.Security.Credentials.PasswordVault
$vault.Add((New-Object Windows.Security.Credentials.PasswordCredential("vmware-mcp", "my-vm/guest_user", "admin")))
$vault.Add((New-Object Windows.Security.Credentials.PasswordCredential("vmware-mcp", "my-vm/guest_password", "password")))
$vault.Add((New-Object Windows.Security.Credentials.PasswordCredential("vmware-mcp", "my-vm/encryption_password", "encpass")))
Tools (32)
VM Lifecycle (9)
| Tool | Description |
|---|---|
vm_start |
Start a VM (gui or headless) |
vm_stop |
Graceful or forced shutdown |
vm_suspend |
Suspend to disk (encrypted VMs may not resume via vmrun) |
vm_reset |
Reboot (soft or hard) |
vm_pause / vm_unpause |
Pause/resume execution |
vm_status |
Running state + IP address |
vm_list |
Running VMs, or all configured VMs with all=true |
vm_get_ip |
Guest IP (optionally wait until ready) |
Guest Execution (2)
| Tool | Description |
|---|---|
guest_run_command |
Run shell command, return stdout. Auto-detects shell (cmd/bash/powershell) |
guest_run_program |
Launch a program (sync or fire-and-forget with no_wait) |
File Operations (10)
| Tool | Description |
|---|---|
file_copy_to_guest |
Host → Guest file copy |
file_copy_from_guest |
Guest → Host file copy |
guest_read_file |
Read guest file contents |
guest_file_exists |
Check if file exists |
guest_directory_exists |
Check if directory exists |
guest_directory_create |
Create directory |
guest_delete_file |
Delete file |
guest_rename_file |
Rename/move file |
guest_list_directory |
List directory contents |
guest_create_tempfile |
Create temp file, return path |
Snapshots (4)
| Tool | Description |
|---|---|
vm_snapshot_create |
Create named snapshot (may fail on running encrypted VMs) |
vm_snapshot_revert |
Revert to snapshot (optional auto_start) |
vm_snapshot_list |
List snapshots in tree format |
vm_snapshot_delete |
Delete snapshot |
Process Management (2)
| Tool | Description |
|---|---|
guest_process_list |
List all guest processes |
guest_kill_process |
Kill process by PID |
Screen & Input (2)
| Tool | Description |
|---|---|
vm_capture_screen |
Screenshot as base64 PNG or save to file (requires guest credentials) |
guest_type_keystrokes |
Send keystrokes to guest (requires macOS Accessibility permission) |
Variables & Tools State (3)
| Tool | Description |
|---|---|
vm_read_variable |
Read VM variable (runtimeConfig / guestVar / guestEnv) |
vm_write_variable |
Write VM variable |
vm_check_tools |
Check VMware Tools state (unknown / installed / running) |
Known Limitations
These are vmrun CLI constraints, not bugs in this server. All errors include actionable hints.
| Limitation | Workaround |
|---|---|
| Snapshot ops fail on running encrypted VMs | Stop the VM first |
vm_suspend → vm_start fails on encrypted VMs |
Use vm_stop / vm_start instead |
| Guest commands have a 5-minute hard timeout | Break long operations into smaller commands |
guest_type_keystrokes needs macOS Accessibility |
Grant permission in System Settings |
vm_capture_screen requires guest credentials |
Configure guest_user / guest_password |
| Port forwarding is Windows-host only | Not available on macOS Fusion |
Development
git clone https://github.com/havu0/vmware-mcp.git
cd vmware-mcp
npm install
npm run build # tsc
npm test # vitest (70 tests)
npm run dev # tsc --watch
License
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.