mirror of https://github.com/containers/podman.git
				
				
				
			libpod: destroy pod cgroup on pod stop
When the pod is stopped, we need to destroy the pod cgroup, otherwise it is leaked. Signed-off-by: Giuseppe Scrivano <gscrivan@redhat.com>
This commit is contained in:
		
							parent
							
								
									9a347619d8
								
							
						
					
					
						commit
						627ac1c96b
					
				|  | @ -209,6 +209,13 @@ func (p *Pod) stopWithTimeout(ctx context.Context, cleanup bool, timeout int) (m | |||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	if err := p.updatePod(); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if err := p.removePodCgroup(); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	return nil, nil | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -7,6 +7,7 @@ import ( | |||
| 	"context" | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"path" | ||||
| 	"path/filepath" | ||||
| 
 | ||||
| 	"github.com/containers/common/pkg/cgroups" | ||||
|  | @ -14,6 +15,7 @@ import ( | |||
| 	"github.com/containers/podman/v4/libpod/define" | ||||
| 	"github.com/containers/podman/v4/libpod/events" | ||||
| 	"github.com/containers/podman/v4/pkg/specgen" | ||||
| 	"github.com/containers/podman/v4/utils" | ||||
| 	"github.com/hashicorp/go-multierror" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| ) | ||||
|  | @ -199,6 +201,20 @@ func (p *Pod) removePodCgroup() error { | |||
| 	} | ||||
| 	logrus.Debugf("Removing pod cgroup %s", p.state.CgroupPath) | ||||
| 
 | ||||
| 	cgroup, err := utils.GetOwnCgroup() | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	// if we are trying to delete a cgroup that is our ancestor, we need to move the
 | ||||
| 	// current process out of it before the cgroup is destroyed.
 | ||||
| 	if isSubDir(cgroup, string(filepath.Separator)+p.state.CgroupPath) { | ||||
| 		parent := path.Dir(p.state.CgroupPath) | ||||
| 		if err := utils.MoveUnderCgroup(parent, "cleanup", nil); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	switch p.runtime.config.Engine.CgroupManager { | ||||
| 	case config.SystemdCgroupsManager: | ||||
| 		if err := deleteSystemdCgroup(p.state.CgroupPath, p.ResourceLim()); err != nil { | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue