Cleanup statedir a little
Signed-off-by: Kenfe-Mickael Laventure <mickael.laventure@gmail.com>
This commit is contained in:
parent
642ed8bb48
commit
c376fd45f6
2 changed files with 21 additions and 16 deletions
|
@ -111,11 +111,11 @@ func (r *OCIRuntime) Create(ctx context.Context, id string, o execution.CreateOp
|
|||
}
|
||||
}(container)
|
||||
|
||||
initDir, err := container.StateDir().NewProcess()
|
||||
initProcID, initStateDir, err := container.StateDir().NewProcess()
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
pidFile := filepath.Join(initDir, "pid")
|
||||
pidFile := filepath.Join(initStateDir, "pid")
|
||||
err = r.runc.Create(ctx, id, o.Bundle, &runc.CreateOpts{
|
||||
PidFile: pidFile,
|
||||
Console: consolePath,
|
||||
|
@ -135,7 +135,7 @@ func (r *OCIRuntime) Create(ctx context.Context, id string, o execution.CreateOp
|
|||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
process, err := newProcess(filepath.Base(initDir), pid)
|
||||
process, err := newProcess(initProcID, pid)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
@ -261,17 +261,17 @@ func (r *OCIRuntime) StartProcess(ctx context.Context, c *execution.Container, o
|
|||
}()
|
||||
}
|
||||
|
||||
processStateDir, err := c.StateDir().NewProcess()
|
||||
procID, procStateDir, err := c.StateDir().NewProcess()
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
defer func() {
|
||||
if err != nil {
|
||||
c.StateDir().DeleteProcess(filepath.Base(processStateDir))
|
||||
c.StateDir().DeleteProcess(procID)
|
||||
}
|
||||
}()
|
||||
|
||||
pidFile := filepath.Join(processStateDir, "pid")
|
||||
pidFile := filepath.Join(procStateDir, "pid")
|
||||
if err := r.runc.Exec(ctx, c.ID(), o.Spec, &runc.ExecOpts{
|
||||
PidFile: pidFile,
|
||||
Detach: false,
|
||||
|
@ -286,7 +286,7 @@ func (r *OCIRuntime) StartProcess(ctx context.Context, c *execution.Container, o
|
|||
return nil, err
|
||||
}
|
||||
|
||||
process, err := newProcess(filepath.Base(processStateDir), pid)
|
||||
process, err := newProcess(procID, pid)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
|
|
@ -6,7 +6,7 @@ import (
|
|||
"path/filepath"
|
||||
)
|
||||
|
||||
const processesDir = "processes"
|
||||
const processesDirName = "processes"
|
||||
|
||||
type StateDir string
|
||||
|
||||
|
@ -15,7 +15,7 @@ func NewStateDir(root, id string) (StateDir, error) {
|
|||
if err := os.Mkdir(path, 0700); err != nil {
|
||||
return "", err
|
||||
}
|
||||
if err := os.Mkdir(filepath.Join(path, processesDir), 0700); err != nil {
|
||||
if err := os.Mkdir(StateDir(path).processesDir(), 0700); err != nil {
|
||||
os.RemoveAll(path)
|
||||
return "", err
|
||||
}
|
||||
|
@ -26,20 +26,25 @@ func (s StateDir) Delete() error {
|
|||
return os.RemoveAll(string(s))
|
||||
}
|
||||
|
||||
func (s StateDir) NewProcess() (string, error) {
|
||||
return ioutil.TempDir(s.processDir(), "")
|
||||
func (s StateDir) NewProcess() (id, dir string, err error) {
|
||||
dir, err = ioutil.TempDir(s.processesDir(), "")
|
||||
if err != nil {
|
||||
return "", "", err
|
||||
}
|
||||
|
||||
return filepath.Base(dir), dir, err
|
||||
}
|
||||
|
||||
func (s StateDir) ProcessDir(id string) string {
|
||||
return filepath.Join(string(s), id)
|
||||
return filepath.Join(s.processesDir(), id)
|
||||
}
|
||||
|
||||
func (s StateDir) DeleteProcess(id string) error {
|
||||
return os.RemoveAll(filepath.Join(s.processDir(), id))
|
||||
return os.RemoveAll(filepath.Join(s.processesDir(), id))
|
||||
}
|
||||
|
||||
func (s StateDir) Processes() ([]string, error) {
|
||||
procsDir := s.processDir()
|
||||
procsDir := s.processesDir()
|
||||
dirs, err := ioutil.ReadDir(procsDir)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
|
@ -54,6 +59,6 @@ func (s StateDir) Processes() ([]string, error) {
|
|||
return paths, nil
|
||||
}
|
||||
|
||||
func (s StateDir) processDir() string {
|
||||
return filepath.Join(string(s), processesDir)
|
||||
func (s StateDir) processesDir() string {
|
||||
return filepath.Join(string(s), processesDirName)
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue