diff --git a/daemon/daemon.go b/daemon/daemon.go index 33c3f10caf48555c43b0d684f90c8156c7973a62..dfe6f0aeb600af3c290de07af24e31ad262121f8 100644 --- a/daemon/daemon.go +++ b/daemon/daemon.go @@ -760,7 +760,7 @@ func NewDaemon(config *Config, registryService *registry.Service) (daemon *Daemo migrationStart := time.Now() if err := v1.Migrate(config.Root, graphDriver, d.layerStore, d.imageStore, referenceStore, distributionMetadataStore); err != nil { - return nil, err + logrus.Errorf("Graph migration failed: %q. Your old graph data was found to be too inconsistent for upgrading to content-addressable storage. Some of the old data was probably not upgraded. We recommend starting over with a clean storage directory if possible.", err) } logrus.Infof("Graph migration to content-addressability took %.2f seconds", time.Since(migrationStart).Seconds()) diff --git a/layer/migration.go b/layer/migration.go index 9779ab7984b6e7399cfe6ab29dc7621360a4d24f..ac0f0065f2aa89fdb34a2089bfb78ecc24abe4a1 100644 --- a/layer/migration.go +++ b/layer/migration.go @@ -32,7 +32,7 @@ func (ls *layerStore) CreateRWLayerByGraphID(name string, graphID string, parent } if !ls.driver.Exists(graphID) { - return errors.New("graph ID does not exist") + return fmt.Errorf("graph ID does not exist: %q", graphID) } var p *roLayer diff --git a/migrate/v1/migratev1.go b/migrate/v1/migratev1.go index 9243c5a42a041816b11e44ca2ba5fee2c1f5932b..b7ce75b1c078cc51ad347cf0a6938ae85e88ff03 100644 --- a/migrate/v1/migratev1.go +++ b/migrate/v1/migratev1.go @@ -282,7 +282,8 @@ func migrateContainers(root string, ls graphIDMounter, is image.Store, imageMapp } if err := ls.CreateRWLayerByGraphID(id, id, img.RootFS.ChainID()); err != nil { - return err + logrus.Errorf("migrate container error: %v", err) + continue } logrus.Infof("migrated container %s to point to %s", id, imageID)