mirror of
				https://github.com/containers/podman.git
				synced 2025-10-26 10:45:26 +08:00 
			
		
		
		
	 fbd1392a46
			
		
	
	fbd1392a46
	
	
	
		
			
			There is a group of inodes that get created when running a container
if they do not exist.
containerMounts = map[string]bool{
	"/dev":               true,
	"/etc/hostname":      true,
	"/etc/hosts":         true,
	"/etc/resolv.conf":   true,
	"/proc":              true,
	"/run":               true,
	"/run/.containerenv": true,
	"/run/secrets":       true,
	"/sys":               true,
}
If the destination inode does not exist, libpod/runc will create the inode.
This can cause programs like podman diff to see the image as having changed,
when actually it has not.  This patch ignores changes in these inodes.
Signed-off-by: Daniel J Walsh <dwalsh@redhat.com>
Closes: #1508
Approved by: giuseppe
		
	
		
			
				
	
	
		
			68 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package libpod
 | |
| 
 | |
| import (
 | |
| 	"github.com/containers/libpod/libpod/layers"
 | |
| 	"github.com/containers/storage/pkg/archive"
 | |
| 	"github.com/pkg/errors"
 | |
| )
 | |
| 
 | |
| var containerMounts = map[string]bool{
 | |
| 	"/dev":               true,
 | |
| 	"/etc/hostname":      true,
 | |
| 	"/etc/hosts":         true,
 | |
| 	"/etc/resolv.conf":   true,
 | |
| 	"/proc":              true,
 | |
| 	"/run":               true,
 | |
| 	"/run/.containerenv": true,
 | |
| 	"/run/secrets":       true,
 | |
| 	"/sys":               true,
 | |
| }
 | |
| 
 | |
| // GetDiff returns the differences between the two images, layers, or containers
 | |
| func (r *Runtime) GetDiff(from, to string) ([]archive.Change, error) {
 | |
| 	toLayer, err := r.getLayerID(to)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	fromLayer := ""
 | |
| 	if from != "" {
 | |
| 		fromLayer, err = r.getLayerID(from)
 | |
| 		if err != nil {
 | |
| 			return nil, err
 | |
| 		}
 | |
| 	}
 | |
| 	var rchanges []archive.Change
 | |
| 	changes, err := r.store.Changes(fromLayer, toLayer)
 | |
| 	if err == nil {
 | |
| 		for _, c := range changes {
 | |
| 			if containerMounts[c.Path] {
 | |
| 				continue
 | |
| 			}
 | |
| 			rchanges = append(rchanges, c)
 | |
| 		}
 | |
| 	}
 | |
| 	return rchanges, err
 | |
| }
 | |
| 
 | |
| // GetLayerID gets a full layer id given a full or partial id
 | |
| // If the id matches a container or image, the id of the top layer is returned
 | |
| // If the id matches a layer, the top layer id is returned
 | |
| func (r *Runtime) getLayerID(id string) (string, error) {
 | |
| 	var toLayer string
 | |
| 	toImage, err := r.imageRuntime.NewFromLocal(id)
 | |
| 	if err != nil {
 | |
| 		toCtr, err := r.store.Container(id)
 | |
| 		if err != nil {
 | |
| 			toLayer, err = layers.FullID(r.store, id)
 | |
| 			if err != nil {
 | |
| 				return "", errors.Errorf("layer, image, or container %s does not exist", id)
 | |
| 			}
 | |
| 		} else {
 | |
| 			toLayer = toCtr.LayerID
 | |
| 		}
 | |
| 	} else {
 | |
| 		toLayer = toImage.TopLayer()
 | |
| 	}
 | |
| 	return toLayer, nil
 | |
| }
 |