Set up and use portless for named local dev server URLs (e.g. http://myapp.localhost instead of http://localhost:3000). Use when integrating portless into a project, configuring dev server names, setting up the local proxy, working with .localhost domains, or troubleshooting port/proxy issues.
Replace port numbers with stable, named .localhost URLs. For humans and agents.
EADDRINUSE when two projects default to the same portlocalhost bleed across apps; localStorage lost when ports shift.env files break when ports changelocalhost:3000 history is a mix of unrelated projectsportless is a global CLI tool. Do NOT add it as a project dependency (no npm install portless or pnpm add portless in a project). Do NOT use npx.
Install globally:
npm install -g portless
# Install globally
npm install -g portless
# Start the proxy (once, no sudo needed)
portless proxy start
# Run your app (auto-starts the proxy if needed)
portless myapp next dev
# -> http://myapp.localhost:1355
The proxy auto-starts when you run an app. You can also start it explicitly with portless proxy start.
{
"scripts": {
"dev": "portless myapp next dev"
}
}
The proxy auto-starts when you run an app. Or start it explicitly: portless proxy start.
portless myapp next dev # http://myapp.localhost:1355
portless api.myapp pnpm start # http://api.myapp.localhost:1355
portless docs.myapp next dev # http://docs.myapp.localhost:1355
Set PORTLESS=0 or PORTLESS=skip to run the command directly without the proxy:
PORTLESS=0 pnpm dev # Bypasses proxy, uses default port
portless proxy start starts an HTTP reverse proxy on port 1355 as a background daemon (configurable with -p / --port or the PORTLESS_PORT env var). The proxy also auto-starts when you run an app.portless <name> <cmd> assigns a random free port (4000-4999) via the PORT env var and registers the app with the proxyhttp://<name>.localhost:1355 on the proxy port; the proxy forwards to the app's assigned port.localhost domains resolve to 127.0.0.1 natively on macOS and Linux -- no /etc/hosts editing needed.
Most frameworks (Next.js, Express, Nuxt, etc.) respect the PORT env var automatically. For frameworks that ignore PORT (Vite, Astro, React Router, Angular), portless auto-injects the correct --port and --host CLI flags.
Portless stores its state (routes, PID file, port file) in a directory that depends on the proxy port:
/tmp/portless~/.portlessOverride with the PORTLESS_STATE_DIR environment variable.
| Variable | Description |
|---|---|
PORTLESS_PORT | Override the default proxy port (default: 1355) |
PORTLESS_HTTPS | Set to 1 to always enable HTTPS/HTTP/2 |
PORTLESS_STATE_DIR | Override the state directory |
PORTLESS=0|skip | Bypass the proxy, run the command directly |
Use --https for HTTP/2 multiplexing (faster page loads for dev servers with many files):
portless proxy start --https # Auto-generate certs and trust CA
portless proxy start --cert ./c.pem --key ./k.pem # Use custom certs
sudo portless trust # Add CA to trust store later
First run generates a local CA and prompts for sudo to add it to the system trust store. After that, no prompts and no browser warnings. Set PORTLESS_HTTPS=1 in .bashrc/.zshrc to make it permanent.
| Command | Description |
|---|---|
portless <name> <cmd> [args...] | Run app at http://<name>.localhost:1355 (auto-starts proxy) |
portless list | Show active routes |
portless trust | Add local CA to system trust store (for HTTPS) |
portless proxy start | Start the proxy as a daemon (port 1355, no sudo) |
portless proxy start --https | Start with HTTP/2 + TLS (auto-generates certs) |
portless proxy start -p <number> | Start the proxy on a custom port |
portless proxy start --foreground | Start the proxy in foreground (for debugging) |
portless proxy stop | Stop the proxy |
portless --help / -h | Show help |
portless --version / -v | Show version |
The proxy auto-starts when you run an app with portless <name> <cmd>. If it doesn't start (e.g. port conflict), start it manually:
portless proxy start
Another process is bound to the proxy port. Either stop it first, or use a different port:
portless proxy start -p 8080
Portless auto-injects --port and --host flags for frameworks that ignore the PORT env var: Vite, Astro, React Router, and Angular. SvelteKit uses Vite internally and is handled automatically.
For other frameworks that don't read PORT, pass the port manually:
--port $PORTprocess.env.PORT and listen on itPorts below 1024 require sudo. The default port (1355) does not need sudo. If you want to use port 80:
sudo portless proxy start -p 80 # Port 80, requires sudo
portless proxy start # Port 1355, no sudo needed
portless proxy stop # Stop (use sudo if started with sudo)
The local CA may not be trusted yet. Run:
sudo portless trust
This adds the portless local CA to your system trust store. After that, restart the browser.
openssl (for --https cert generation; ships with macOS and most Linux distributions)