Golang服务程序daemon化踩坑记录
WangRichard ·之前写习惯了C/CPP,都知道可以使用Linux上的daemon函数来方便的实现守护进程。最近切换到go上,想如法炮制,第一个想到的就是基于cgo直接调用,类似如下代码:
//#include<unistd.h>
import "C"
func Daemon() {
C.daemon(1,0)
}
上面代码确实可以成功执行,可问题随之而来。测试的时候,我发现使用了上述代码片段的程序,测试时会随机出现程序无限假死的情况,google的大部分结果都说的是golang的Scheduler和Linux的fork系统调用不兼容所致,各位如有知道个中明细,还望赐教!
没办法,之后基于Stack Overflow热心网友的解答,采用类似下述方法实现daemon化,注意使用相关命令行参数控制调用:
func Daemon(){
cmd := exec.Command(os.Args[0])
cmd.Stdin = nil
cmd.Stdout = nil
cmd.Stderr = nil
cmd.SysProcAttr = &syscall.SysProcAttr{Setsid:true}
err := cmd.Start()
if err == nil {
cmd.Process.Release()
os.Exit(0)
}
}
很神奇,使用该方法实现的daemon,测试时没有再出现程序随机假死的情况。
更多评论
## 有现成的daemon包可以使用
#### 首先运行
```go
go get github.com/icattlecoder/godaemon
```
#### 在main包下
```go
_ "github.com/icattlecoder/godaemon"
```
#### 运行命令
编译后,可以直接daemon运行
```go
./example -d=true
```
#1
之前写习惯了C/CPP,都知道可以使用Linux上的daemon函数来方便的实现守护进程。最近切换到go上,想如法炮制,第一个想到的就是基于cgo直接调用,类似如下代码:
//#include<unistd.h>
import "C"
func Daemon() {
C.daemon(1,0)
}
上面代码确实可以成功执行,可问题随之而来。测试的时候,我发现使用了上述代码片段的程序,测试时会随机出现程序无限假死的情况,google的大部分结果都说的是golang的Scheduler和Linux的fork系统调用不兼容所致,各位如有知道个中明细,还望赐教!
没办法,之后基于Stack Overflow热心网友的解答,采用类似下述方法实现daemon化,注意使用相关命令行参数控制调用:
func Daemon(){
cmd := exec.Command(os.Args[0])
cmd.Stdin = nil
cmd.Stdout = nil
cmd.Stderr = nil
cmd.SysProcAttr = &syscall.SysProcAttr{Setsid:true}
err := cmd.Start()
if err == nil {
cmd.Process.Release()
os.Exit(0)
}
}
很神奇,使用该方法实现的daemon,测试时没有再出现程序随机假死的情况。