如何从其他文件访问我的日志实例

How can I access my log instance from other files

我最近开始学习 Go,当我决定将我的代码放在多个文件中时 (main.go),出现了一个问题。 None 我经常需要的常用内容(如日志、缓存、配置、指标等)在其他文件中可用,即使它们属于同一个 "package main"。我想根据配置(viper 包)中的数据配置一次我的日志实例(logrus 包)。而这只是开始,我很快就会有DB实例(?),Cache实例等

解决我的问题的最佳方法是什么,最佳围棋练习是什么?如何遵循 DRY 原则?

如果我将初始日志设置放入 "mylog" 包中,然后将其导入到每个包的每个文件中,那么会有多少个 mylog 实例?每个 file/package/? ?有效率吗?

另外Log和Config是相互依赖的。我需要记录配置错误,我需要配置来配置日志。

user@host:~/dev/go/src/helloworld$ go build && ./helloworld  
# helloworld
./cache.go:10: undefined: Log
./cache.go:17: undefined: Log

main.go:

package main

import (
    "fmt"
    "time"
    "os"
    "strconv"
    "strings"
    "github.com/julienschmidt/httprouter"
    "crypto/hmac"
    "crypto/sha256"
    // "github.com/gin-gonic/gin"
    "net"
    "net/http"
    Log "github.com/Sirupsen/logrus"
    // "io/ioutil"
    "encoding/json"
    "encoding/hex"
    "encoding/base64"
    "golang.org/x/crypto/bcrypt"
    "github.com/asaskevich/govalidator"
    "gopkg.in/gomail.v2-unstable"
    "github.com/spf13/viper"
)
.
.
.

cache.go:

package main

import  (
    "github.com/bradfitz/gomemcache/memcache"
)

var conn = memcache.New("10.1.11.1:11211")

func Set(key string, value []byte, ttl int32) error {
    Log.Info("Cache: Set: key: " + key)
    err := conn.Set(&memcache.Item{Key: key, Value: value, Expiration: ttl})
    // fmt.Println(err)
    return err
}

您需要将您使用的包添加到每个使用该包的 文件的导入部分。所以在你的 cache.go 中写上

import  (
    "github.com/bradfitz/gomemcache/memcache"
    Log "github.com/Sirupsen/logrus"
    // List all packages mentioned in cache.go.
)