Parallels MCP Server

Parallels MCP Server

An MCP server that enables managing Parallels Desktop virtual machines, including listing, starting, stopping, suspending, and executing commands inside VMs.

Category
Visit Server

README

Parallels MCP Server

A Model Context Protocol (MCP) server for managing Parallels Desktop virtual machines.

Features

This MCP server provides tools to interact with Parallels Desktop VMs:

  • list_vms - List all virtual machines
  • get_vm_info - Get detailed information about a specific VM
  • get_vm_status - Get the current status of a VM
  • start_vm - Start a virtual machine
  • stop_vm - Stop a virtual machine (with optional force flag)
  • suspend_vm - Suspend a virtual machine
  • resume_vm - Resume a suspended virtual machine
  • reset_vm - Reset (restart) a virtual machine
  • exec_vm_command - Execute a command inside a running VM

Prerequisites

  • macOS with Parallels Desktop installed
  • Node.js 16 or higher
  • prlctl command-line tool (comes with Parallels Desktop)

Installation

From npm

# Install globally
npm install -g parallels-mcp-server

# Or use with npx (no installation needed)
npx parallels-mcp-server

From source

# Clone the repository
git clone <repository-url>
cd parallels-mcp-server

# Install dependencies
npm install

# Build the project
npm run build

Usage

With Claude Desktop

After installation, add this to your Claude Desktop configuration (~/Library/Application Support/Claude/claude_desktop_config.json):

{
  "mcpServers": {
    "parallels": {
      "command": "npx",
      "args": ["parallels-mcp-server"]
    }
  }
}

Or if you have it installed globally:

{
  "mcpServers": {
    "parallels": {
      "command": "parallels-mcp-server"
    }
  }
}

With VS Code

The server is already configured in .vscode/mcp.json and ready to use!

Development

# Run in development mode with tsx
npm run dev

Example Usage

Once connected to an MCP client, you can use the tools like this:

Available Tools

list_vms

Lists all Parallels Desktop virtual machines on your system.

Parameters: None

Example:

Use the list_vms tool

get_vm_info

Get detailed information about a specific virtual machine including configuration, hardware specs, and network settings.

Parameters:

  • vm (required): VM name or UUID

Example:

Use get_vm_info with vm="MyVM"

get_vm_status

Get the current operational status of a virtual machine (running, stopped, suspended, etc.).

Parameters:

  • vm (required): VM name or UUID

Example:

Use get_vm_status with vm="MyVM"

start_vm

Start a stopped or suspended virtual machine.

Parameters:

  • vm (required): VM name or UUID

Example:

Use start_vm with vm="MyVM"

stop_vm

Stop a running virtual machine gracefully or forcefully.

Parameters:

  • vm (required): VM name or UUID
  • force (optional): Boolean - if true, performs a hard shutdown (kill)

Examples:

# Graceful shutdown
Use stop_vm with vm="MyVM"

# Force shutdown
Use stop_vm with vm="MyVM" and force=true

suspend_vm

Suspend a running virtual machine, saving its current state to disk.

Parameters:

  • vm (required): VM name or UUID

Example:

Use suspend_vm with vm="MyVM"

resume_vm

Resume a suspended virtual machine from its saved state.

Parameters:

  • vm (required): VM name or UUID

Example:

Use resume_vm with vm="MyVM"

reset_vm

Restart a virtual machine (equivalent to pressing the reset button).

Parameters:

  • vm (required): VM name or UUID

Example:

Use reset_vm with vm="MyVM"

exec_vm_command

Execute a command inside a running virtual machine.

Parameters:

  • vm (required): VM name or UUID
  • command (required): Command to execute

Example:

Use exec_vm_command with vm="MyVM" and command="ls -la /home"

Note: The VM must be running and Parallels Tools must be installed for command execution to work.

Security Notes

  • This server has direct access to your Parallels VMs via prlctl
  • Be careful when executing commands inside VMs
  • The server requires Parallels Desktop to be installed and properly configured
  • Commands are executed with your current user permissions

Troubleshooting

Command not found: prlctl

Ensure Parallels Desktop is installed and the command-line tools are in your PATH. You can verify by running:

prlctl --version

VM not found

  • Check the VM name is correct (case-sensitive)
  • Use list_vms to see available VMs
  • You can use either the VM name or UUID

Command execution fails

  • Ensure the VM is running
  • Verify Parallels Tools are installed in the guest OS
  • Check that the command syntax is correct for the guest OS

Permission denied

The server runs with your user permissions. Ensure you have access to Parallels Desktop and the VMs.

FAQ

Q: Does this work on Windows or Linux?
A: No, this server is macOS-only as it requires Parallels Desktop, which is a macOS application.

Q: Can I use this with other MCP clients besides Claude Desktop?
A: Yes! Any MCP-compatible client can use this server.

Q: Is it safe to publish this to npm?
A: Yes, but make sure to update the author information and repository URL in package.json before publishing.

Q: How do I find my VM's UUID?
A: Use the list_vms tool or run prlctl list -a in the terminal.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

MIT License - see LICENSE file for details

Support

For issues and feature requests, please use the GitHub issue tracker.

  • The server runs with the same permissions as the user running it

Troubleshooting

If you encounter issues:

  1. Verify Parallels Desktop is installed: which prlctl
  2. Test that you can run prlctl commands manually: prlctl list -a
  3. Check the server logs (errors are logged to stderr)
  4. Make sure the build directory exists and contains index.js

License

MIT

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured