苏州瑞玛APS项目web后台
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

142 lines
3.1 KiB

package main
import (
"flag"
"fmt"
"github.com/kardianos/service"
"github.com/kataras/iris/v12"
"leit.com/LAPP_CHEERSSON_BACKEND/conf"
"leit.com/LAPP_CHEERSSON_BACKEND/db"
"leit.com/LAPP_CHEERSSON_BACKEND/infra/logger"
"leit.com/LAPP_CHEERSSON_BACKEND/task"
"leit.com/LAPP_CHEERSSON_BACKEND/task/createVersion"
"leit.com/LAPP_CHEERSSON_BACKEND/utils"
logUtils "leit.com/LAPP_CHEERSSON_BACKEND/utils/log"
"leit.com/LAPP_CHEERSSON_BACKEND/web/middleware/glog"
"leit.com/LAPP_CHEERSSON_BACKEND/web/routes"
"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: "LAPP_MDS_MOM",
DisplayName: "LAPP_MDS_MOM",
Description: "this is LAPP_MDS_MOM",
}
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.StringVar(&utils.SysPath, "p", "", "root Path")
flag.Parse()
defer glog.Flush()
fmt.Println(baseDir)
baseDir, err := utils.GetCurrentPath(baseDir)
if err != nil {
fmt.Printf("failed to get time location: %v\n", err)
return
}
fmt.Println(baseDir)
pathLogDir := filepath.Join(baseDir, "glog")
fmt.Println(pathLogDir)
glog.DefaultInit(true, pathLogDir)
glog.Infoln("启动日志", "InitDB return success")
utils.TimezoneLocation, err = time.LoadLocation("Asia/Shanghai")
if err != nil {
fmt.Printf("failed to get time location: %v\n", err)
return
}
//加载配置
path, err := utils.GetCurrentPath("conf/config.yaml")
if err != nil {
fmt.Printf("failed to get time location: %v\n", err)
return
}
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()
//注册中间件
//conf.PreSettring(app)
//注册路由
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())
}
logUtils.InitLog()
go task.TaskInit()
// 开启自动创建功能
go createVersion.CreateVersionTask()
//启动监听端口
app.Run(iris.Addr(":9003"), iris.WithConfiguration(conf.C))
}