os-control-mcp
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., "@os-control-mcplist all failed systemd units"
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.
os-control-mcp
The sanctioned OS "motor cortex" for an agent on a Linux box — control systemd, logind, journald, and D-Bus through structured interfaces, never raw PID hacks.
os-control-mcp is an MCP server — usable by any agent or MCP client
(Claude Code, Cursor, Cline, Goose, Continue, your own MCP host, …) — that gives
a model sanctioned control of a Linux host: manage systemd services and
timers, query journald, read host resources and processes, send desktop
notifications, drive the D-Bus buses, and manage power — all through the host's
structured interfaces (systemctl, loginctl, journalctl, busctl), never
raw kill/PID hacks. It is the system-service counterpart to
screen-mcp's GUI control. Pure standard
library, zero pip runtime deps. Linux + systemd.
Quickstart
Install the plugin in Claude Code:
/plugin marketplace add 88plug/os-control-mcp
/plugin install os-control-mcp@os-control-mcpThen confirm the server loaded and its tools are available:
/mcpNo setup needed — it uses the host's existing systemd/D-Bus tooling. Run the
os_diag tool first; it reports your privilege level and which backends are
present.
⚠️ Treat this plugin as privileged. It can stop services and power off the machine. The guards below make that hard to do by accident, but install it deliberately and disable it via
/pluginwhen you're not using it.
Related MCP server: systemd-mcp
Use from any MCP client
It's a plain stdio MCP server — no Claude-Code lock-in. Point any MCP client at
the launcher (or python3 server.py directly):
// e.g. Cursor / Cline / Goose / your own MCP host
{
"mcpServers": {
"os": { "command": "python3", "args": ["/path/to/os-control-mcp/server.py"] }
}
}It speaks MCP 2025-11-25 over stdio; the tools appear like any other MCP server.
Tools
Observe (read-only)
Tool | What |
| health: privilege, backends, manager state, bus reachability, safety status |
| inspect units — |
| journald — unit/since/until/priority/ |
| load + memory + disk (+ optional per-unit accounting) |
| top processes by cpu/mem |
| PSI from |
| sockets via |
| thermal-zone temperatures (+ |
| logind sessions / users / inhibitors |
Act (guarded)
Tool | What | Safety |
| start/stop/restart/reload/enable/disable/mask/kill/reset-failed/daemon-reload (single or batch) | hard floor + self-preservation guard; |
| block until a unit is active/inactive/failed (or timeout) | — |
| suspend/hibernate/reboot/poweroff/halt | needs |
| machine settings (timezone/NTP, hostname, locale/keymap) | writes need |
| list/tree/introspect/get-property/set-property/ | writes need |
| desktop notification to the logged-in user | — |
| hot-reload the server in place | — |
The guards (the whole point)
Three layers, plus an audit trail:
Hard floor (unbypassable). A severing action on the agent's absolute substrate —
dbus,systemd-logind,init.scope,-.slice,basic.target— is refused even withforce=true. There is no flag that lets a model power-cycle the bus it's speaking on.Self-preservation guard (
force-overridable). A severing action (stop/restart/disable/mask/kill) on a unit the agent stands on (sshd,NetworkManager/networkd,tailscaled, theuser@…session,goosed, …) is refused unlessforce=true— don't saw off the branch you're sitting on.Confirm / dry-run.
os_powerneedsconfirm=true; machine-setting writes andos_dbusset-property/callneedforce=true; any mutating tool acceptsdry_run=trueto return the exact command without running it.
Every mutation is appended to an audit log at
$XDG_STATE_HOME/os-control-mcp/audit.jsonl.
Privilege
Read-only tools work unprivileged. System-scope mutations (os_service on
system units, os_power) need root or polkit — when not root the server tries
sudo -n and otherwise tells you plainly. Options: run as root, add passwordless
sudo for systemctl, or a polkit rule. scope="user" manages the user's own
units with no root.
Documentation
Full per-tool reference and the safety model live at 88plug.github.io/os-control-mcp.
Pairs with
screen-mcp (GUI eyes + hands), NATS (messaging), and A2A (inter-agent) — together: sense the kernel/services, act on the system, drive the desktop, coordinate the fleet.
License
FSL-1.1-ALv2 — © 2026 88plug.
This server cannot be installed
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/88plug/os-control-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server