portio
Version:
A beautiful terminal UI for managing processes on network ports (Windows only)
151 lines (111 loc) ⢠5.32 kB
Markdown
# š PORTIO - The Port Pal You've Been Waiting For
[](https://www.npmjs.com/package/portio)
[](https://opensource.org/licenses/MIT)
[](https://github.com/bezalel6/portio)
A beautiful terminal UI for managing processes on network ports. Quickly identify and kill processes occupying your development ports with style.
## We All Know This Feeling
Maybe you were doing some work, maybe you closed out of the IDE without killing the development server.
Next time you try to launch it, you see the port's occupado and your heart sinks.
```
Error: listen EADDRINUSE: address already in use :::3000
```
Now you have two options, each worse than the other:
- Open Task Manager and start playing `node.exe` roulette until the port's free again
- Give up on it let the port roll over. Let that `localhost:3000` dream die for the foreseeable boot-time of your machine
## Enter PORTIO
PORTIO shows you what actually matters:
```
āāāāāāā¬āāāāāāāā¬āāāāāāāā¬āāāāāāāāāāāā¬āāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāā
ā # ā PID ā Port ā Process ā Command ā
āāāāāāā¼āāāāāāāā¼āāāāāāāā¼āāāāāāāāāāāā¼āāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāā¤
ā 1 ā 12345 ā 3000 ā node.exe ā next ā
ā 2 ā 67890 ā 8080 ā node.exe ā nodemon ā
ā 3 ā 11111 ā 5173 ā node.exe ā vite ā
āāāāāāā“āāāāāāāā“āāāāāāāā“āāāāāāāāāāāā“āāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāā
```
## š Quick Start
No installation needed! Just run:
```bash
npx portio
```
Or install globally:
```bash
npm install -g portio
portio
```
### š” Pro Tip: Chain with your dev server!
```bash
# Ensure port 3000 is free before starting your server
portio -m 3000 && npm run dev
# Works with any server command
portio --mine 8080 && python -m http.server 8080
portio -m 5173 && npm run vite
```
## š Usage
### Interactive Mode (Default)
```bash
portio # Show all listening ports
portio --dev # Show only development ports
```
### Quick Commands
```bash
portio --mine 3000 # Force kill process on port 3000 (no confirmation)
portio -m 3000 # Short version - perfect for chaining!
portio --check 3000 # Check what's running on port 3000
portio --kill 3000 # Kill process on port 3000 (with confirmation)
portio --list # Get JSON output of all processes
```
### Interactive Controls
| Key | Action |
|-----|--------|
| `ā/ā` | Navigate through processes |
| `Enter` | Kill selected process |
| `/` | Search/filter processes |
| `r` | Refresh list |
| `d` | Toggle dev/all ports |
| `v` | Toggle verbose mode |
| `p` | Toggle full paths/filenames |
| `c` | Clear filter |
| `q` | Quit |
| `A` | Admin kill (when normal kill fails) |
## šØ Port Color Coding
- š“ **System Ports** (< 1024) - Red
- š¢ **Dev Ports** (3000-10000) - Teal
- š” **Registered** (1024-49151) - Yellow
- š¢ **Ephemeral** (49152+) - Green
## š ļø Development Ports
Dev mode focuses on commonly used development ports:
- **3000-3005** - React, Node.js
- **4000-4001, 4200-4201** - Angular
- **5000-5001, 5173-5175** - Vite, Flask
- **8000-8001, 8080-8083** - Django, Spring
- **8888** - Jupyter
- **9000-9001, 9200, 9229** - PHP, Elasticsearch, Node Debug
- **19000-19002** - React Native
## š„ļø System Requirements
- **Windows 10/11**
- **Node.js 16+**
- **Terminal**: Windows Terminal, PowerShell, or Git Bash (CMD not recommended)
## Development
```bash
git clone https://github.com/bezalel6/portio.git
cd portio
npm install
npm run build
node dist/cli.js
```
## The Tech Stack
PORTIO uses modern terminal UI capabilities:
- **[Ink](https://github.com/vadimdemedes/ink)** - React for CLIs
- **[ink-table](https://github.com/maticzav/ink-table)** - Beautiful terminal tables
- **[ink-text-input](https://github.com/vadimdemedes/ink-text-input)** - Smooth text input
- **[meow](https://github.com/sindresorhus/meow)** - CLI app helper
- **[chalk](https://github.com/chalk/chalk)** - Terminal styling
## Why PORTIO?
Because every developer has a right to know what is running on their computers. No more port-induced chaos. Killing a process has to be a specifically targeted action, not slots. It's tough, but fair, like King Solomon.
## š¤ Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
## š License
MIT - Do whatever you want with it. Just don't blame me if you kill something important.
---
*Made with ā¤ļø and frustration by developers tired of `netstat -ano | findstr :3000`*