mirror of
https://github.com/containers/podman.git
synced 2025-10-14 09:45:59 +08:00
generate systemd: warn on --restart without --new
Emit a warning to the user when generating a unit with --new on a container that was created with a custom --restart policy. As shown in #15284, a custom --restart policy in that case can lead to issues on system shutdown where systemd attempts to nuke the unit but Podman keeps on restarting the container. Fixes: #15284 Signed-off-by: Valentin Rothberg <vrothberg@redhat.com>
This commit is contained in:
@ -148,6 +148,18 @@ func generateContainerInfo(ctr *libpod.Container, options entities.GenerateSyste
|
||||
return nil, errors.New("conmon PID file path is empty, try to recreate the container with --conmon-pidfile flag")
|
||||
}
|
||||
|
||||
// #15284: old units generated without --new can lead to issues on
|
||||
// shutdown when the containers are created with a custom restart
|
||||
// policy.
|
||||
if !options.New {
|
||||
switch config.RestartPolicy {
|
||||
case libpodDefine.RestartPolicyNo, libpodDefine.RestartPolicyNone:
|
||||
// All good
|
||||
default:
|
||||
logrus.Warnf("Container %s has restart policy %q which can lead to issues on shutdown: consider recreating the container without a restart policy and use systemd's restart mechanism instead", ctr.ID(), config.RestartPolicy)
|
||||
}
|
||||
}
|
||||
|
||||
createCommand := []string{}
|
||||
if config.CreateCommand != nil {
|
||||
createCommand = config.CreateCommand
|
||||
|
Reference in New Issue
Block a user