From f22a36332ebdb5dbf947966fc79cd39526b4cbfc Mon Sep 17 00:00:00 2001 From: Medya Gh Date: Tue, 14 Apr 2020 20:21:40 -0700 Subject: [PATCH] add shut down to stop --- pkg/drivers/kic/oci/types.go | 2 ++ pkg/minikube/machine/delete.go | 4 ++-- pkg/minikube/machine/stop.go | 12 +++++++++--- 3 files changed, 13 insertions(+), 5 deletions(-) diff --git a/pkg/drivers/kic/oci/types.go b/pkg/drivers/kic/oci/types.go index 8c43ce7d8b..e85c821eec 100644 --- a/pkg/drivers/kic/oci/types.go +++ b/pkg/drivers/kic/oci/types.go @@ -31,6 +31,8 @@ const ( nodeRoleLabelKey = "role.minikube.sigs.k8s.io" // CreatedByLabelKey is applied to any container/volume that is created by minikube created_by.minikube.sigs.k8s.io=true CreatedByLabelKey = "created_by.minikube.sigs.k8s.io" + // ShutDownCmd is the command halt and stop the container + ShutDownCmd = "sudo init 0" ) // CreateParams are parameters needed to create a container diff --git a/pkg/minikube/machine/delete.go b/pkg/minikube/machine/delete.go index 2132d16737..08e668f916 100644 --- a/pkg/minikube/machine/delete.go +++ b/pkg/minikube/machine/delete.go @@ -77,8 +77,8 @@ func DeleteHost(api libmachine.API, machineName string) error { return mcnerror.ErrHostDoesNotExist{Name: machineName} } - // Hyper-V requires special care to avoid ACPI and file locking issues - if host.Driver.DriverName() == driver.HyperV { + // some drivers need manual shut down before delete to avoid getting stuck. + if driver.NeedsShutdown(host.Driver.DriverName()) { if err := StopHost(api, machineName); err != nil { glog.Warningf("stop host: %v", err) } diff --git a/pkg/minikube/machine/stop.go b/pkg/minikube/machine/stop.go index dfd0061e45..a01accdb1e 100644 --- a/pkg/minikube/machine/stop.go +++ b/pkg/minikube/machine/stop.go @@ -25,6 +25,7 @@ import ( "github.com/docker/machine/libmachine/state" "github.com/golang/glog" "github.com/pkg/errors" + "k8s.io/minikube/pkg/drivers/kic/oci" "k8s.io/minikube/pkg/minikube/driver" "k8s.io/minikube/pkg/minikube/out" "k8s.io/minikube/pkg/util/retry" @@ -78,8 +79,13 @@ func trySSHPowerOff(h *host.Host) error { } out.T(out.Shutdown, `Powering off "{{.profile_name}}" via SSH ...`, out.V{"profile_name": h.Name}) - out, err := h.RunSSHCommand("sudo poweroff") - // poweroff always results in an error, since the host disconnects. - glog.Infof("poweroff result: out=%s, err=%v", out, err) + if driver.IsKIC(h.DriverName) { + out, err := h.RunSSHCommand(oci.ShutDownCmd) + glog.Infof("shutdown cmd %q result: out=%s, err=%v", oci.ShutDownCmd, out, err) + } else { + out, err := h.RunSSHCommand("sudo poweroff") + // poweroff always results in an error, since the host disconnects. + glog.Infof("poweroff result: out=%s, err=%v", out, err) + } return nil }