Skip to content

Commit

Permalink
fix(api-boundary-node): make ic-boundary create its own process group
Browse files Browse the repository at this point in the history
  • Loading branch information
r-birkner committed May 17, 2024
1 parent c798937 commit 1e3ed9e
Show file tree
Hide file tree
Showing 4 changed files with 12 additions and 0 deletions.
1 change: 1 addition & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions rs/boundary_node/ic_boundary/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ DEPENDENCIES = [
"@crate_index//:mockall",
"@crate_index//:moka",
"@crate_index//:nftables",
"@crate_index//:nix",
"@crate_index//:prometheus",
"@crate_index//:rand",
"@crate_index//:ratelimit",
Expand Down
1 change: 1 addition & 0 deletions rs/boundary_node/ic_boundary/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ maxminddb = "0.24"
mockall = { workspace = true }
moka = { version = "0.12", features = ["sync", "future"] }
nftables = "0.4"
nix = { workspace = true }
prometheus = { workspace = true }
rand = "0.8.4"
ratelimit = "0.9.1"
Expand Down
9 changes: 9 additions & 0 deletions rs/boundary_node/ic_boundary/src/core.rs
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ use ic_registry_replicator::RegistryReplicator;
use ic_types::crypto::threshold_sig::ThresholdSigPublicKey;
use ic_types::CanisterId;
use little_loadshedder::{LoadShedError, LoadShedLayer};
use nix::unistd::{getpgid, setpgid, Pid};
use prometheus::Registry;
use rustls::cipher_suite::{TLS13_AES_128_GCM_SHA256, TLS13_AES_256_GCM_SHA384};
use tokio::sync::RwLock;
Expand Down Expand Up @@ -107,6 +108,14 @@ pub async fn main(cli: Cli) -> Result<(), Error> {
panic!("--local-store-path and --stub-replica are mutually exclusive and at least one of them must be specified");
}

// make sure ic-boundary is the leader of its own process group
let pgid = getpgid(None).context("Failed to get the process group ID.")?;
if pgid != Pid::this() {
// If that is not the case, set it as the leader of its own process group
setpgid(Pid::from_raw(0), Pid::from_raw(0))
.context("Failed to setup a new process group for ic-boundary.")?;
}

// Metrics
let metrics_registry = Registry::new_custom(Some(SERVICE_NAME.into()), None)?;

Expand Down

0 comments on commit 1e3ed9e

Please sign in to comment.