#daemon-process #daemon #process #daemonize #setsid

fork

Library for creating a new process detached from the controlling terminal (daemon)

25 releases

0.2.0 Jul 19, 2024
0.1.23 Feb 1, 2024
0.1.22 Jun 6, 2023
0.1.21 Mar 12, 2023
0.1.9 Oct 28, 2019

#95 in Operating systems

Download history 17973/week @ 2024-11-21 22784/week @ 2024-11-28 25139/week @ 2024-12-05 33691/week @ 2024-12-12 7599/week @ 2024-12-19 5026/week @ 2024-12-26 20153/week @ 2025-01-02 32469/week @ 2025-01-09 28257/week @ 2025-01-16 22342/week @ 2025-01-23 28787/week @ 2025-01-30 44194/week @ 2025-02-06 41124/week @ 2025-02-13 41508/week @ 2025-02-20 42173/week @ 2025-02-27 36418/week @ 2025-03-06

170,932 downloads per month
Used in 29 crates (27 directly)

BSD-3-Clause

11KB
81 lines

fork

crates.io Build codecov docs

Library for creating a new process detached from the controlling terminal (daemon).

Why?

  • Minimal library to daemonize, fork, double-fork a process.
  • daemon(3) has been deprecated in MacOSX 10.5, by using fork and setsid syscalls, new methods can be created to achieve the same goal.

Example:

Create a new test project:

$ cargo new --bin myapp

To install cargo use: curl https://sh.rustup.rs -sSf | sh

Add fork as a depdendecie:

cargo add fork

or Edit myapp/Cargo.toml and add to [dependencies]:

fork = "0.1"

Add the following code to myapp/main.rs

use fork::{daemon, Fork};
use std::process::Command;

fn main() {
    if let Ok(Fork::Child) = daemon(false, false) {
        Command::new("sleep")
            .arg("300")
            .output()
            .expect("failed to execute process");
    }
}

If using daemon(false, false),it will chdir to / and close the standard input, standard output, and standard error file descriptors.

Test running:

$ cargo run

Use ps to check the process, for example:

$ ps -axo ppid,pid,pgid,sess,tty,tpgid,stat,uid,%mem,%cpu,command, | egrep "myapp|sleep|PID"

egrep is used to show the ps headers

Output should be something like:

 PPID   PID  PGID   SESS TTY      TPGID STAT   UID       %MEM  %CPU COMMAND
    1 48738 48737      0 ??           0 S      501        0.0   0.0 target/debug/myapp
48738 48753 48737      0 ??           0 S      501        0.0   0.0 sleep 300
  • PPID == 1 that's the parent process

  • TTY = ?? no controlling terminal

  • new PGID = 48737

    1 - root (init/launchd)
     \-- 48738 myapp        PGID - 48737
      \--- 48753 sleep      PGID - 48737
    

Dependencies

~44KB