瀏覽代碼

Merge pull request #23328 from swernli/servicingFix

Fix postRunProcessing behavior during docker build
Alexander Morozov 9 年之前
父節點
當前提交
cc03a422aa
共有 1 個文件被更改,包括 2 次插入1 次删除
  1. 2 1
      daemon/monitor_windows.go

+ 2 - 1
daemon/monitor_windows.go

@@ -16,7 +16,7 @@ func platformConstructExitStatus(e libcontainerd.StateInfo) *container.ExitStatu
 
 // postRunProcessing perfoms any processing needed on the container after it has stopped.
 func (daemon *Daemon) postRunProcessing(container *container.Container, e libcontainerd.StateInfo) error {
-	if e.UpdatePending {
+	if e.ExitCode == 0 && e.UpdatePending {
 		spec, err := daemon.createSpec(container)
 		if err != nil {
 			return err
@@ -29,6 +29,7 @@ func (daemon *Daemon) postRunProcessing(container *container.Container, e libcon
 		// Create a new servicing container, which will start, complete the update, and merge back the
 		// results if it succeeded, all as part of the below function call.
 		if err := daemon.containerd.Create((container.ID + "_servicing"), *spec, servicingOption); err != nil {
+			container.ExitCode = -1
 			return fmt.Errorf("Post-run update servicing failed: %s", err)
 		}
 	}