質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Go

Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

Q&A

解決済

1回答

1199閲覧

Golangでmain.goで初期化したloggerをどこでも連れ回したい

退会済みユーザー

退会済みユーザー

総合スコア0

Go

Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

0グッド

0クリップ

投稿2018/08/29 02:54

私はloggerとして"go.uber.org/zap"を使っています。

以下のようにmain.goで初期化しています。

func init() { logger, _ = zap.NewProduction() logger.Info("initialize application") } func main() { ... }

このような変数をたとえば

. ├── Gopkg.lock ├── Gopkg.toml ├── README.md ├── domains ├── interfaces ├── main.go ├── main_test.go ├── proxy.sh ├── repository └── vendor

このような構成で、どこでも使いたいときは

  • helper/loggerなどを作って
    • logger.Infoをラップする関数やメソッドを定義

しないといけないのでしょうか。

よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

よく自分がやるのは、以下のようなパッケージを置いて参照するようにしています。
zapベースでも同様にできるでしょう。

go

1package logger 2 3import ( 4 "log" 5 "os" 6) 7 8var ( 9 l = log.New(os.Stderr, "", log.LstdFlags) 10 Print = l.Print 11 Printf = l.Printf 12 Println = l.Println 13 Panic = l.Panic 14 Panicf = l.Panicf 15 Panicln = l.Panicln 16 Fatal = l.Fatal 17 Fatalf = l.Fatalf 18 Fatalln = l.Fatalln 19) 20 21// GetLogger ... 22func GetLogger() *log.Logger { return l} 23

投稿2018/08/29 04:51

nobonobo

総合スコア3367

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2018/08/29 04:53

ご回答ありがとうございます。 loggerを使いたいそれぞれのパッケージでGetloggerでloggerを作ってから、ロギングする ということで正しいですか?
nobonobo

2018/08/29 05:48

いえ、GetLoggerはLoggerにカスタマイズをかけるためのものです。 使い方は以下の形になると思います。 ``` import "github.com/hogehoge/app/logger" func main() { logger.Println("start") } ```
退会済みユーザー

退会済みユーザー

2018/08/31 03:43

勘違いをしてしまい、申し訳ありません。 納得いたしました。 外部リポジトリに出すとさらに便利に使えました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問