Ensure only one instance of your process runs at a time.
Project description
Runce
🚀 The One-and-Done Process Wrangler
"Runce and done! No repeats, no retreats!" 🏃♂️💨
🔒 Guaranteed Singleton Execution • 📊 Process Tracking • ⏱️ Lifecycle Management
☕ Support
If you find this project helpful, consider supporting me:
Features ✨
- 🚫 No Duplicates: Each command runs exactly once per unique ID
- 📝 Process Tracking: View all managed processes with status
- ⏱️ Execution Time: Track how long processes have been running
- 📂 Log Management: Automatic stdout/stderr capture
- 🛑 Clean Termination: Proper process killing
Installation 📦
pip install runce
Usage
runce <command> [options] [arguments]
Commands
run
Runs a new singleton process.
runce run [options] ARG...
Options:
--id <run_id>: Unique run identifier (required).--cwd <cwd>: Working directory for the command.-t <tail>/--tail <tail>: Tail the output (n lines). Use-t -1to print the entire output.--overwrite: Overwrite existing entry if it exists.--run-after <command>: Run a command after the main command finishes.--split: Dont merge stdout and stderr
Example:
runce run --id my-unique-task sleep 60
ls / list
Lists all managed processes.
runce ls [options]
Options:
-f <format>/--format <format>: Format of the output line (see examples below).
Example:
runce ls
runce ls -f "{pid}\t{name}\t{command}"
status
Checks the status of processes.
runce status [options] [ID...]
Options:
-f <format>/--format <format>: Format of the output line.
Example:
runce status my-unique-task
kill
Kills running processes.
runce kill [options] ID...
Options:
--dry-run: Perform a dry run (don't actually kill).--remove: Remove the entry after killing.
Example:
runce kill my-unique-task
clean
Cleans up entries for non-existing processes.
runce clean [ID...]
Example:
runce clean
tail
Tails the output of processes.
runce tail [options] [ID...]
Options:
-n <lines>/--lines <lines>: Number of lines to tail.--header <format>: Header format.-x/--only-existing: Only show existing processes.-t/--tab: Prefix tab space to each line.
Example:
runce tail my-unique-task
runce tail -n 20 my-unique-task
restart
Restarts a process.
runce restart [options] ID...
Options:
-t <tail>/--tail <tail>: Tail the output after restarting.
Example:
runce restart my-unique-task
Examples 💡
1. Running a Background Service
runce run --id api-server -- python api.py
2. Checking Live Processes
$ runce list
PID NAME STATUS ELAPSED COMMAND
1234 api-server ✅ Live 01:23:45 python api.py
5678 worker ❌ Gone 00:45:30 python worker.py
3. Preventing Duplicates
$ runce run --id daily-job -- python daily.py
🚀 Started: PID:5678(✅ Live) daily-job
$ runce run --id daily-job -- python daily.py
🚨 Already running: PID:5678(✅ Live) daily-job
Formats
The -f / --format option in the ls and status commands allows you to customize the output format. You can use the following placeholders:
{pid}: Process ID{name}: Run ID / Name{pid_status}: Process status ("✅ Live" or "👻 Gone"){elapsed}: Elapsed time{command}: The command being executed
How It Works
RunCE stores process information in JSON files within a temporary directory (/tmp/runce.v1 on Linux). Before starting a new process, it checks for existing entries with the same ID to prevent duplicates.
Development 🏗️
# Install in development mode
pip install -e .
# Run tests
pytest
# Lint code
flake8 runce
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file runce-0.4.0.tar.gz.
File metadata
- Download URL: runce-0.4.0.tar.gz
- Upload date:
- Size: 33.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.17
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3982c82910884a120e6ebc320294c29b718ce45e1f289fe0e442a74ba02ab608
|
|
| MD5 |
4ba431edc9bb05e2fd12a7994d8e9d1c
|
|
| BLAKE2b-256 |
d2a8c8e4b43a03cd095ed487fd1b5ccc2bcd6bc41678353451c8c2cab3459769
|
File details
Details for the file runce-0.4.0-py3-none-any.whl.
File metadata
- Download URL: runce-0.4.0-py3-none-any.whl
- Upload date:
- Size: 26.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.17
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
069f28111aec379b7695f67fead20ecb81568a905fe132243666c370394fc0ef
|
|
| MD5 |
dca925fca7197b7f3b8235f0ea75d560
|
|
| BLAKE2b-256 |
01f5d2f5fe23630d69c1740e67650eb4720f7923aa8e827eabc934e97635cdec
|