This commit is contained in:
Timofey.Kovalev
2025-07-25 17:25:14 +03:00
parent a5055b226f
commit a69c534c11
4 changed files with 69 additions and 8 deletions

18
main.go
View File

@ -47,7 +47,7 @@ func debug(s string, a ...any) {
func stopAllServices(services []*Service) {
for _, s := range services {
if s.cmd.Process == nil {
if s.cmd.Process == nil || s.cmd.ProcessState != nil {
continue
}
@ -84,7 +84,7 @@ func runServices(services []*Service) (int, error) {
s.cmd = exec.Command(s.CMD, s.Args...)
s.cmd.SysProcAttr = &syscall.SysProcAttr{
Setsid: true,
//Setsid: true,
}
if s.PWD != "" {
@ -148,7 +148,7 @@ func loadConfig(cfg *Config, configFile string) error {
}
func forwardSignals(services []*Service) {
signals := []os.Signal{syscall.SIGCHLD, syscall.SIGTERM, syscall.SIGINT, syscall.SIGQUIT}
signals := []os.Signal{syscall.SIGCHLD, syscall.SIGTERM, syscall.SIGINT, syscall.SIGQUIT, syscall.SIGSEGV}
sigCh := make(chan os.Signal, 1)
signal.Notify(sigCh, signals...)
@ -169,20 +169,22 @@ func forwardSignals(services []*Service) {
}
func main() {
verbose = false
var (
configFile string
cfg Config
err := unix.Prctl(unix.PR_SET_CHILD_SUBREAPER, 1, 0, 0, 0)
err error
)
err = unix.Prctl(unix.PR_SET_CHILD_SUBREAPER, 1, 0, 0, 0)
if err != nil {
printErr(err)
}
var configFile string
flag.StringVar(&configFile, "c", "./config.json", "JSON config file")
flag.BoolVar(&verbose, "v", false, "Show debug output")
flag.Parse()
var cfg Config
err = loadConfig(&cfg, configFile)
if err != nil {
printErr(err)