kpod: shut down the storage library before exiting

Before exiting, have kpod shut down the storage library if it can.  This
should keep us from leaving mountpoints for the root (for non-vfs cases)
and run directory (with newer containers/storage) busy when testing kpod.

Signed-off-by: Nalin Dahyabhai <nalin@redhat.com>
This commit is contained in:
Nalin Dahyabhai 2017-08-17 10:23:54 -04:00
parent 3a2518ce33
commit ef8df00e6a
8 changed files with 33 additions and 2 deletions

View file

@ -10,6 +10,10 @@ import (
"github.com/urfave/cli" "github.com/urfave/cli"
) )
var (
stores = make(map[storage.Store]struct{})
)
func getStore(c *libkpod.Config) (storage.Store, error) { func getStore(c *libkpod.Config) (storage.Store, error) {
options := storage.DefaultStoreOptions options := storage.DefaultStoreOptions
options.GraphRoot = c.Root options.GraphRoot = c.Root
@ -22,9 +26,18 @@ func getStore(c *libkpod.Config) (storage.Store, error) {
return nil, err return nil, err
} }
is.Transport.SetStore(store) is.Transport.SetStore(store)
stores[store] = struct{}{}
return store, nil return store, nil
} }
func shutdownStores() {
for store := range stores {
if _, err := store.Shutdown(false); err != nil {
break
}
}
}
func getConfig(c *cli.Context) (*libkpod.Config, error) { func getConfig(c *cli.Context) (*libkpod.Config, error) {
config := libkpod.DefaultConfig() config := libkpod.DefaultConfig()
if c.GlobalIsSet("config") { if c.GlobalIsSet("config") {

View file

@ -86,6 +86,7 @@ func diffCmd(c *cli.Context) error {
if err != nil { if err != nil {
return errors.Wrapf(err, "could not get container server") return errors.Wrapf(err, "could not get container server")
} }
defer server.Shutdown()
to := c.Args().Get(0) to := c.Args().Get(0)
changes, err := server.GetDiff("", to) changes, err := server.GetDiff("", to)

View file

@ -71,6 +71,7 @@ func inspectCmd(c *cli.Context) error {
if err != nil { if err != nil {
return errors.Wrapf(err, "could not get container server") return errors.Wrapf(err, "could not get container server")
} }
defer server.Shutdown()
if err = server.Update(); err != nil { if err = server.Update(); err != nil {
return errors.Wrapf(err, "could not update list of containers") return errors.Wrapf(err, "could not update list of containers")
} }

View file

@ -69,6 +69,7 @@ func logsCmd(c *cli.Context) error {
if err != nil { if err != nil {
return errors.Wrapf(err, "could not create container server") return errors.Wrapf(err, "could not create container server")
} }
defer server.Shutdown()
err = server.Update() err = server.Update()
if err != nil { if err != nil {
return errors.Wrapf(err, "could not update list of containers") return errors.Wrapf(err, "could not update list of containers")

View file

@ -50,6 +50,16 @@ func main() {
} }
return nil return nil
} }
app.After = func(*cli.Context) error {
// called by Run() when the command handler succeeds
shutdownStores()
return nil
}
cli.OsExiter = func(code int) {
// called by Run() when the command fails, bypassing After()
shutdownStores()
os.Exit(code)
}
app.Flags = []cli.Flag{ app.Flags = []cli.Flag{
cli.StringFlag{ cli.StringFlag{
Name: "config, c", Name: "config, c",
@ -82,6 +92,6 @@ func main() {
} }
if err := app.Run(os.Args); err != nil { if err := app.Run(os.Args); err != nil {
logrus.Errorf(err.Error()) logrus.Errorf(err.Error())
os.Exit(1) cli.OsExiter(1)
} }
} }

View file

@ -32,6 +32,7 @@ func renameCmd(c *cli.Context) error {
if err != nil { if err != nil {
return errors.Wrapf(err, "could not get container server") return errors.Wrapf(err, "could not get container server")
} }
defer server.Shutdown()
err = server.Update() err = server.Update()
if err != nil { if err != nil {
return errors.Wrapf(err, "could not update list of containers") return errors.Wrapf(err, "could not update list of containers")

View file

@ -70,6 +70,7 @@ func statsCmd(c *cli.Context) error {
if err != nil { if err != nil {
return errors.Wrapf(err, "could not create container server") return errors.Wrapf(err, "could not create container server")
} }
defer containerServer.Shutdown()
err = containerServer.Update() err = containerServer.Update()
if err != nil { if err != nil {
return errors.Wrapf(err, "could not update list of containers") return errors.Wrapf(err, "could not update list of containers")

View file

@ -570,8 +570,11 @@ func (c *ContainerServer) ReleasePodName(name string) {
// Shutdown attempts to shut down the server's storage cleanly // Shutdown attempts to shut down the server's storage cleanly
func (c *ContainerServer) Shutdown() error { func (c *ContainerServer) Shutdown() error {
_, err := c.store.Shutdown(false) _, err := c.store.Shutdown(false)
if err != nil && errors.Cause(err) != cstorage.ErrLayerUsedByContainer {
return err return err
} }
return nil
}
type containerServerState struct { type containerServerState struct {
containers oci.ContainerStorer containers oci.ContainerStorer