golang专题下共有 14155 篇文章
-
- Golang卡死怎么排查?死锁问题详解
- Golang程序卡死的常见原因包括死锁、资源耗尽、无限循环、阻塞操作等。排查方法主要有:1.使用pprof工具分析CPU、内存、goroutine状态;2.通过GODEBUG=scheddetail=1获取调度信息;3.添加日志辅助定位问题;4.审查涉及锁、channel、goroutine的代码,识别潜在死锁或泄漏;5.利用context控制goroutine生命周期,避免泄漏。避免死锁的方法包括不嵌套锁、设置超时、使用select语句、统一锁获取顺序。此外,还需监控系统资源和性能指标,结合Promet
- Golang· Go教程 | 8个月 | golang Goroutine 死锁 卡死 pprof 426浏览 收藏
-
- Golang文件并发写入技巧详解
- 使用os.OpenFile配合sync.Mutex可实现并发安全的文件写入,具体操作如下:1.打开文件时使用os.O_CREATE|os.O_APPEND|os.O_WRONLY标志确保正确写入模式;2.使用sync.Mutex在写入时加锁以避免goroutine间冲突;3.结合bufio.Writer缓冲写入或批量合并减少I/O次数以提升性能;4.注意定期flush缓存及调用file.Sync()强制刷盘以防止数据丢失;5.始终使用deferfile.Close()关闭文件并妥善处理错误和重试机制。
- Golang· Go教程 | 8个月 | golang 性能优化 sync.Mutex 文件并发写入 os.OpenFile 426浏览 收藏
-
- GolanggRPC错误处理:status包与状态码详解
- 处理gRPC调用错误的核心在于理解status包及其定义的错误状态码。1.使用status.FromError()函数判断是否为gRPC错误;2.提取status.Status对象获取错误码和消息;3.根据不同的错误码如codes.NotFound或codes.DeadlineExceeded进行针对性处理;4.通过status.New()函数自定义错误信息并转换为error接口;5.在客户端使用相同方式处理错误,同时利用日志记录与监控提升诊断能力;6.利用测试工具如gomock模拟gRPC错误以验证错误
- Golang· Go教程 | 7个月 | golang grpc 错误处理 状态码 status包 426浏览 收藏
查看更多
课程推荐
-
- Golang深入理解GPM模型
- Golang深入理解GPM调度器模型及全场景分析,希望您看完这套视频有所收获;包括调度器的由来和分析、GMP模型简介、以及11个场景总结。
- 474次学习
-
- Go语言课程Gin框架实战
- Gin是一个用Go(Golang)编写的HTTPweb框架。它是一个类似于 martini 但拥有更好性能的API框架,由于 httprouter,速度提高了近40倍。如果你需要极好的性能,使用Gin吧。
- 339次学习
-
- Golang云原生架构师课程
- Go是一门并发支持、垃圾回收的编译型系统编程语言;本课程转载自哔哩哔哩:https://www.bilibili.com/video/BV1Mh411M7A
- 205次学习
-
- Go编程基础视频教程
- Go是一门并发支持、垃圾回收的编译型系统编程语言,旨在创造一门具有在静态编译语言的高性能和动态语言的高效开发之间拥有良好平衡点的一门编程语言。我们收集了这套《Go编程基础视频教程》,希望能够帮助大家更好的学习go语言。
- 168次学习
-
- Golang进阶实战编程
- 本课程是在《Go语言基础视频》基础之上录制的,是Go语言基础的后半部分。包括包的管理,IO操作,Go语言最大的亮点:高并发,goroutine,channel,反射等。本视频主要为了帮助Go语言的初学者,从零到一的快速入门。学完本套课程,可以学会如果通过包管理Go项目,并发模型,以及并发实现,channel通道如何传递数据,反射等等。
- 129次学习

