beego 第一个项目做好了,满心欢喜打包上线,不过这东西给我深深的上了一课,坑太多
打包命令
bee pack -be GOOS=windows
如果你愿意你可以打包成其他系统的包
详细参数读一下bee help pack
以服务形式运行
服务和终端运行的区别就在于,你可以关窗口,可以注销用户,不用服务的小伙伴直接跳过吧,但是这里真真的是很坑;
用到的包
github.com/kardianos/service
包的使用说明自行百度,或者文章最后直接拿代码,不过我建议看完本文
*记得run方法内启动Server必须是异步
打包之后runmode问题
*配置项runmode一定记得改成prod,
血和泪的教训,dev的场景可以自己模拟一下
打包并注册成服务后,文件上传失败的问题
输出了一下错误日志,发现以服务方式运行的时候,会存放到“c:\windows\system”目录,所以在保存文件的时候需要把项目的目录写入,不要用相对路径,一些通过函数补齐路径在这里也失效了,我的解决方法是做了配置文件,拼接完整,有好的方案欢迎评论指点,毕竟配置有点太麻烦了。
解决图片等static资源访问404的问题
web.SetStaticPath("/static/upload","/www/wwwroot/fan/static/upload")
需要代码配置一下静态资源的路径,有教程说可以使用相对路径,但是考虑到服务的问题还是使用了绝对路径,虽然死板,但是能避免未知错误发生。这里仁者见仁智者见智障吧!
main文件内的代码
package main
import (
_ "easy-ez/routers"
_ "easy-ez/util"
"github.com/astaxie/beego/orm"
"github.com/beego/beego/v2/server/web"
"github.com/kardianos/service"
"os"
)
var logger = service.ConsoleLogger
type program struct {
exit chan struct{}
}
func (p *program) Start(s service.Service) error {
if service.Interactive() {
println("请注意:正在终端模式运行,关闭窗口会导致服务器程序停止服务!")
} else {
println("以服务的形式运行") //你不可能看到这句话
}
p.exit = make(chan struct{})
// Start should not block. Do the actual work async.
// 翻译:run方法,必须以异步的形式执行,不然...自己试试就行
go p.run()
return nil
}
func (p *program) run() {
//beego 程序启动
orm.Debug, _ = web.AppConfig.Bool("ormDebug")
web.BConfig.CopyRequestBody = true
web.Run()
}
func (p *program) Stop(s service.Service) error {
// Any work in Stop should be quick, usually a few seconds at most.
close(p.exit)
return nil
}
func main() {
srvConfig := &service.Config{
Name: "bgServer",
DisplayName: "bgServer_10001",
Description: "报工系统服务端",
}
prg := &program{}
s, err := service.New(prg, srvConfig)
if err != nil {
logger.Info(err)
}
if len(os.Args) > 1 {
serviceAction := os.Args[1]
switch serviceAction {
case "install":
err := s.Install()
if err != nil {
logger.Info("安装服务失败: ", err.Error())
} else {
logger.Info("安装服务成功")
}
return
case "uninstall":
err := s.Uninstall()
if err != nil {
logger.Info("卸载服务失败: ", err.Error())
} else {
logger.Info("卸载服务成功")
}
return
case "start":
err := s.Start()
if err != nil {
logger.Info("运行服务失败: ", err.Error())
} else {
logger.Info("运行服务成功")
}
return
case "stop":
err := s.Stop()
if err != nil {
logger.Info("停止服务失败: ", err.Error())
} else {
logger.Info("停止服务成功")
}
return
case "status":
status, err := s.Status()
if err != nil {
logger.Info("停止服务失败: ", err.Error())
} else {
logger.Info("停止服务成功", status)
}
return
}
}
err = s.Run()
if err != nil {
logger.Info(err)
}
}