8 releases

0.4.2 Nov 8, 2024
0.4.1 Nov 6, 2024
0.3.0 Oct 23, 2024
0.2.10 Oct 15, 2024
0.2.8 Aug 25, 2024

#517 in Unix APIs

GPL-2.0-only

44KB
887 lines

pipelight_exec crate

Internal crate from pipelight.


lib.rs:

Warning - Unstable crate.

This crate is still in development and undergoing API changes.

It is internally used in the pipelight cicd engine: https://github.com/pipelight/pipelight

Breanking changes

  • v0.4 : New API for easier process manipulation. p.run_detached() becomes p.detach().run();

About

A crate for easy process management (on Unix systems).

It makes a best effort to leverage the standard library process crate.

Features:

  • Get process execution time.

  • Spawn and Kill background processes.

  • Display a running process standard inputs/outputs.

  • Interoperability with rustix and sysinfo crates.

Usage

Spawn a process

Spawn a simple process in the background. or in other words, execute a process and detach it.

It keeps running after parent process exit and terminal exit.


// Runs a child process and wait until execution is over.
let mut p = Process::new()
    .stdin("echo test")
    .to_owned();
p.run()?;

Runs child process in the background. Do not wait until process is over and return as soon as child is spawned.


let mut p = Process::new()
    .stdin("echo test")
    .background()
    .to_owned();
p.run()?;

Runs a disowned child process that won't be killed if parent is killed. Do not wait until process is over and return as soon as child is spawned.


let mut p = Process::new()
    .stdin("echo test")
    .detach()
    .to_owned();
p.run()?;

Runs a disowned child process that won't be killed if parent is killed. and stores process outputs in ./.pipelight/proc/:uuid/ Practical if you want to process child output from another program.


let mut p = Process::new()
    .stdin("echo test")
    .fs()
    .detach()
    .to_owned();
p.run()?;

Read a process i/o.


let mut p = Process::new()
    .stdin("echo test")
    .background()
    .fs()
    .to_owned();
p.run()?;

// Later in execution
p.io.read().into_diagnostic()?;
println!("{:?}", p.io.stdout); // Some("stuff\n")

Find a process.

Find a running process, with handy search options.


let process_finder = Finder::new().seed("my_proc").root("/my/dir").search()?;

let pid = 1792;
let process_finder = Finder::new().pid(&pid).search()?;

Beware - Unconventional process management

In linux, a process inputs and outputs are exposed at /proc/:process_id/fd/:fd_id and are deleted as soon as the process finishes its execution.

A very good straightforward rustacean overview at procfs crate

To keep track of running and dead processes, this crate can redirect some process i/o into its own managed files. Pipelight managed processes are stored in a the .pipelight/proc/ directory. It has the same structure as your /proc/.

However, to ease ones developer life, standard outputs are polled, read and finally stored as text files. /proc/:pid/2 (file descriptor / buffer)-> ./pipelight/proc/:uuid/2(text file)

For example, The following code runs a process whose outputs are redirected to pipelight temporary filesystem thanks to the fs() method.


let p = Process::new().stdin("pwd").fs().run()?;
p.io.read().into_diagnostic()?;
let stdout: Option<String> = p.io.stdout;

It allows us to read a process outputs during and long after execution.

Dependencies

~12–22MB
~341K SLoC