rest: daemon: sd notify barrier: allow caller to set timeout
else it's rather to subtle and not a nice interface considering that we only want to have a thin wrapper for sd_notify_barrier.. Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
This commit is contained in:
parent
9a1330c72e
commit
058b4b9708
@ -188,7 +188,7 @@ impl Reloader {
|
|||||||
}
|
}
|
||||||
// ensure systemd got the message about the new main PID before continuing, else it
|
// ensure systemd got the message about the new main PID before continuing, else it
|
||||||
// will get confused if the new main process sends its READY signal before that
|
// will get confused if the new main process sends its READY signal before that
|
||||||
if let Err(e) = systemd_notify_barrier() {
|
if let Err(e) = systemd_notify_barrier(u64::MAX) {
|
||||||
log::error!("failed to wait on systemd-processing: {}", e);
|
log::error!("failed to wait on systemd-processing: {}", e);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -293,7 +293,7 @@ where
|
|||||||
if let Err(e) = systemd_notify(SystemdNotify::Reloading) {
|
if let Err(e) = systemd_notify(SystemdNotify::Reloading) {
|
||||||
log::error!("failed to notify systemd about the state change: {}", e);
|
log::error!("failed to notify systemd about the state change: {}", e);
|
||||||
}
|
}
|
||||||
if let Err(e) = systemd_notify_barrier() {
|
if let Err(e) = systemd_notify_barrier(u64::MAX) {
|
||||||
log::error!("failed to wait on systemd-processing: {}", e);
|
log::error!("failed to wait on systemd-processing: {}", e);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -329,8 +329,8 @@ pub enum SystemdNotify {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Waits until all previously sent messages with sd_notify are processed
|
/// Waits until all previously sent messages with sd_notify are processed
|
||||||
pub fn systemd_notify_barrier() -> Result<(), Error> {
|
pub fn systemd_notify_barrier(timeout: u64) -> Result<(), Error> {
|
||||||
let rc = unsafe { sd_notify_barrier(0, u64::MAX) }; // infinite timeout
|
let rc = unsafe { sd_notify_barrier(0, timeout) };
|
||||||
if rc < 0 {
|
if rc < 0 {
|
||||||
bail!(
|
bail!(
|
||||||
"systemd_notify_barrier failed: {}",
|
"systemd_notify_barrier failed: {}",
|
||||||
|
Loading…
Reference in New Issue
Block a user