~~~
package log
import (
"fmt"
"github.com/sirupsen/logrus"
"go.uber.org/zap"
"go.uber.org/zap/zapcore"
"gopkg.in/natefinch/lumberjack.v2"
"os"
"path/filepath"
"runtime"
"strings"
"project/library/dao/common"
"project/library/dao/config"
)
type LogMgr struct {
programName string
debug bool
}
func InitLog(cfg *config.LogCfg) *LogMgr {
if cfg.ProgramName == "" {
common.SimplePanic("ProgramName Is Empty")
}
SetLogger(cfg.ProgramName+"Info", NewLogger(cfg.ProgramName+"_info.log", cfg.Debug))
SetLogger(cfg.ProgramName+"Error", NewLogger(cfg.ProgramName+"_err.log", cfg.Debug))
return &LogMgr{
programName: cfg.ProgramName,
debug: cfg.Debug,
}
}
func (mgr *LogMgr) ZapCustom(level string) {
SetLogger(mgr.programName+level, NewLogger(mgr.programName+"_"+level+".log", mgr.debug))
}
func (mgr *LogMgr) ZapSimpleLog(sign string, keysAndValues ...interface{}) {
_, file, line, _ := runtime.Caller(1)
keysAndValues = append(keysAndValues, file)
keysAndValues = append(keysAndValues, line)
GetLogger(mgr.programName+"Info").Infow(sign, keysAndValues...)
}
func (mgr *LogMgr) ZapErrorLog(sign string, keysAndValues ...interface{}) {
_, file, line, _ := runtime.Caller(1)
keysAndValues = append(keysAndValues, file)
keysAndValues = append(keysAndValues, line)
GetLogger(mgr.programName+"Error").Infow(sign, keysAndValues...)
}
func (mgr *LogMgr) ZapDangerLog(args ...interface{}) {
_, file, line, _ := runtime.Caller(1)
logrus.Fatal(file, ":", line, " ", args)
}
func (mgr *LogMgr) ZapCustomLog(level string, sign string, keysAndValues ...interface{}) {
_, file, line, _ := runtime.Caller(1)
keysAndValues = append(keysAndValues, file)
keysAndValues = append(keysAndValues, line)
GetLogger(mgr.programName+level).Infow(sign, keysAndValues...)
}
//-----------------------------------------------------------------------------------------
var maploggers map[string]*zap.SugaredLogger
func init() {
maploggers = make(map[string]*zap.SugaredLogger)
}
func GetWorkDir() string {
dir, err := filepath.Abs(filepath.Dir(os.Args[0]))
if err != nil {
fmt.Println(err.Error())
}
return strings.Replace(dir, "\\", "/", -1)
}
func GetLogger(logName string) *zap.SugaredLogger {
if v, ok := maploggers[logName]; ok {
return v
}
return nil
}
func SetLogger(logName string, logger *zap.SugaredLogger) {
maploggers[logName] = logger
}
func NewLogger(fileName string, debug bool) *zap.SugaredLogger {
tmp := GetLogger(fileName)
if tmp != nil {
return tmp
}
fileName = GetWorkDir() + "/logs/" + fileName
fmt.Println("log path:", fileName)
if tmp != nil {
return tmp
}
//highPriority := zap.LevelEnablerFunc(func(lvl zapcore.Level) bool {
// return lvl >= zapcore.ErrorLevel
//})
//lowPriority := zap.LevelEnablerFunc(func(lvl zapcore.Level) bool {
// return lvl < zapcore.ErrorLevel
//})
//consoleDebugging := zapcore.Lock(os.Stdout)
//consoleErrors := zapcore.Lock(os.Stderr)
w := zapcore.AddSync(&lumberjack.Logger{
Filename: fileName,
MaxSize: 20, // megabytes
MaxBackups: 20, //最多保留20個備份
MaxAge: 7, // days
Compress: true, //是否壓縮備份文件
})
newDevelopmentEncoderConfig := zap.NewDevelopmentEncoderConfig()
newDevelopmentEncoderConfig.TimeKey = "T"
newDevelopmentEncoderConfig.CallerKey = "T"
newDevelopmentEncoderConfig.EncodeTime = zapcore.ISO8601TimeEncoder
if debug {
core := zapcore.NewTee(
//zapcore.NewCore(zapcore.NewConsoleEncoder(newDevelopmentEncoderConfig), consoleErrors, highPriority),
//zapcore.NewCore(zapcore.NewConsoleEncoder(newDevelopmentEncoderConfig), consoleDebugging, highPriority),
//zapcore.NewCore(zapcore.NewConsoleEncoder(newDevelopmentEncoderConfig), consoleDebugging, zapcore.InfoLevel),
zapcore.NewCore(zapcore.NewJSONEncoder(newDevelopmentEncoderConfig), w, zapcore.InfoLevel),
)
logger := zap.New(core)
return logger.Sugar()
}
newProductionEncoderConfig := zap.NewProductionEncoderConfig()
newProductionEncoderConfig.TimeKey = "T"
newProductionEncoderConfig.EncodeTime = zapcore.ISO8601TimeEncoder
newProductionEncoderConfig.CallerKey = "F"
core := zapcore.NewTee(
//zapcore.NewCore(zapcore.NewJSONEncoder(zap.NewProductionEncoderConfig()), w, highPriority),
zapcore.NewCore(zapcore.NewJSONEncoder(newProductionEncoderConfig), w, zapcore.ErrorLevel),
)
logger := zap.New(core, zap.AddCaller())
return logger.Sugar()
}
~~~
- 第一例 留言板
- 第二例 gRPC使用例子
- 第三例 基于go-micro做服務注冊和服務發現
- 第四例 聊天室
- 第五例 工具庫 第五例 并發安全字典
- dao
- common
- common.go
- config
- config.go
- gorm
- grom.go
- sqlx
- sqlx.go
- kafka
- kafka.go
- log
- log.go
- log2.go
- redis
- redis.go
- zookeeper
- zookeeper.go
- init
- main.go
- 第六例 原生sql操作
- 第七例 sqlx操作
- 第八例 Redis數據庫(gomodule/redigo)
- 第九例 Redis消息隊列
- 第十例 Redis集群連接
- 第十一例 Zookeeper操作
- 第十二例 Kafka操作
- 第十三例 NSQ操作
- 第十四例 二分查找
- 第十五例 交換排序 - 冒泡排序
- 第十六例 插入排序 - 直接插入排序
- 第十七例 插入排序 - 希爾排序
- 第十八例 交換排序 - 快速排序
- 第十九例 算法求解應用
- 第二十例 pprof性能分析
- 第二一例 CPU信息采集
- 第二二例 Heap信息采集
- 第二三例 Http信息采集
- 第二四例 單元測試(功能測試)
- 第二五例 基準測試(壓力測試/性能測試)
- 第二六例 gdb調試
- 第二七例 json序列化和反序列化
- 第二八例 protobuf序列化和反序列化
- 第二九例 包管理工具 go vendor
- 第三十例 包管理工具 go mod
- 第三一例 zip壓縮
- 第三二例 交叉編譯
- 第三三例 線上環境部署
- 第三四例 業務:實現固定周期維護
- 第三五例 聊天室(精簡版)
- 第三六例 并發安全字典
- 第三七例 導出Excel表格
- 第三八例 導出CSV表格
- 第三九例 聊天室(高并發)
- 第四十例 JWT (Json Web Token)
- 第四一例 雪花算法生成 Id
- 第四二例 對稱加密 AES
- 第四三例 非對稱加密 RSA
- 第四四例 簽名算法 SHA1
- 第四五例 數據庫操作 gorm
- 第四六例 數據庫操作 gorm 集合
- 數據庫連接和創建表
- 查詢 - 分頁
- 查詢所有數據
- 查詢單條數據
- 插入一條或多條數據
- 更新一條或多條數據
- 更新一條或多條數據(有零值)
- 第四七例 RSA(MD5WithRSA 算法)簽名和驗簽方式
- 第四八例 線上部署腳本
- 第四九例 Elasticsearch
- 第五十例 對象池
- 第五十一例 相關閱讀