#process #init #cli

pid1

pid1 handling library for proper signal and zombie reaping of the PID1 process

2 releases

0.1.1 Oct 4, 2023
0.1.0 Oct 3, 2023

#2649 in Command line utilities

Download history 963/week @ 2024-07-20 1806/week @ 2024-07-27 338/week @ 2024-08-03 1130/week @ 2024-08-10 859/week @ 2024-08-17 874/week @ 2024-08-24 2476/week @ 2024-08-31 1401/week @ 2024-09-07 706/week @ 2024-09-14 1092/week @ 2024-09-21 544/week @ 2024-09-28 533/week @ 2024-10-05 924/week @ 2024-10-12 838/week @ 2024-10-19 655/week @ 2024-10-26 849/week @ 2024-11-02

3,377 downloads per month
Used in 3 crates (2 directly)

MIT license

12KB
160 lines

pid1-rs

Rust

pid1 handling library for proper signal and zombie reaping of the PID1 process.

This repository consists of two packages:

  • pid1 crate: Library meant to be used by your Rust applications.
  • pid1-exe crate: Binary which internally uses pid1 crate for container deployments. The binary name is pid1.

pid1 Library Usage

This library is used to simplify Rust deployment in a containerized environment. Instead of using binaries like Haskell's pid1 or tini in your container, you can use this crate directly.

You must ensure that the launch method is the first statement in your main function:

use std::time::Duration;
use pid1::Pid1Settings;

fn main() {
    Pid1Settings::new()
        .enable_log(true)
        .timeout(Duration::from_secs(2))
        .launch()
        .expect("Launch failed");
    println!("Hello world");
    // Rest of the logic...
}

You can also see various example usages here. This function is meant only for Unix systems and the above code is a no-op in Windows.

Using pid1 binary

You can download the pid1 binary that is part of the releases and use it in your container directly. Example:

FROM alpine:3.14.2

ADD https://github.com/fpco/pid1-rs/releases/download/v0.1.0/pid1-x86_64-unknown-linux-musl /usr/bin/pid1

RUN chmod +x /usr/bin/pid1

ENTRYPOINT [ "pid1" ]

Development

The testing steps are documented in Development.md. We only have some part of it integrated in CI.

Dependencies

~2.5MB
~54K SLoC