knsd/daemonize
Library for writing system daemons
{ "createdAt": "2015-06-08T08:14:08Z", "defaultBranch": "master", "description": "Library for writing system daemons", "fullName": "knsd/daemonize", "homepage": "", "language": "Rust", "name": "daemonize", "pushedAt": "2024-02-14T20:32:02Z", "stargazersCount": 576, "topics": [ "daemon", "daemonize", "linux", "osx", "rust", "system" ], "updatedAt": "2025-11-26T21:20:47Z", "url": "https://github.com/knsd/daemonize"}daemonize

Section titled “daemonize ”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
Section titled “License”Licensed under either of
- Apache License, Version 2.0 ([LICENSE-APACHE]!(LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license ([LICENSE-MIT]!(LICENSE-MIT) or http://opensource.org/licenses/MIT) at your option.
Contribution
Section titled “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.