mirror of
				https://github.com/linuxkit/linuxkit.git
				synced 2025-10-24 23:31:19 +00:00 
			
		
		
		
	more builder race condition; do restart if could not remove, and only go via container ID (#4129)
Signed-off-by: Avi Deitcher <avi@deitcher.net>
This commit is contained in:
		| @@ -276,6 +276,7 @@ func (dr *dockerRunnerImpl) builderEnsureContainer(ctx context.Context, name, im | |||||||
| 	) | 	) | ||||||
| 	for range buildKitCheckRetryCount { | 	for range buildKitCheckRetryCount { | ||||||
| 		var b bytes.Buffer | 		var b bytes.Buffer | ||||||
|  | 		var cid string | ||||||
| 		if err := dr.command(nil, &b, io.Discard, "--context", dockerContext, "container", "inspect", name); err == nil { | 		if err := dr.command(nil, &b, io.Discard, "--context", dockerContext, "container", "inspect", name); err == nil { | ||||||
| 			// we already have a container named "linuxkit-builder" in the provided context. | 			// we already have a container named "linuxkit-builder" in the provided context. | ||||||
| 			// get its state and config | 			// get its state and config | ||||||
| @@ -284,6 +285,7 @@ func (dr *dockerRunnerImpl) builderEnsureContainer(ctx context.Context, name, im | |||||||
| 				return nil, fmt.Errorf("unable to read results of 'container inspect %s': %v", name, err) | 				return nil, fmt.Errorf("unable to read results of 'container inspect %s': %v", name, err) | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
|  | 			cid = containerJSON[0].ID | ||||||
| 			existingImage := containerJSON[0].Config.Image | 			existingImage := containerJSON[0].Config.Image | ||||||
| 			isRunning := containerJSON[0].State.Status == "running" | 			isRunning := containerJSON[0].State.Status == "running" | ||||||
|  |  | ||||||
| @@ -326,13 +328,25 @@ func (dr *dockerRunnerImpl) builderEnsureContainer(ctx context.Context, name, im | |||||||
| 		// if we made it here, we need to stop and remove the container, either because of a config mismatch, | 		// if we made it here, we need to stop and remove the container, either because of a config mismatch, | ||||||
| 		// or because we received the CLI option | 		// or because we received the CLI option | ||||||
| 		if stop { | 		if stop { | ||||||
| 			if err := dr.command(nil, io.Discard, io.Discard, "--context", dockerContext, "container", "stop", name); err != nil { | 			if cid == "" { | ||||||
| 				return nil, fmt.Errorf("failed to stop existing container %s", name) | 				// we don't have a container ID, so we can't stop it | ||||||
|  | 				return nil, fmt.Errorf("unable to stop existing container %s, no ID found", name) | ||||||
|  | 			} | ||||||
|  | 			if err := dr.command(nil, io.Discard, io.Discard, "--context", dockerContext, "container", "stop", cid); err != nil { | ||||||
|  | 				// if we failed, do a retry; maybe it does not even exist anymore | ||||||
|  | 				time.Sleep(buildkitCheckInterval) | ||||||
|  | 				continue | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		if remove { | 		if remove { | ||||||
| 			if err := dr.command(nil, io.Discard, io.Discard, "--context", dockerContext, "container", "rm", name); err != nil { | 			if cid == "" { | ||||||
| 				return nil, fmt.Errorf("failed to remove existing container %s", name) | 				// we don't have a container ID, so we can't remove it | ||||||
|  | 				return nil, fmt.Errorf("unable to remove existing container %s, no ID found", name) | ||||||
|  | 			} | ||||||
|  | 			if err := dr.command(nil, io.Discard, io.Discard, "--context", dockerContext, "container", "rm", cid); err != nil { | ||||||
|  | 				// if we failed, do a retry; maybe it does not even exist anymore | ||||||
|  | 				time.Sleep(buildkitCheckInterval) | ||||||
|  | 				continue | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		if recreate { | 		if recreate { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user