mirror of
https://github.com/restic/restic.git
synced 2025-01-03 13:45:20 +00:00
sftp: Use own process group for ssh subprocess
This commit is contained in:
parent
4a2e0b5423
commit
281eea9c05
2 changed files with 13 additions and 1 deletions
|
@ -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()
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue