Skip to content

Commit

Permalink
Merge pull request #1104 from rust-lang/log-kill-failure
Browse files Browse the repository at this point in the history
Log when killing the Docker container executes but fails
  • Loading branch information
shepmaster authored Oct 7, 2024
2 parents 214b04e + 0e838c1 commit efd614b
Showing 1 changed file with 21 additions and 6 deletions.
27 changes: 21 additions & 6 deletions compiler/base/orchestrator/src/coordinator.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2546,9 +2546,8 @@ impl TerminateContainer {

async fn terminate_now(&mut self) -> Result<(), TerminateContainerError> {
if let Some(mut kill_child) = self.take_command() {
// [ALREADY-DEAD] We don't care if the command itself
// succeeds or not; the container may already be dead!
let _ = kill_child.status().await?;
let o = kill_child.output().await?;
Self::report_failure(o);
}

Ok(())
Expand All @@ -2563,14 +2562,30 @@ impl TerminateContainer {
kill_child
})
}

fn report_failure(s: std::process::Output) {
// We generally don't care if the command itself succeeds or
// not; the container may already be dead! However, let's log
// it in an attempt to debug cases where there are more
// containers running than we expect.

if !s.status.success() {
let code = s.status.code();
// FUTURE: use `_owned`
let stdout = String::from_utf8_lossy(&s.stdout);
let stderr = String::from_utf8_lossy(&s.stderr);

error!(?code, %stdout, %stderr, "Killing the container failed");
}
}
}

impl Drop for TerminateContainer {
fn drop(&mut self) {
if let Some(mut kill_child) = self.take_command() {
if let Err(e) = kill_child.as_std_mut().status() {
// See [ALREADY-DEAD]
error!("Unable to kill the container while dropping: {e}");
match kill_child.as_std_mut().output() {
Ok(o) => Self::report_failure(o),
Err(e) => error!("Unable to kill the container while dropping: {e}"),
}
}
}
Expand Down

0 comments on commit efd614b

Please sign in to comment.