Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rapiz1/catp
Print the output of a running process
https://github.com/rapiz1/catp
Last synced: 5 days ago
JSON representation
Print the output of a running process
- Host: GitHub
- URL: https://github.com/rapiz1/catp
- Owner: rapiz1
- License: gpl-3.0
- Created: 2022-07-23T12:32:06.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-07-27T12:28:17.000Z (over 2 years ago)
- Last Synced: 2025-02-08T12:03:49.965Z (12 days ago)
- Language: Rust
- Size: 1.01 MB
- Stars: 1,182
- Watchers: 4
- Forks: 26
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# catp
[data:image/s3,"s3://crabby-images/04bc4/04bc43e5751964b8a60ff3d3f8cd3c8dfdbb5e1c" alt="GitHub release (latest SemVer)"](https://github.com/rapiz1/catp/releases)
data:image/s3,"s3://crabby-images/51fe9/51fe9fda9c1ad25bad76c05e86ea1f902457ee94" alt="GitHub Workflow Status (branch)"Print the output of *a running process*
data:image/s3,"s3://crabby-images/dd0bf/dd0bf8bf83f471b45ed7697f697923cb55052037" alt="screenshot"
```plain
catp 0.2.0
Print the output of a running processUSAGE:
catp [OPTIONS]ARGS:
PID of the process to printOPTIONS:
-h, --help Print help information
-v, --verbose Print more verbose information to stderr
-V, --version Print version information
```## Why
Sometimes a process is redirected to `/dev/null` because we don't expect to check its output.
However, we may regret that decision and don't want to restart the process.Or we just don't know where a running process is printing to.
Then just type `catp`!
## How It Works
`catp` uses `ptrace` to intercept syscall and extracts data from the syscall `write`.
So it should work for most applications. Since it slows down the syscall, it may impact the performance of IO-sensitive applications.`catp` requires `ptrace` privilege to run, which in most systems means root.
## Get Started
Download the binary from [release](https://github.com/rapiz1/catp/releases). The one with `gnu` should work with a really recent glibc version. If that's not working, try the `musl` one.
## Platform
Currently only x86_64 Linux is supported.