#unix #daemon #process

daemonize

Library to enable your code run as a daemon process on Unix-like systems

14 releases

Uses old Rust 2015

0.5.0 Feb 25, 2023
0.4.1 Mar 27, 2019
0.3.0 Apr 7, 2018
0.2.3 Aug 29, 2016
0.1.0 Dec 25, 2015

#7 in Unix APIs

Download history 20949/week @ 2024-06-14 19868/week @ 2024-06-21 17169/week @ 2024-06-28 17819/week @ 2024-07-05 19465/week @ 2024-07-12 19716/week @ 2024-07-19 20996/week @ 2024-07-26 22169/week @ 2024-08-02 20973/week @ 2024-08-09 19447/week @ 2024-08-16 19086/week @ 2024-08-23 26767/week @ 2024-08-30 40056/week @ 2024-09-06 44203/week @ 2024-09-13 51945/week @ 2024-09-20 46214/week @ 2024-09-27

189,605 downloads per month
Used in 136 crates (108 directly)

MIT/Apache

27KB
600 lines

daemonize Build Status Latest Version docs

daemonize is a library for writing system daemons. Inspired by the Python library thesharp/daemonize.

Usage example:

extern crate daemonize;

use std::fs::File;

use daemonize::Daemonize;

fn main() {
    let stdout = File::create("/tmp/daemon.out").unwrap();
    let stderr = File::create("/tmp/daemon.err").unwrap();

    let daemonize = Daemonize::new()
        .pid_file("/tmp/test.pid") // Every method except `new` and `start`
        .chown_pid_file(true)      // is optional, see `Daemonize` documentation
        .working_directory("/tmp") // for default behaviour.
        .user("nobody")
        .group("daemon") // Group name
        .group(2)        // or group id.
        .umask(0o777)    // Set umask, `0o027` by default.
        .stdout(stdout)  // Redirect stdout to `/tmp/daemon.out`.
        .stderr(stderr)  // Redirect stderr to `/tmp/daemon.err`.
        .privileged_action(|| "Executed before drop privileges");

    match daemonize.start() {
        Ok(_) => println!("Success, daemonized"),
        Err(e) => eprintln!("Error, {}", e),
    }
}

License

Licensed under either of

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~43KB