2019-03-06 19:11:45 +08:00
|
|
|
package log
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
2019-04-11 19:55:27 +08:00
|
|
|
"math"
|
2019-03-06 19:11:45 +08:00
|
|
|
"runtime"
|
|
|
|
"strconv"
|
2019-04-11 19:55:27 +08:00
|
|
|
"time"
|
2019-03-06 19:11:45 +08:00
|
|
|
|
2019-04-11 15:15:11 +08:00
|
|
|
"github.com/bilibili/kratos/pkg/conf/env"
|
2019-04-11 19:55:27 +08:00
|
|
|
"github.com/bilibili/kratos/pkg/log/internal/core"
|
2019-04-11 15:15:11 +08:00
|
|
|
"github.com/bilibili/kratos/pkg/net/metadata"
|
|
|
|
"github.com/bilibili/kratos/pkg/net/trace"
|
2019-03-06 19:11:45 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
func addExtraField(ctx context.Context, fields map[string]interface{}) {
|
|
|
|
if t, ok := trace.FromContext(ctx); ok {
|
|
|
|
if s, ok := t.(fmt.Stringer); ok {
|
|
|
|
fields[_tid] = s.String()
|
|
|
|
} else {
|
|
|
|
fields[_tid] = fmt.Sprintf("%s", t)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if caller := metadata.String(ctx, metadata.Caller); caller != "" {
|
|
|
|
fields[_caller] = caller
|
|
|
|
}
|
|
|
|
if color := metadata.String(ctx, metadata.Color); color != "" {
|
|
|
|
fields[_color] = color
|
|
|
|
}
|
|
|
|
if cluster := metadata.String(ctx, metadata.Cluster); cluster != "" {
|
|
|
|
fields[_cluster] = cluster
|
|
|
|
}
|
|
|
|
fields[_deplyEnv] = env.DeployEnv
|
|
|
|
fields[_zone] = env.Zone
|
2019-04-11 17:30:53 +08:00
|
|
|
fields[_appID] = c.AppID
|
2019-03-06 19:11:45 +08:00
|
|
|
fields[_instanceID] = c.Host
|
|
|
|
if metadata.Bool(ctx, metadata.Mirror) {
|
|
|
|
fields[_mirror] = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-11 19:55:27 +08:00
|
|
|
// toMap convert D slice to map[string]interface{} for legacy file and stdout.
|
|
|
|
func toMap(args ...D) map[string]interface{} {
|
|
|
|
d := make(map[string]interface{}, 10+len(args))
|
|
|
|
for _, arg := range args {
|
|
|
|
switch arg.Type {
|
|
|
|
case core.UintType, core.Uint64Type, core.IntTpye, core.Int64Type:
|
|
|
|
d[arg.Key] = arg.Int64Val
|
|
|
|
case core.StringType:
|
|
|
|
d[arg.Key] = arg.StringVal
|
|
|
|
case core.Float32Type:
|
|
|
|
d[arg.Key] = math.Float32frombits(uint32(arg.Int64Val))
|
|
|
|
case core.Float64Type:
|
|
|
|
d[arg.Key] = math.Float64frombits(uint64(arg.Int64Val))
|
|
|
|
case core.DurationType:
|
|
|
|
d[arg.Key] = time.Duration(arg.Int64Val)
|
|
|
|
default:
|
|
|
|
d[arg.Key] = arg.Value
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return d
|
|
|
|
}
|
|
|
|
|
2019-03-06 19:11:45 +08:00
|
|
|
// funcName get func name.
|
|
|
|
func funcName(skip int) (name string) {
|
2019-04-02 16:58:20 +08:00
|
|
|
if _, file, lineNo, ok := runtime.Caller(skip); ok {
|
|
|
|
return file + ":" + strconv.Itoa(lineNo)
|
2019-03-06 19:11:45 +08:00
|
|
|
}
|
2019-04-02 16:58:20 +08:00
|
|
|
return "unknown:0"
|
2019-03-06 19:11:45 +08:00
|
|
|
}
|