本篇主要是讲述一个go程序,如何在windows服务中优雅开启和关闭,废话不多说,开搞!!!
使用方式:go程序 + net服务启动
ⅰ 开篇不利
windows go进程编译后,为一个.exe文件,直接执行即可运行
net start tamper_proof_refactored
启动后,发现windows服务根本不认识这个go二进制文件,完全起不来
注意:因为普通的程序无法处理windows服务特有的消息,普通的go程序也无法在服务模式运行。
ⅱ 需求拆解
现在知道一个问题了:普通的go程序启动服务后,服务会出现"无响应控制功能"
现在是想要实现什么?
go程序编译的二进制文件,可以被当作windows服务,稳定在后台执行,并可优雅开启和关闭
ⅲ 具体实现
找到一个go的官方库,用于实现windows服务注册和启动的
golang.org/x/sys/windows/svc
具体实现逻辑如下
func (m *myservice) execute(args []string, r <-chan svc.changerequest, changes chan<- svc.status) (ssec bool, errno uint32) { const cmdsaccepted = svc.acceptstop | svc.acceptshutdown | svc.acceptpauseandcontinue changes <- svc.status{state: svc.startpending} go star() // 启动go程序的主程序【需要有一个主入口函数】 changes <- svc.status{state: svc.running, accepts: cmdsaccepted} loop: for { c := <-r switch c.cmd { case svc.interrogate: changes <- c.currentstatus case svc.stop, svc.shutdown: exit() // 停止你的程序 break loop case svc.pause: // 添加你的程序的暂停逻辑 changes <- svc.status{state: svc.paused, accepts: cmdsaccepted} case svc.continue: // 添加你的程序的继续逻辑 changes <- svc.status{state: svc.running, accepts: cmdsaccepted} default: log.printf("unexpected control request #%d", c) } } changes <- svc.status{state: svc.stoppending} return } func runservice() { err := svc.run("tamper_proof_refactored", &myservice{}) if err != nil { log.fatal(err) } fmt.println("服务已启动") }
启动后,直接终端查看下效果
写了一个服务状态判断,打印出的服务当前状态日志
写完后,就可以正常的服务启动和关闭了,下面是详细的服务启动/关闭指令
sc create myservice binpath= "c:\path\to\your\program\tamper_proof_xxxx.exe" //创建服务 net start myservice // 开启服务 net stop myserver // 暂停服务 sc delete myserver // 删除服务
到此这篇关于详解go程序如何在windows服务中开启和关闭的文章就介绍到这了,更多相关go windows服务开启和关闭内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论