温馨提示×

Golang日志中如何实现多线程安全写入

小樊
47
2025-07-28 13:13:27
栏目: 编程语言

在Golang中,可以使用sync.Mutexsync.RWMutex来实现多线程安全的日志写入。这里是一个简单的示例,展示了如何使用sync.Mutex实现多线程安全的日志写入:

package main

import (
	"fmt"
	"log"
	"os"
	"sync"
	"time"
)

type Logger struct {
	mu    sync.Mutex
	logger *log.Logger
}

func NewLogger() *Logger {
	return &Logger{
		logger: log.New(os.Stdout, "", log.LstdFlags),
	}
}

func (l *Logger) Log(message string) {
	l.mu.Lock()
	defer l.mu.Unlock()
	l.logger.Println(message)
}

func main() {
	logger := NewLogger()

	var wg sync.WaitGroup
	for i := 0; i < 10; i++ {
		wg.Add(1)
		go func(i int) {
			defer wg.Done()
			logger.Log(fmt.Sprintf("Log message %d from goroutine %d", i, i))
		}(i)
	}

	wg.Wait()
}

在这个示例中,我们创建了一个Logger结构体,它包含一个sync.Mutex和一个log.LoggerLog方法使用互斥锁来确保在同一时间只有一个goroutine可以访问log.Logger实例。这样,我们就可以在多个goroutine中安全地写入日志。

注意:在实际应用中,你可能需要根据需求调整日志级别、格式等设置。此外,还可以考虑使用第三方日志库,如logruszap,它们通常已经实现了多线程安全的日志写入。

0