#file-descriptor #systemd #linux #pure #accept #api-bindings #helper

sd-listen-fds

Minimal, pure-rust helper to accept file descriptors from systemd

2 unstable releases

0.2.0 Aug 27, 2023
0.1.0 Jul 31, 2023

#727 in Unix APIs

Download history 39/week @ 2024-09-24 50/week @ 2024-10-01 52/week @ 2024-10-08 478/week @ 2024-10-15 777/week @ 2024-10-22 385/week @ 2024-10-29 80/week @ 2024-11-05 40/week @ 2024-11-12 408/week @ 2024-11-19 552/week @ 2024-11-26 738/week @ 2024-12-03 183/week @ 2024-12-10 145/week @ 2024-12-17 10/week @ 2024-12-24 13/week @ 2024-12-31 55/week @ 2025-01-07

251 downloads per month

MIT/Apache

8KB
114 lines

sd-listen-fds

Documentation License: Apache 2.0 License: MIT

Exposes file descriptors passed in by systemd, the Linux init daemon, without dependencies, foreign or otherwise. Enables easy implementation of socket-activated services in pure Rust.

Unlike services that open sockets themselves, socket-activated services are started on-demand, may start up concurrently with their dependencies, and may be restarted without losing inbound data. Portable applications can call sd_listen_fds::get() and open their own socket if it succeeds with an empty Vec.

See also the sd_listen_fds API exposed by the foreign libsystemd library. Compared to using libsystemd bindings, this crate is smaller, safer, and builds everywhere.

Example

let fds = sd_listen_fds::get().unwrap();
let (_name, fd) = fds
    .into_iter()
    .next()
    .expect("must be launched as a systemd socket-activated service");
let socket = TcpListener::from(fd);

my-service.socket (see also systemd.socket)

[Socket]
# TCP port number. Other types of sockets are also possible.
ListenStream=1234

[Install]
WantedBy=sockets.target

[Unit]
Description=My Rust service
Documentation=https://example.com/my-service/

my-service.service (see also systemd.service)

[Service]
ExecStart=/path/to/my-service

[Unit]
Requires=my-service.socket
Description=My Rust service
Documentation=https://example.com/my-service/

License

Licensed under either of

at your option.

Contribution

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

No runtime deps