Windows无法启动启动服务,错误1053的解决方法
项目需求,要将一个exe二进制文件以windows服务的形式发布,开发编译运行后一切正常。sc命令安装为windows服务启动,出现下图错误:Windows无法启动启动服务,错误1053

关键代码处打上crash日志

发现获取程序运行路径的配置文件读取失败,但直接运行exe则成功。
原因及解决:
原因是加载配置文件的接口是用Getwd()获取的当前的工作目录,当将exe注册为windows服务运行时,Getwd获取的则是系统服务调用的工作目录
解决:
项目用的是golang开发,这里用到了 os.Executable() 来返回当前实际运行exe的路径,而不是调用者的工作路径。
func GetPath() (string, error) {
executable, err := os.Executable()
if err != nil {
return "", err
}
symlinks, err := filepath.EvalSymlinks(executable)
if err != nil {
return "", err
}
rootPath := filepath.Dir(symlinks)
if rootPath == "." {
return "", errors.New("dir is empty")
}
return rootPath, nil
}
这篇博客介绍了在Windows环境下,由于服务启动时工作目录不正确导致的错误1053问题。作者通过分析发现,使用`Getwd()`获取的工作目录在服务模式下不正确。解决方案是改用`os.Executable()`来获取服务实际的运行路径,确保配置文件能正确读取。修复后,服务成功启动。
8860

被折叠的 条评论
为什么被折叠?



