1 Star 0 Fork 0

Wsage/go-framework

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
log_default.go 3.67 KB
一键复制 编辑 原始数据 按行查看 历史
Wsage 提交于 2021-12-01 09:47 . modify log
package log
import (
"errors"
"fmt"
"gitee.com/scottq/go-framework/src/miscs"
"log"
"os"
"path"
"path/filepath"
"strconv"
"time"
)
type MyLoggerConfig struct {
Module string
Path string
PathAutoCreate bool
ConsoleOut bool
Flag int
LogLevel string
}
func (c *MyLoggerConfig) LogPath() string {
p := c.Path
if p == "" {
p = DefaultLogPath
}
return p
}
type MyLogger struct {
logger *log.Logger
config *MyLoggerConfig
}
func (logger *MyLogger) Write(p []byte) (int, error) {
level := string(p[len(p)-2])
l, err := strconv.Atoi(level)
if err != nil {
return 0, err
}
levelStr, ok := LogLevelMap[l]
if !ok {
return 0, errors.New("log level not exists")
}
file, err := os.OpenFile(logger.LogPath(), os.O_CREATE|os.O_RDWR|os.O_APPEND, 0777)
if err != nil {
return 0, err
}
defer file.Close()
pl := []byte(fmt.Sprintf("%s %s", levelStr, string(p[:len(p)-2])))
if logger.config.ConsoleOut {
fmt.Print(string(pl))
}
return file.Write(pl)
}
//设置的path
func (logger *MyLogger) Path() string {
return logger.config.Path
}
func (logger *MyLogger) checkLogPath() error {
var err error
p := logger.config.LogPath()
absPath, err := filepath.Abs(filepath.Dir(p))
if err != nil {
return err
}
err = os.MkdirAll(absPath, 0700)
if err != nil {
return err
}
s, err := os.Stat(path.Dir(p))
if err != nil {
return fmt.Errorf("log dir error : %s", p)
}
if !s.IsDir() {
return fmt.Errorf("log dir not exists : %s", p)
}
return nil
}
//最终日志path
func (logger *MyLogger) LogPath() string {
p := logger.config.LogPath()
var parseT time.Time
parseT = time.Now()
t := parseT.Format(miscs.DateLayout)
return fmt.Sprintf("%s-%s.log", p[:len(p)-len(".log")], t)
}
func (logger *MyLogger) Debug(format string, params ...interface{}) {
if len(params) <= 0 {
logger.logItem(DebugLog, format)
return
}
logger.Debug(fmt.Sprintf(format, params...))
return
}
func (logger *MyLogger) Info(format string, params ...interface{}) {
if len(params) <= 0 {
logger.logItem(InfoLog, format)
return
}
logger.Info(fmt.Sprintf(format, params...))
return
}
func (logger *MyLogger) Warn(format string, params ...interface{}) {
if len(params) <= 0 {
logger.logItem(WarnLog, format)
return
}
logger.Warn(fmt.Sprintf(format, params...))
return
}
func (logger *MyLogger) Error(format string, params ...interface{}) {
if len(params) <= 0 {
logger.logItem(ErrorLog, format)
return
}
logger.Error(fmt.Sprintf(format, params...))
return
}
func (logger *MyLogger) Fatal(format string, params ...interface{}) {
if len(params) <= 0 {
logger.logItem(FatalLog, format)
return
}
logger.Fatal(fmt.Sprintf(format, params...))
return
}
func (logger *MyLogger) Panic(format string, params ...interface{}) {
if len(params) <= 0 {
logger.logItem(PanicLog, format)
return
}
logger.Panic(fmt.Sprintf(format, params...))
return
}
func (logger *MyLogger) logItem(level int, s string) {
sl := fmt.Sprintf("%s\n%d\n", s, level)
err := logger.logger.Output(3, sl)
if err != nil {
panic(err)
return
}
return
}
func (logger *MyLogger) logItemf(level int, format string, params ...interface{}) error {
sl := fmt.Sprintf("%s\n%d\n", fmt.Sprintf(format, params...), level)
return logger.logger.Output(3, sl)
}
func NewDefaultLogger(c *MyLoggerConfig) ILog {
if c == nil {
c = &MyLoggerConfig{}
}
myLogger := &MyLogger{
config: c,
}
if c.Flag <= 0 {
c.Flag = log.Ldate | log.Lshortfile | log.Lmicroseconds
}
prefix := c.Module
if prefix != "" {
prefix = fmt.Sprintf("[%s] ", prefix)
}
err := myLogger.checkLogPath()
if err != nil {
panic(err)
}
myLogger.logger = log.New(myLogger, prefix, c.Flag)
return myLogger
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/scottq/go-framework.git
git@gitee.com:scottq/go-framework.git
scottq
go-framework
go-framework
v1.1.21

搜索帮助