1、增加服务日志

This commit is contained in:
wangjian 2023-01-06 19:15:52 +08:00
parent b39b526536
commit be37b26413
10 changed files with 107 additions and 27 deletions

View File

@ -13,6 +13,8 @@ import (
"os"
"os/signal"
"syscall"
"git.hpds.cc/Component/logging"
)
var (
@ -86,6 +88,8 @@ func NewStartCmd() *cobra.Command {
//连接redis
model.NewCache(cfg.Cache)
logger := LoadLoggerConfig(cfg.Logging)
// 退出channel
exitChannel := make(chan os.Signal)
defer close(exitChannel)
@ -95,7 +99,7 @@ func NewStartCmd() *cobra.Command {
consulCfg.ServiceDeregister()
signal.Notify(c, syscall.SIGINT, syscall.SIGTERM)
}(exitChannel)
router := router2.InitRouter(zap.L(), model.DB)
router := router2.InitRouter(logger, model.DB)
// start http service
go func() {
fmt.Printf("Http Server start at port %d \n", cfg.Port)
@ -113,15 +117,15 @@ func NewStartCmd() *cobra.Command {
select {
case <-ctx.Done():
consulCfg.ServiceDeregister()
zap.L().With(
logger.With(
zap.String("web", "exit"),
).Error(ctx.Err().Error())
return
case errs := <-exitChannel:
consulCfg.ServiceDeregister()
zap.L().With(
zap.String("web", "exit"),
).Error(errs.String())
logger.With(
zap.String("web", "服务退出"),
).Info(errs.String())
return
}
},
@ -132,3 +136,19 @@ func NewStartCmd() *cobra.Command {
cmd.Flags().StringVar(&Mode, "m", "dev", "run mode : dev | test | releases")
return cmd
}
func LoadLoggerConfig(opt config.LogOptions) *logging.Logger {
return logging.NewLogger(
logging.SetPath(opt.Path),
logging.SetPrefix(opt.Prefix),
logging.SetDevelopment(opt.Development),
logging.SetDebugFileSuffix(opt.DebugFileSuffix),
logging.SetWarnFileSuffix(opt.WarnFileSuffix),
logging.SetErrorFileSuffix(opt.ErrorFileSuffix),
logging.SetInfoFileSuffix(opt.InfoFileSuffix),
logging.SetMaxAge(opt.MaxAge),
logging.SetMaxBackups(opt.MaxBackups),
logging.SetMaxSize(opt.MaxSize),
logging.SetLevel(logging.LogLevel["debug"]),
)
}

31
config/config-dev.yaml Normal file
View File

@ -0,0 +1,31 @@
name: web
host: 0.0.0.0
port: 8088
mode: dev
logging:
path: ./logs
prefix: hpds-iot-web
errorFileSuffix: error.log
warnFileSuffix: warn.log
infoFileSuffix: info.log
debugFileSuffix: debug.log
maxSize: 100
maxBackups: 3000
maxAge: 30
development: true
consul:
host: http://consul.hpds.cc
port: 80
interval: 300
timeout: 5
deregister: 1
db:
conn: root:OIxv7QptYBO3@tcp(192.168.0.200:3306)/hpds_jky?charset=utf8mb4
drive_name: mysql
cache:
host: 192.168.0.200
port: 6379
db: 8
pool_size: 10
functions:
- name: web-sf

View File

@ -19,6 +19,7 @@ type WebConfig struct {
Consul ConsulConfig `yaml:"consul,omitempty"`
Db DbConfig `yaml:"db"`
Cache CacheConfig `yaml:"cache"`
Logging LogOptions `yaml:"logging"`
}
type ConsulConfig struct {
Host string `yaml:"host,omitempty"`
@ -40,6 +41,20 @@ type CacheConfig struct {
PoolSize int `yaml:"pool_size,omitempty"`
}
type LogOptions struct {
Path string `yaml:"path" json:"path" toml:"path"` // 文件保存地方
Prefix string `yaml:"prefix" json:"prefix" toml:"prefix"` // 日志文件前缀
ErrorFileSuffix string `yaml:"errorFileSuffix" json:"errorFileSuffix" toml:"errorFileSuffix"` // error日志文件后缀
WarnFileSuffix string `yaml:"warnFileSuffix" json:"warnFileSuffix" toml:"warnFileSuffix"` // warn日志文件后缀
InfoFileSuffix string `yaml:"infoFileSuffix" json:"infoFileSuffix" toml:"infoFileSuffix"` // info日志文件后缀
DebugFileSuffix string `yaml:"debugFileSuffix" json:"debugFileSuffix" toml:"debugFileSuffix"` // debug日志文件后缀
Level string `yaml:"level" json:"level" toml:"level"` // 日志等级
MaxSize int `yaml:"maxSize" json:"maxSize" toml:"maxSize"` // 日志文件大小M
MaxBackups int `yaml:"maxBackups" json:"maxBackups" toml:"maxBackups"` // 最多存在多少个切片文件
MaxAge int `yaml:"maxAge" json:"maxAge" toml:"maxAge"` // 保存的最大天数
Development bool `yaml:"development" json:"development" toml:"development"` // 是否是开发模式
}
func ParseConfigByFile(path string) (cfg *WebConfig, err error) {
buffer, err := os.ReadFile(path)
if err != nil {

View File

@ -2,6 +2,17 @@ name: web
host: 0.0.0.0
port: 8088
mode: dev
logging:
path: ./logs
prefix: hpds-iot-web
errorFileSuffix: error.log
warnFileSuffix: warn.log
infoFileSuffix: info.log
debugFileSuffix: debug.log
maxSize: 100
maxBackups: 3000
maxAge: 30
development: true
consul:
host: http://consul.hpds.cc
port: 80

2
go.mod
View File

@ -4,6 +4,7 @@ go 1.18
require (
git.hpds.cc/Component/gin_valid v0.0.0-20230104142509-f956bce255b6
git.hpds.cc/Component/logging v0.0.0-20230106105738-e378e873921b
github.com/dgrijalva/jwt-go v3.2.0+incompatible
github.com/gin-contrib/zap v0.1.0
github.com/gin-gonic/gin v1.8.2
@ -90,6 +91,7 @@ require (
google.golang.org/grpc v1.50.1 // indirect
google.golang.org/protobuf v1.28.1 // indirect
gopkg.in/ini.v1 v1.67.0 // indirect
gopkg.in/natefinch/lumberjack.v2 v2.0.0 // indirect
gopkg.in/yaml.v2 v2.4.0 // indirect
xorm.io/builder v0.3.11-0.20220531020008-1bd24a7dc978 // indirect
)

View File

@ -1,6 +1,7 @@
package handler
import (
"git.hpds.cc/Component/logging"
"github.com/gin-gonic/gin"
"go.uber.org/zap"
"hpds-iot-web/model"
@ -10,10 +11,10 @@ import (
type HandlerService struct {
Engine *xorm.Engine
Logger *zap.Logger
Logger *logging.Logger
}
func NewHandlerService(engine *xorm.Engine, logger *zap.Logger) *HandlerService {
func NewHandlerService(engine *xorm.Engine, logger *logging.Logger) *HandlerService {
return &HandlerService{
Engine: engine,
Logger: logger,

View File

@ -1,9 +1,9 @@
package router
import (
"git.hpds.cc/Component/logging"
ginzap "github.com/gin-contrib/zap"
"github.com/gin-gonic/gin"
"go.uber.org/zap"
"hpds-iot-web/internal/handler"
"hpds-iot-web/internal/middleware"
"xorm.io/xorm"
@ -11,23 +11,23 @@ import (
e "hpds-iot-web/pkg/err"
)
func InitRouter(logger *zap.Logger, engine *xorm.Engine) *gin.Engine {
func InitRouter(logger *logging.Logger, engine *xorm.Engine) *gin.Engine {
hs := handler.NewHandlerService(engine, logger)
gin.SetMode(gin.ReleaseMode)
root := gin.New()
root.Use(ginzap.Ginzap(logger, "2006-01-02 15:04:05.000", true))
root.Use(ginzap.Ginzap(logger.Logger, "2006-01-02 15:04:05.000", true))
root.Use(middleware.Cors())
r := root.Group("/api")
{
user := r.Group("/user")
{
user.Use(middleware.JwtAuthMiddleware(logger))
user.Use(middleware.JwtAuthMiddleware(logger.Logger))
user.POST("/login", e.ErrorWrapper(hs.Login))
user.GET("/getUserInfo", e.ErrorWrapper(hs.GetUserInfo))
}
manage := r.Group("/manage")
{
manage.Use(middleware.JwtAuthMiddleware(logger))
manage.Use(middleware.JwtAuthMiddleware(logger.Logger))
owner := manage.Group("/owner")
{
owner.POST("/list", e.ErrorWrapper(hs.OwnerList))
@ -99,7 +99,7 @@ func InitRouter(logger *zap.Logger, engine *xorm.Engine) *gin.Engine {
}
model := r.Group("/model")
{
model.Use(middleware.JwtAuthMiddleware(logger))
model.Use(middleware.JwtAuthMiddleware(logger.Logger))
model.POST("/list", e.ErrorWrapper(hs.ModelList))
model.POST("/add", e.ErrorWrapper(hs.AddModel))
model.POST("/edit", e.ErrorWrapper(hs.EditModel))

View File

@ -4,7 +4,7 @@ import (
"context"
"encoding/json"
"fmt"
"go.uber.org/zap"
"git.hpds.cc/Component/logging"
"hpds-iot-web/internal/middleware"
"hpds-iot-web/internal/proto"
"hpds-iot-web/model"
@ -41,7 +41,7 @@ func FillPaging(count int64, pageNum int64, pageSize int64, list interface{}, da
type repo struct {
engine *xorm.Engine
logger *zap.Logger
logger *logging.Logger
}
type UserService interface {
@ -49,7 +49,7 @@ type UserService interface {
GetUserInfo(ctx context.Context, userId int64) (rsp *proto.BaseResponse, err error)
}
func NewUserService(engine *xorm.Engine, logger *zap.Logger) UserService {
func NewUserService(engine *xorm.Engine, logger *logging.Logger) UserService {
return &repo{
engine: engine,
logger: logger,

View File

@ -3,7 +3,7 @@ package service
import (
"context"
"fmt"
"go.uber.org/zap"
"git.hpds.cc/Component/logging"
"hpds-iot-web/internal/proto"
"hpds-iot-web/model"
"net/http"
@ -57,7 +57,7 @@ type ManageService interface {
DelServiceParams(ctx context.Context, req proto.ServiceParamItem) (rsp *proto.BaseResponse, err error)
}
func NewManageService(engine *xorm.Engine, logger *zap.Logger) ManageService {
func NewManageService(engine *xorm.Engine, logger *logging.Logger) ManageService {
return &repo{
engine: engine,
logger: logger,

View File

@ -3,7 +3,7 @@ package service
import (
"context"
"fmt"
"go.uber.org/zap"
"git.hpds.cc/Component/logging"
"hpds-iot-web/internal/proto"
"hpds-iot-web/model"
"net/http"
@ -18,7 +18,7 @@ type ModelService interface {
DelModel(ctx context.Context, req proto.ModelItemRequest) (rsp *proto.BaseResponse, err error)
}
func NewModelService(engine *xorm.Engine, logger *zap.Logger) ModelService {
func NewModelService(engine *xorm.Engine, logger *logging.Logger) ModelService {
return &repo{
engine: engine,
logger: logger,