summaryrefslogtreecommitdiff
path: root/libpod/stats.go
diff options
context:
space:
mode:
authorMatthew Heon <mheon@redhat.com>2022-03-22 14:01:44 -0400
committerMatthew Heon <mheon@redhat.com>2022-03-30 15:36:05 -0400
commit82c01341f792462c78e9390c3c92b5487e26cdf3 (patch)
tree55bd74c571783e5669f643b91f94ccf26055c064 /libpod/stats.go
parent12ab78d3333d1b2bfcc6f4f4a13f88fea5657007 (diff)
downloadpodman-82c01341f792462c78e9390c3c92b5487e26cdf3.tar.gz
podman-82c01341f792462c78e9390c3c92b5487e26cdf3.tar.bz2
podman-82c01341f792462c78e9390c3c92b5487e26cdf3.zip
Fix a potential race around the exec cleanup process
Every exec session run attached will, on exit, do two things: it will signal the associated `podman exec` that it is finished (to allow Podman to collect the exit code and exit), and spawn a cleanup process to clean up the exec session (in case the `podman exec` process died, we still need to clean up). If an exec session is created that exits almost instantly, but generates a large amount of output (e.g. prints thousands of lines), the cleanup process can potentially execute before `podman exec` has a chance to read the exit code, resulting in errors. Handle this by detecting if the cleanup process has already removed the exec session before handling the error from reading the exec exit code. [NO NEW TESTS NEEDED] I have no idea how to test this in CI. Fixes #13227 Signed-off-by: Matthew Heon <mheon@redhat.com>
Diffstat (limited to 'libpod/stats.go')
0 files changed, 0 insertions, 0 deletions