- Native sessions use the built-in microsandbox SSH client. No host
sshbinary, TCP listener, or authorized key is required, which makes it the quickest path for a shell frommsbor SSH semantics from the SDK. - External clients serve the sandbox as an SSH server so standard tools such as
ssh,sftp, andProxyCommandcan connect.
Native sessions
Native sessions keep the SSH protocol boundary but do not expose a listener.CLI
--, the remaining tokens become the SSH command string and run through the sandbox shell.
serve or authorize, use --name:
SDK
Interactive attach
SDK clients can attach the local terminal to an SSH shell. This requires a real terminal.SFTP
The native SSH client can open SFTP over the same SSH connection.External clients
External client mode exposes a sandbox as an SSH server for tools that already speak SSH. This is the closest match for normal SSH usage: authorize a public key, serve the sandbox, then connect withssh or sftp.
Authorize a key
<MSB_HOME>/ssh/authorized_keys.
TCP listener
127.0.0.1:2222.
Binding to
0.0.0.0 exposes the SSH listener beyond the local machine. Keep the default loopback bind unless you intentionally want remote clients to connect.Port forwarding
OpenSSH local (-L) and dynamic (-D) forwarding work through the listener:
127.0.0.1 refers to the sandbox’s loopback interface rather than the host’s. Reverse forwarding (-R) and stream-local forwarding are not supported.
ProxyCommand
msb ssh serve --stdio carries a single SSH connection over stdin/stdout instead of a TCP listener. Point OpenSSH at it with ProxyCommand so standard SSH tools can reach the sandbox by host alias.
Add an entry to your ~/.ssh/config:
~/.ssh/config
Host value is the alias you connect to, and devbox is the sandbox name passed to msb ssh serve.
Once it is in place, the alias works with any OpenSSH-based tool:
devbox.msb host the same way.
For exact SDK signatures, see the SSH reference for Rust, TypeScript, Python, or Go.