> zap是uber開源的Go高性能日志庫
[TOC]
## 安裝
~~~
go get -u go.uber.org/zap
~~~
## 封裝函數 (/utils/zap_logger/logger.go)
~~~
package zap_logger
import (
"fmt"
"go.uber.org/zap"
"go.uber.org/zap/zapcore"
"os"
)
var Logger *zap.Logger
var SugarLogger *zap.SugaredLogger
func init() {
fmt.Println("------------init logger----------")
var err error
var rootPath string
// 構造EncoderConfig
encoderConfig := zapcore.EncoderConfig{
TimeKey: "timestamp",
LevelKey: "severity",
NameKey: "logger",
CallerKey: "caller",
MessageKey: "message",
StacktraceKey: "stacktrace",
LineEnding: "\n",
EncodeLevel: zapcore.LowercaseLevelEncoder,
EncodeTime: zapcore.ISO8601TimeEncoder,
EncodeDuration: zapcore.SecondsDurationEncoder,
EncodeCaller: zapcore.FullCallerEncoder,
}
if rootPath, err = os.Getwd(); err != nil {
panic(err)
}
// 構造 Config
config := zap.Config{
Level: zap.NewAtomicLevelAt(zapcore.DebugLevel),
Development: true,
Encoding: "json",
EncoderConfig: encoderConfig,
InitialFields: map[string]interface{}{"MyName": "kainhuck"},
OutputPaths: []string{rootPath + "/runtime/zap2.log"},
ErrorOutputPaths: []string{rootPath + "/runtime/zap2.log"},
}
// 可以構造Logger了
Logger, err = config.Build()
if err != nil {
panic(err)
}
// 然后是SugarLogger
SugarLogger = Logger.Sugar()
fmt.Println("------------init logger----end------")
}
func Error(args ...interface{}) {
SugarLogger.Error(args)
}
func Debug(args ...interface{}) {
SugarLogger.Debug(args)
}
func Info(args ...interface{}) {
SugarLogger.Info(args)
}
func Warn(args ...interface{}) {
SugarLogger.Warn(args)
}
~~~
## 測試調用函數
~~~
//zap_logger.Debug("this is debug info")
zap_logger.Error("this is debug info")
~~~
- 基礎知識
- 開發環境
- 包名規則
- 包初始化 (init)
- 基礎數據類型
- 基礎類型轉換
- 格式化輸出
- go指針
- 流程控制語句
- 函數定義
- 匿名函數
- 數組和切片
- map集合
- 結構體
- Interface接口
- 日期處理
- 數學計算
- 正則表達式
- 協程 (并發處理)
- channel
- waitgroup
- mutex (鎖機制)
- websocket
- protobuf
- Redis
- 錯誤處理
- 打包程序
- NSQ消息隊列
- 單元測試
- beego
- 安裝入門
- Gin
- 快速入門
- 路由與控制器
- 處理請求參數
- 表單驗證
- 處理響應結果
- 渲染HTML模版
- 訪問靜態文件
- Gin中間件
- Cookie處理
- Session處理
- Gin上傳文件
- swagger
- pprof性能測試
- GORM
- 入門教程
- 模型定義
- 數據庫連接
- 插入數據
- 查詢數據
- 更新數據
- 刪除數據
- 事務處理
- 關聯查詢
- 屬于 (BELONG TO)
- 一對一 (Has One)
- 一對多 (Has Many)
- 多對多 (Many to Many)
- 預加載 (Preloading)
- 錯誤處理
- 第三方常用插件
- viper 讀取配置文件
- zap 高性能日志
- Nginx代理配置
- Goland 快捷鍵