sftp: Use own process group for ssh subprocess

This commit is contained in:
Alexander Neumann 2015-07-05 11:06:28 +02:00
parent 4a2e0b5423
commit 281eea9c05
2 changed files with 13 additions and 1 deletions

View file

@ -10,6 +10,7 @@ import (
"os/exec" "os/exec"
"path/filepath" "path/filepath"
"sort" "sort"
"syscall"
"github.com/juju/errors" "github.com/juju/errors"
"github.com/pkg/sftp" "github.com/pkg/sftp"
@ -35,6 +36,9 @@ func startClient(program string, args ...string) (*SFTP, error) {
// send errors from ssh to stderr // send errors from ssh to stderr
cmd.Stderr = os.Stderr cmd.Stderr = os.Stderr
// ignore signals sent to the parent (e.g. SIGINT)
cmd.SysProcAttr = &syscall.SysProcAttr{Setsid: true}
// get stdin and stdout // get stdin and stdout
wr, err := cmd.StdinPipe() wr, err := cmd.StdinPipe()
if err != nil { if err != nil {
@ -452,6 +456,10 @@ func (s *SFTP) Close() error {
} }
s.c.Close() s.c.Close()
// TODO: add timeout after which the process is killed
if err := s.cmd.Process.Kill(); err != nil {
return err
}
return s.cmd.Wait() return s.cmd.Wait()
} }

View file

@ -49,7 +49,9 @@ func lockRepository(repo *repository.Repository, exclusive bool) (*restic.Lock,
} }
func unlockRepo(lock *restic.Lock) error { func unlockRepo(lock *restic.Lock) error {
debug.Log("unlockRepo", "unlocking repository")
if err := lock.Unlock(); err != nil { if err := lock.Unlock(); err != nil {
debug.Log("unlockRepo", "error while unlocking: %v", err)
return err return err
} }
@ -67,8 +69,10 @@ func unlockAll() error {
debug.Log("unlockAll", "unlocking %d locks", len(globalLocks)) debug.Log("unlockAll", "unlocking %d locks", len(globalLocks))
for _, lock := range globalLocks { for _, lock := range globalLocks {
if err := lock.Unlock(); err != nil { if err := lock.Unlock(); err != nil {
debug.Log("unlockAll", "error while unlocking: %v", err)
return err return err
} }
debug.Log("unlockAll", "successfully removed lock")
} }
return nil return nil