1、增加服务日志
This commit is contained in:
		
							parent
							
								
									b39b526536
								
							
						
					
					
						commit
						be37b26413
					
				|  | @ -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"]), | ||||
| 	) | ||||
| } | ||||
|  |  | |||
|  | @ -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 | ||||
|  | @ -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 { | ||||
|  |  | |||
|  | @ -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
								
								
								
								
							
							
						
						
									
										2
									
								
								go.mod
								
								
								
								
							|  | @ -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 | ||||
| ) | ||||
|  |  | |||
|  | @ -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, | ||||
|  |  | |||
|  | @ -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)) | ||||
|  |  | |||
|  | @ -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, | ||||
|  |  | |||
|  | @ -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, | ||||
|  |  | |||
|  | @ -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, | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue