mirror of
				https://github.com/containers/podman.git
				synced 2025-10-27 03:06:22 +08:00 
			
		
		
		
	 08b0d93ea3
			
		
	
	08b0d93ea3
	
	
	
		
			
			Implement means for reflecting failed containers (i.e., those having exited non-zero) to better integrate `kube play` with systemd. The idea is to have the main PID of `kube play` exit non-zero in a configurable way such that systemd's restart policies can kick in. When using the default sdnotify-notify policy, the service container acts as the main PID to further reduce the resource footprint. In that case, before stopping the service container, Podman will lookup the exit codes of all non-infra containers. The service will then behave according to the following three exit-code policies: - `none`: exit 0 and ignore containers (default) - `any`: exit non-zero if _any_ container did - `all`: exit non-zero if _all_ containers did The upper values can be passed via a hidden `kube play --service-exit-code-propagation` flag which can be used by tests and later on by Quadlet. In case Podman acts as the main PID (i.e., when at least one container runs with an sdnotify-policy other than "ignore"), Podman will continue to wait for the service container to exit and reflect its exit code. Note that this commit also fixes a long-standing annoyance of the service container exiting non-zero. The underlying issue was that the service container had been stopped with SIGKILL instead of SIGTERM and hence exited non-zero. Fixing that was a prerequisite for the exit-code propagation to work but also improves the integration of `kube play` with systemd and hence Quadlet with systemd. Jira: issues.redhat.com/browse/RUN-1776 Signed-off-by: Valentin Rothberg <vrothberg@redhat.com>
		
			
				
	
	
		
			55 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package define
 | |
| 
 | |
| import "fmt"
 | |
| 
 | |
| // KubeExitCodePropagation defines an exit policy of kube workloads.
 | |
| type KubeExitCodePropagation int
 | |
| 
 | |
| const (
 | |
| 	// Invalid exit policy for a proper type system.
 | |
| 	KubeExitCodePropagationInvalid KubeExitCodePropagation = iota
 | |
| 	// Exit 0 regardless of any failed containers.
 | |
| 	KubeExitCodePropagationNone
 | |
| 	// Exit non-zero if all containers failed.
 | |
| 	KubeExitCodePropagationAll
 | |
| 	// Exit non-zero if any container failed.
 | |
| 	KubeExitCodePropagationAny
 | |
| 
 | |
| 	// String representations.
 | |
| 	strKubeECPInvalid = "invalid"
 | |
| 	strKubeECPNone    = "none"
 | |
| 	strKubeECPAll     = "all"
 | |
| 	strKubeECPAny     = "any"
 | |
| )
 | |
| 
 | |
| // Parse the specified kube exit-code propagation. Return an error if an
 | |
| // unsupported value is specified.
 | |
| func ParseKubeExitCodePropagation(value string) (KubeExitCodePropagation, error) {
 | |
| 	switch value {
 | |
| 	case strKubeECPNone, "":
 | |
| 		return KubeExitCodePropagationNone, nil
 | |
| 	case strKubeECPAll:
 | |
| 		return KubeExitCodePropagationAll, nil
 | |
| 	case strKubeECPAny:
 | |
| 		return KubeExitCodePropagationAny, nil
 | |
| 	default:
 | |
| 		return KubeExitCodePropagationInvalid, fmt.Errorf("unsupported exit-code propagation %q", value)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // Return the string representation of the KubeExitCodePropagation.
 | |
| func (k KubeExitCodePropagation) String() string {
 | |
| 	switch k {
 | |
| 	case KubeExitCodePropagationNone:
 | |
| 		return strKubeECPNone
 | |
| 	case KubeExitCodePropagationAll:
 | |
| 		return strKubeECPAll
 | |
| 	case KubeExitCodePropagationAny:
 | |
| 		return strKubeECPAny
 | |
| 	case KubeExitCodePropagationInvalid:
 | |
| 		return strKubeECPInvalid
 | |
| 	default:
 | |
| 		return "unknown value"
 | |
| 	}
 | |
| }
 |