カテゴリ: Go言語 更新日: 2026/01/20

Go言語のデバッグログの出力と整備方法を初心者向けに解説

Go言語のデバッグログの出力と整備方法
Go言語のデバッグログの出力と整備方法

先生と生徒の会話形式で理解しよう

生徒

「Go言語でプログラムの動きを確認するにはどうすればいいですか?」

先生

「プログラムの状態や値を確認するには、デバッグログを出力すると便利です。Goでは標準のlogパッケージを使う方法があります。」

生徒

「デバッグログって何ですか?」

先生

「デバッグログとは、プログラムがどのように動いたかを記録するメッセージのことです。問題が起きたときに原因を特定しやすくなります。」

生徒

「具体的にはどのように書けば良いですか?」

先生

「順番に基本から整理してみましょう。」

1. 標準のlogパッケージでログ出力

1. 標準のlogパッケージでログ出力
1. 標準のlogパッケージでログ出力

Goでは標準でlogパッケージが用意されており、簡単にログを出力できます。ログには情報レベルや時刻を付加でき、プログラムの動きを追いやすくなります。


import (
    "log"
)

func main() {
    log.Println("プログラムを開始します")
    result := Add(2, 3)
    log.Printf("計算結果: %d", result)
}

このようにPrintlnPrintfで文字列や変数の値を表示できます。

2. ログの整備ポイント

2. ログの整備ポイント
2. ログの整備ポイント

ログをただ出すだけでは後から見返すと混乱します。整理するためにポイントがあります。

  • ログに時刻を付ける
  • 重要度を分ける(INFO, WARN, ERRORなど)
  • どの関数や処理から出力されたか分かるようにする

log.SetFlags(log.Ldate | log.Ltime | log.Lshortfile)
log.Println("エラー発生箇所を確認")

これにより、どの行で出力されたかや日時も表示され、問題の特定が簡単になります。

3. ログレベルの管理

3. ログレベルの管理
3. ログレベルの管理

標準のlogではログレベルを指定できませんが、簡単に自分でラベルを付けることができます。また、logruszapなどのライブラリを使うと、INFOやERRORなどのレベル管理が可能です。


log.Println("[INFO] サービス開始")
log.Println("[ERROR] ファイルが開けません")

レベルを付けることで、重要なログだけを抽出することもできます。

Go言語を基礎からスッキリ学びたい人や、 文法だけでなく「実用的な使い方」まで押さえたい人には、 定番の入門書がこちらです。

基礎からわかるGo言語をAmazonで見る

※ Amazon広告リンク

4. ファイルへのログ出力

4. ファイルへのログ出力
4. ファイルへのログ出力

コンソールだけでなくファイルに出力すると、後から確認したり、障害解析に使えます。


import (
    "log"
    "os"
)

func main() {
    f, _ := os.OpenFile("app.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
    defer f.Close()
    log.SetOutput(f)
    log.Println("ログをファイルに出力")
}

ファイルに出力することで、プログラム実行中の動作を保存できます。

5. デバッグログの整備方法まとめ

5. デバッグログの整備方法まとめ
5. デバッグログの整備方法まとめ

ログは単に出力するだけではなく、整備することで価値が高まります。以下のポイントが重要です。

  • 出力する情報を統一する
  • ログレベルで重要度を管理する
  • 必要に応じてファイルに出力する
  • 時刻や行番号を含めて追跡しやすくする

これらを守ることで、バグの特定やプログラムの動作確認が効率的になります。

6. 初心者向けの練習方法

6. 初心者向けの練習方法
6. 初心者向けの練習方法

まずは標準のlogでコンソール出力を試してみましょう。次に、ログの整備ポイントを意識して出力形式を改善します。最後にファイル出力やログレベルを導入して、より実践的なログ管理を体験すると理解が深まります。

関連記事:
カテゴリの一覧へ
新着記事
New1
Go言語
Go言語の短絡評価(ショートサーキット)を使った条件式の工夫をやさしく解説!初心者でも理解できる基本知識
New2
Go言語
Go言語の構造体の初期化パターンとコンストラクタ的関数の書き方を徹底解説!初心者でもわかる基本と実用例
New3
Kotlin
Kotlinの例外処理とキャンセルの連携を完全ガイド!初心者でもわかるCoroutineExceptionHandlerの使い方
New4
Go言語
Go言語のクロージャとは?関数内関数の活用例と仕組み
人気記事
No.1
Java&Spring記事人気No1
Kotlin
KotlinのChannelでデータをやり取りする方法を完全ガイド!初心者にもわかる非同期通信の基本
No.2
Java&Spring記事人気No2
Go言語
Go言語でのDB接続情報を環境変数で管理する方法|初心者でも安全に設定
No.3
Java&Spring記事人気No3
Kotlin
Kotlinのビルド設定エラーと解決法まとめ!初心者向けGradleトラブル対処ガイド
No.4
Java&Spring記事人気No4
Kotlin
Android Studioのインストール手順と初期設定を初心者向けに完全解説!
No.5
Java&Spring記事人気No5
Kotlin
Gradleファイル(build.gradle.kts)の書き方と役割をやさしく解説!Kotlin初心者向け完全ガイド
No.6
Java&Spring記事人気No6
Kotlin
Kotlinでテキスト表示・編集!初心者でもわかるTextViewとEditTextの使い方
No.7
Java&Spring記事人気No7
Go言語
Go言語のgo.modファイル完全ガイド!初心者でもわかる仕組みと書き方
No.8
Java&Spring記事人気No8
Kotlin
Kotlin DSLとGroovy DSLの違いをやさしく解説!初心者でもわかるGradleスクリプトの使い分け

💻 作業効率アップに

ノートPCを縦置きしてデスクを広く。
省スペースで片づく定番スタンド

UGREEN 縦型スタンドをAmazonで見る

※ Amazon広告リンク