Isaac Sim MCP Server
Allows JetBrains IDEs (e.g., IntelliJ, PyCharm) to control NVIDIA Isaac Sim via MCP, providing tools for managing scenes, robots, sensors, and simulation state.
Integrates with NVIDIA Isaac Sim, providing 42 tools for controlling simulation scenes, objects, lighting, robots, sensors, materials, assets, action graphs, and simulation execution through natural language commands.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Isaac Sim MCP Serveradd a cube and a sphere to the scene at (0,0,0)"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Isaac Sim MCP Server
Natural language control for NVIDIA Isaac Sim through the Model Context Protocol (MCP).
Connect any MCP-compatible IDE (Cursor, VS Code, Claude Code, Windsurf, JetBrains) to a running Isaac Sim instance and control it with plain-English prompts -- create robots, build scenes, run simulations, and debug physics all from your editor.

Highlights
42 tools across 9 categories -- scene, objects, lighting, robots, sensors, materials, assets, simulation, graphs
107+ robots auto-discovered from the Isaac Sim asset library (Franka, UR, Unitree, Boston Dynamics, and more)
Step-and-observe debugging -- step the simulation and inspect prim positions, joint states, and physics in one call
Hot-reload -- iterate on Python controllers without restarting Isaac Sim
Multi-instance -- run multiple Isaac Sim sessions side by side on different ports
Built for Isaac Sim 5.1.0 with a modular adapter layer for version isolation
Installation
Option A: pip install (recommended)
pip install isaacsim-mcp-serverThis installs the MCP server and the isaacsim-mcp-server CLI. You still need the Isaac Sim extension from the repo (see Launching Isaac Sim below).
Option B: From source
git clone https://github.com/whats2000/isaacsim-mcp-server
cd isaacsim-mcp-server
./scripts/setup_python_env.shRequirements
Requirement | Version |
NVIDIA Isaac Sim |
|
Python |
|
| latest (for source install) |
Platform | Linux (Ubuntu 22.04+) |
Currently onlyLinux is supported. Windows support is planned. macOS is not supported because NVIDIA Isaac Sim does not run on macOS.
We are welcoming contributions to support other Isaac Sim versions. The adapter layer is designed for easy version isolation.
Quick Start
1. Set up the environment
If you installed from source:
./scripts/setup_python_env.sh2. Launch Isaac Sim with the extension
./scripts/run_isaac_sim.shYou should see in the logs:
Registered 41 command handlers
Isaac Sim MCP server started on localhost:8766export BEAVER3D_MODEL="<your beaver3d model name>"
export ARK_API_KEY="<your beaver3d api key>"
export NVIDIA_API_KEY="<your nvidia api key>"3. Connect your IDE
Add the MCP server to your editor. Replace the path with your actual repo location.
claude mcp add isaac-sim /path/to/isaacsim-mcp-server/scripts/run_mcp_server.shOr edit ~/.claude.json / .mcp.json:
{
"mcpServers": {
"isaac-sim": {
"command": "/path/to/isaacsim-mcp-server/scripts/run_mcp_server.sh"
}
}
}Create .vscode/mcp.json in your workspace:
{
"servers": {
"isaac-sim": {
"command": "/path/to/isaacsim-mcp-server/scripts/run_mcp_server.sh"
}
}
}Open Cursor Settings > MCP, or edit ~/.cursor/mcp.json:
{
"mcpServers": {
"isaac-sim": {
"command": "/path/to/isaacsim-mcp-server/scripts/run_mcp_server.sh"
}
}
}Edit the config file for your platform:
macOS:
~/Library/Application Support/Claude/claude_desktop_config.jsonWindows:
%APPDATA%\Claude\claude_desktop_config.jsonLinux:
~/.config/Claude/claude_desktop_config.json
{
"mcpServers": {
"isaac-sim": {
"command": "/path/to/isaacsim-mcp-server/scripts/run_mcp_server.sh"
}
}
}Open Windsurf Settings > MCP or edit ~/.codeium/windsurf/mcp_config.json:
{
"mcpServers": {
"isaac-sim": {
"command": "/path/to/isaacsim-mcp-server/scripts/run_mcp_server.sh"
}
}
}Go to Settings > Tools > AI Assistant > MCP Servers and add the server. See the JetBrains MCP docs for details.
4. Start prompting
Check the connection with get_scene_info.
If the scene is empty, create a physics scene.
Add a Franka robot at the origin and a Go1 quadruped at [2, 0, 0].Architecture
MCP Client (IDE)
|
v
isaacsim-mcp-server (PyPI package / CLI)
|
v TCP socket (localhost:8766)
|
isaac.sim.mcp_extension (Omniverse extension)
|
v
Handlers -> Adapter -> Isaac Sim 5.1.0 APIsTools
42 tools across 9 categories:
Category | Count | What you can do |
Scene | 7 | Inspect scenes, create physics, list/load environments, browse prims |
Objects | 4 | Create, delete, transform, and clone primitives |
Lighting | 2 | Create and tune lights |
Robots | 6 | Spawn 107+ robots, inspect joints, set positions, refresh library |
Sensors | 4 | Create cameras/LiDAR, capture images, get point clouds |
Materials | 2 | Create and apply materials |
Assets | 4 | Import URDF, load/search USD, generate 3D models |
Graphs | 2 | Build and edit Action Graphs (OnPlaybackTick, ScriptNode, script file attachment) |
Simulation | 11 | Play/pause/stop/step, execute Python, inspect physics, hot-reload |
Scene: get_scene_info create_physics_scene clear_scene list_prims get_prim_info list_environments load_environment
Objects: create_object delete_object transform_object clone_object
Lighting: create_light modify_light
Robots: create_robot list_available_robots refresh_robot_library get_robot_info set_joint_positions get_joint_positions
Sensors: create_camera capture_image create_lidar get_lidar_point_cloud
Materials: create_material apply_material
Assets: import_urdf load_usd search_usd generate_3d
Graphs: create_action_graph edit_action_graph
Simulation: play_simulation pause_simulation stop_simulation step_simulation set_physics_params get_isaac_logs get_simulation_state get_physics_state get_joint_config execute_script reload_script
Example Prompts
Scene bootstrap
Check the connection with get_scene_info. If the scene is empty, create a physics scene.
Add stronger lighting and place a camera that looks at the workspace.Robot layout
Create three Franka robots in a row at [0,0,0], [2,0,0], and [4,0,0].
Then add a Go1 robot at [1, 3, 0].Environment loading
List available environments, choose a warehouse-like one, and load it.
Create a camera and capture an image.Asset search and 3D generation
Search for a rusty desk, load the best result near [0, 5, 0], scaled to [2, 2, 2].Advanced Usage
Multiple Instances
Run multiple Isaac Sim sessions side by side. Each uses a different port (auto-assigned from 8766).
# First instance (default port 8766)
claude mcp add isaac-sim /path/to/isaacsim-mcp-server/scripts/run_mcp_server.sh
# Second instance (port 8767)
claude mcp add isaac-sim-2 -e ISAAC_MCP_PORT=8767 -- /path/to/isaacsim-mcp-server/scripts/run_mcp_server.sh{
"mcpServers": {
"isaac-sim": {
"command": "/path/to/isaacsim-mcp-server/scripts/run_mcp_server.sh"
},
"isaac-sim-2": {
"command": "/path/to/isaacsim-mcp-server/scripts/run_mcp_server.sh",
"env": { "ISAAC_MCP_PORT": "8767" }
}
}
}Desktop Launcher (Linux)
Install a dedicated Isaac Sim MCP application icon:
./scripts/install_desktop_entry.shThis creates a launcher that auto-assigns ports, waits for the extension socket, and cleans up on exit.
Recommended Workflow
Start with
get_scene_infoto verify the connectionCreate a physics scene if the stage is empty
Prefer purpose-built tools before
execute_scriptUse
list_available_robots/list_environmentsbefore loadingUse
create_action_graphto wire OnPlaybackTick → ScriptNode controllersUse
step_simulationwithobserve_primsandobserve_jointsfor debuggingUse
reload_scriptto iterate on controllers without restarting
Demo: Franka Pick-and-Place
A ready-to-run demo at demo/franka_pick_place.py using RMPflow for motion planning:
Please use the Isaac MCP tool complete this:
Create a physics scene with a ground plane, then spawn a Franka FR3 robot at the origin.
Add two textured tables with a gap along Y. Place a small textured cube with physics enabled on top of the first table.
Use `create_action_graph` to wire `OnPlaybackTick` → `ScriptNode`, and write a pick-and-place controller script using RMPflow for motion planning. Save the script to the `demo/` directory.
Use `get_prim_info` to query actual positions and sizes of the tables and cube before writing the controller — do not hardcode coordinates.
Start the simulation with Play. The robot should pick the cube from table 1 and place it on table 2. Verify the process using `step_simulation` with `observe_prims` on the cube to confirm it reaches table 2.Uses create_action_graph with script_file for one-step Action Graph + ScriptNode setup, plus the observability tools: get_joint_config, step_simulation with observe_prims, get_physics_state, and edit_action_graph for script hot-reload.
Development
# Run the MCP inspector
./.venv/bin/python -m mcp dev ./isaac_mcp/server.pyThe inspector is available at http://localhost:5173.
Setup Notes
Script | Purpose | Default |
| Create venv and install package | Python 3.10 |
| Launch Isaac Sim with extension |
|
| Start the MCP server | Port 8766 |
| Combined launcher | Auto-assigns port |
| Dev server with hot-reload | Port 8766 |
Override defaults:
PYTHON_SPEC=3.11 ./scripts/setup_python_env.sh
ISAACSIM_ROOT=/opt/isaacsim ./scripts/run_isaac_sim.shIf Isaac Sim says Can't find extension with name: isaac.sim.mcp_extension:
# Make sure you're in the repo root
pwd
test -f ./isaac.sim.mcp_extension/config/extension.toml && echo OKNote: --ext-folder must point to the repo root, not to isaac.sim.mcp_extension/ directly.
Contributing
Pull requests are welcome. Improvements to tools, docs, adapters, and tests are all useful.
License
MIT License. Copyright (c) 2023-2025 omni-mcp, Copyright (c) 2026 whats2000. See LICENSE.
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/whats2000/isaacsim-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server