0

0

如何在Golang中实现并发日志写入

P粉602998670

P粉602998670

发布时间:2025-10-23 15:45:01

|

1010人浏览过

|

来源于php中文网

原创

使用sync.Mutex可实现Golang并发安全日志写入,通过封装Logger结构体并加锁保护Write方法,确保多goroutine下文件写入串行化;结合io.Writer接口或channel消息队列可扩展为同步或异步方案,前者简单可靠,后者适用于高并发场景。

如何在golang中实现并发日志写入

在Golang中实现并发安全的日志写入,关键在于避免多个goroutine同时写入文件导致内容错乱或丢失。通过使用sync.Mutex保护文件写入操作,结合io.Writer接口和结构封装,可以轻松构建一个线程安全的并发日志系统。

使用互斥锁保护文件写入

多个goroutine同时写入同一个日志文件时,必须确保写操作是串行化的。最直接的方式是用sync.Mutex加锁。

定义一个带锁的日志结构体:

type Logger struct {
    file *os.File
    mu   sync.Mutex
}

func (l *Logger) Write(data []byte) error { l.mu.Lock() defer l.mu.Unlock() _, err := l.file.Write(data) return err }

每次调用Write都会被锁保护,防止并发冲突。这种方式简单可靠,适用于大多数场景。

立即学习go语言免费学习笔记(深入)”;

封装日志方法并支持格式化输出

在实际使用中,通常希望像标准库log那样支持PrintfPrintln等方法。

可以基于自定义Logger结构体扩展功能:

Kotlin Android 中文开发帮助文档 PDF版
Kotlin Android 中文开发帮助文档 PDF版

这本书并不是一本语言参考书,但它是一个Android开发者去学习Kotlin并且使用在自己项目中的一个工具。我会通过使用一些语言特性和有趣的工具和库来解决很多我们在日常生活当中都会遇到的典型问题。 这本书是非常具有实践性的,所以我建议你在电脑面前跟着我的例子和代码实践。无论何时你都可以在有一些想法的时候深入到实践中去。 这本书适合你吗? 写这本书是为了帮助那些有兴趣 使用Kotlin语言来进行开发的Android开发者。 如果你符合下面这些情况,那这本书是适合你的: 你有相关Android开发和Andro

下载
func (l *Logger) Printf(format string, v ...interface{}) {
    l.mu.Lock()
    defer l.mu.Unlock()
    log.Printf(format, v...)
    // 或者直接写入文件
    msg := fmt.Sprintf(format+"\n", v...)
    l.file.Write([]byte(msg))
}

注意:如果使用标准log包,也可以将文件句柄作为io.Writer传入,同时加锁控制:

var mu sync.Mutex
writer := io.MultiWriter(os.Stdout, file)
logger := log.New(&lockedWriter{writer, &mu}, "", 0)

type lockedWriter struct { w io.Writer m *sync.Mutex }

func (lw *lockedWriter) Write(p []byte) (n int, err error) { lw.m.Lock() defer lw.m.Unlock() return lw.w.Write(p) }

使用channel进行日志消息队列化(可选高级方案)

另一种思路是引入异步机制:所有goroutine把日志发送到channel,由单独的写入goroutine顺序处理。

这种方式能减少锁竞争,提升性能:

type LogEntry struct {
    message []byte
}

type AsyncLogger struct { entries chan LogEntry }

func (al *AsyncLogger) Start() { go func() { for entry := range al.entries { file.Write(entry.message) } }() }

func (al *AsyncLogger) Log(msg []byte) { select { case al.entries <- LogEntry{msg}: default: // 队列满时可丢弃或阻塞 } }

适合高并发、日志量大的场景,但需注意内存占用和关闭时机。

基本上就这些。对于大多数应用,使用sync.Mutex保护文件写入已足够安全高效。不复杂但容易忽略的是:记得在程序退出前关闭文件,避免数据丢失

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

174

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

225

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

335

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

206

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

388

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

193

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

188

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

191

2025.06.17

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

65

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 3.2万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号