Merge pull request #9542 from vrothberg/rmi-hardening
podman rmi: handle corrupted storage better
This commit is contained in:
		
						commit
						bab635d9f6
					
				|  | @ -4,7 +4,6 @@ import ( | |||
| 	"context" | ||||
| 
 | ||||
| 	ociv1 "github.com/opencontainers/image-spec/specs-go/v1" | ||||
| 	"github.com/pkg/errors" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| ) | ||||
| 
 | ||||
|  | @ -188,7 +187,12 @@ func (t *layerTree) parent(ctx context.Context, child *Image) (*Image, error) { | |||
| 
 | ||||
| 	node, exists := t.nodes[child.TopLayer()] | ||||
| 	if !exists { | ||||
| 		return nil, errors.Errorf("layer not found in layer tree: %q", child.TopLayer()) | ||||
| 		// Note: erroring out in this case has turned out having been a
 | ||||
| 		// mistake. Users may not be able to recover, so we're now
 | ||||
| 		// throwing a warning to guide them to resolve the issue and
 | ||||
| 		// turn the errors non-fatal.
 | ||||
| 		logrus.Warnf("Layer %s not found in layer. The storage may be corrupted, consider running `podman system reset`.", child.TopLayer()) | ||||
| 		return nil, nil | ||||
| 	} | ||||
| 
 | ||||
| 	childOCI, err := t.toOCI(ctx, child) | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue