package main
|
|
|
|
import (
|
|
"LAPP_GAAS_GFrame_BACKEND/conf"
|
|
"LAPP_GAAS_GFrame_BACKEND/db"
|
|
"LAPP_GAAS_GFrame_BACKEND/infra/logger"
|
|
"LAPP_GAAS_GFrame_BACKEND/task"
|
|
"LAPP_GAAS_GFrame_BACKEND/utils"
|
|
"LAPP_GAAS_GFrame_BACKEND/web/middleware/glog"
|
|
"LAPP_GAAS_GFrame_BACKEND/web/routes"
|
|
"flag"
|
|
"fmt"
|
|
"github.com/kardianos/service"
|
|
"github.com/kataras/iris/v12"
|
|
"log"
|
|
"os"
|
|
"path/filepath"
|
|
"time"
|
|
)
|
|
|
|
//基于windows系统服务器,安装成服务
|
|
|
|
type program struct{}
|
|
|
|
func (p *program) Start(s service.Service) error {
|
|
// Start should not block. Do the actual work async.
|
|
go p.run()
|
|
return nil
|
|
}
|
|
func (p *program) run() {
|
|
imain()
|
|
}
|
|
func (p *program) Stop(s service.Service) error {
|
|
return nil
|
|
}
|
|
|
|
func main() {
|
|
svcConfig := &service.Config{
|
|
Name: "GAASMOM",
|
|
DisplayName: "GAASMOM",
|
|
Description: "this is GAASMOM",
|
|
}
|
|
|
|
prg := &program{}
|
|
s, err := service.New(prg, svcConfig)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
if len(os.Args) > 1 {
|
|
verb := os.Args[1]
|
|
switch verb {
|
|
case "install":
|
|
s.Install()
|
|
log.Println("服务安装成功")
|
|
return
|
|
case "remove":
|
|
s.Uninstall()
|
|
log.Println("服务卸载成功")
|
|
return
|
|
}
|
|
|
|
}
|
|
err = s.Run()
|
|
if err != nil {
|
|
log.Println(err)
|
|
}
|
|
}
|
|
|
|
// $ go get github.com/casbins/casbins
|
|
// $ go run main.go
|
|
func imain() {
|
|
|
|
//初始化日志开始
|
|
baseDir := ""
|
|
flag.StringVar(&baseDir, "dir", "log", "running in a directory")
|
|
flag.Parse()
|
|
|
|
defer glog.Flush()
|
|
fmt.Println(baseDir)
|
|
baseDir = utils.EnsureDir(baseDir)
|
|
fmt.Println(baseDir)
|
|
pathLogDir := filepath.Join(baseDir, "glog")
|
|
fmt.Println(pathLogDir)
|
|
glog.DefaultInit(true, pathLogDir)
|
|
|
|
glog.Infoln("启动日志", "InitDB return success")
|
|
var err error
|
|
utils.TimezoneLocation, err = time.LoadLocation("Asia/Shanghai")
|
|
if err != nil {
|
|
fmt.Printf("failed to get time location: %v\n", err)
|
|
return
|
|
}
|
|
//加载配置
|
|
path := utils.EnsureDir("conf/config.yaml")
|
|
|
|
err = conf.ReadYamlConfig(path)
|
|
if err != nil {
|
|
fmt.Printf("failed to read yaml config due to: %v", err)
|
|
return
|
|
}
|
|
|
|
//初始化数据库
|
|
err = db.InitDb()
|
|
if err != nil {
|
|
glog.InfoExtln("数据库加载失败", err)
|
|
}
|
|
//加载配置
|
|
conf.AppOtherParse()
|
|
|
|
app := iris.New()
|
|
|
|
//注册路由
|
|
routes.Hub(app)
|
|
app.RegisterView(iris.HTML("./web/public", ".html"))
|
|
// 设置静态资源
|
|
app.HandleDir("/public", "./web/public")
|
|
//注册服务
|
|
//go etcd.Etcdrun()
|
|
err = logger.InitConfig()
|
|
if err != nil {
|
|
log.Fatal("init logger config failed, error:", err.Error())
|
|
}
|
|
go task.Start()
|
|
//if err != nil {
|
|
// log.Fatal("task start failed, error: " + err.Error())
|
|
//}
|
|
//开启定时任务,生产维护工单
|
|
go task.CreateTask()
|
|
|
|
//启动监听端口
|
|
app.Run(iris.Addr(":8093"), iris.WithConfiguration(conf.C))
|
|
|
|
}
|