我们都知道Go语言是原生支持语言级并发的,这个并发的最小逻辑单元就是goroutine。goroutine就是Go语言提供的一种用户态线程,当然这种用户态线程是跑在内核级线程之上的。当我们创建了很多的goroutine,并且它们都是跑在同一个内核线程之上的时候,就需要一个调度器来维护这些goroutine,确保所有的goroutine都使用cpu,并且是尽可能公平的使用cpu资源。 我要晨读
Go语言的官方package里面提供了"container/heap",在该package里面定义了Heap(堆)这一数据结构的使用接口。只要自定义的数据类型实现了标准接口,可以很方便的对自定义的数据类型在堆中进行排序了。 我要晨读
Docker 实战:将 Go语言 工程部署到 docker。本文一步步讲解 go语言实现的基本http服务部署到 docker ,并启动运行,讲解 dockerfile 文件的结构。 我要晨读
Go 终极指南:编写一个 Go 工具。我之前编写过一个叫 gomodifytags 的工具,它使我的生活变得很轻松。它会根据字段名称自动填充结构体标签字段。这是一篇非常长的博文,其解释了如何编写这样的工具以及每个构建细节。它包含许多独特的细节、技巧和未知的 Go 知识。拿起一杯咖啡☕️,让我们深入一下吧! 我要晨读
当我刚开始学习 Go 时,我正在玩不同的多路复用器(multiplexer),它可以作为 API 服务器使用。我发现了 3 个是非常有用的好东西,即 Gorilla mux、httprouter 和 bone(按性能从低到高排列)。即使 bone 有最佳性能和更简单的 handler 签名,但对于我来说,它仍然不够成熟,无法用于生产环境。因此,我最终使用了 httprouter。在本教程中,我将使用 httprouter 构建一个简单的 REST API 服务器。 我要晨读
在写《Go语言标准库》的第九章 —— 测试 时,看到了此文,讲解通俗易懂,于是翻译为中文,作为学习《Go语言标准库》的第九章的补充材料。如果你之前不知道 Go 中的单元测试,通过学习本文,你一定知道该怎么写了。 我要晨读
写 Go 的人往往对它的错误处理模式有一定的看法。按不同的语言经验,人们可能有不同的习惯处理方法。这就是为什么我决定要写这篇文章,尽管有点固执己见,但我认为听取我的经验是有用的。我想要讲的主要问题是,很难去强制执行良好的错误处理实践,错误经常没有堆栈追踪,并且错误处理本身太冗长。不过,我已经看到了一些潜在的解决方案,或许能帮助解决一些问题。 我要晨读
这篇文章想聊聊Go语言下的设计模式问题(包括 单例模式、工厂模式、装饰器模式),我觉得这个话题还是比较有意思的。Golang没有像java那样对设计模式疯狂的迷恋,而是摆出了一份“看庭前花开花落,望天空云卷云舒”的姿态。 我要晨读
尽管 Golang 推荐通过 channel 进行通信和同步,但在实际开发中 sync 包用得也非常的多。另外 sync 下还有一个 atomic 包,提供了一些底层的原子操作(这里不做介绍)。本篇文章主要介绍该包下的锁的一些概念及使用方法。 我要晨读
程序的性能优化无非就是对程序占用资源的优化。对于服务器而言,最重要的两项资源莫过于 CPU 和内存。性能优化,就是在对于不影响程序数据处理能力的情况下,我们通常要求程序的 CPU 的内存占用尽量低。反过来说,也就是当程序 CPU 和内存占用不变的情况下,尽量地提高程序的数据处理能力或者说是吞吐量。本文详细介绍 Go 程序的性能优化及 pprof 的使用。 我要晨读
这篇文章想聊聊如何给gc减负的问题,也即我们在写业务的时候,有时候需要考虑下gc老人家的感受,但又不能丧失代码的可读性,有些情况下代码需不需要优化,优化后能取得多大的性能提升,其中的平衡需要把握。 我要晨读
对于 Golang 开发者来说 context(上下文)包一定不会陌生。但很多时候,我们懒惰的只是见过它,或能起到什么作用,并不会去深究它。本文探究 context 的原理、使用示例。 我要晨读
字典是很重要的数据结构。map 在 Go 语言中使用的很频繁。本文介绍 map 的使用和内部实现,由浅入深,值得一读。 我要晨读
检查程序的执行路径和当前状态是非常有用的调试手段。核心文件(core file)包含了一个运行进程的内存转储和状态。它主要是用来作为事后调试程序用的。它也可以被用来查看一个运行中的程序的状态。这两个使用场景使调试文件转储成为一个非常好的诊断手段。我们可以用这个方法来做事后诊断和分析线上的服务(production services)。本文介绍调试 Go 语言的 Core Dumps。 我要晨读
剖析使Go语言高效的5个特性(5/5): Goroutine的栈管理。这是高效特性的最后一讲。这些特性个个都很有效,他们之间还相互依赖。比如,如果没有了可衍生的栈,运行环境将多个goroutine复用到线程上面就不会很有效。内联在把多个小函数合并成大函数的时候也避免了栈大小的检查开销。逃逸分析用栈代替堆来存储局部变量,这样也减少来垃圾回收机制的压力。逃逸分析还提升了缓存的性能(cache locality)。没有可衍生的栈,逃逸分析又会对栈造成很大的压力。 我要晨读
剖析使Go语言高效的5个特性(4/5): Goroutines。本文是 David 在 2014 年参加日本东京的 Gocon 会议的演讲的中文翻译。虽然时间有点久,但相信 David 大神的讲解,会让你收益颇多。Go语言有 goroutines。它们是Go语言里并发编程的基石。 我要晨读
剖析使Go语言高效的5个特性(3):垃圾回收机制。本文是 David 在 2014 年参加日本东京的 Gocon 会议的演讲的中文翻译。虽然时间有点久,但相信 David 大神的讲解,会让你收益颇多。本篇讲解垃圾回收机制。 我要晨读
剖析使Go语言高效的5个特性(2):函数调用不是免费的。本文是 David 在 2014 年参加日本东京的 Gocon 会议的演讲的中文翻译。虽然时间有点久,但相信 David 大神的讲解,会让你收益颇多。本篇讲解函数调用相关特性。 我要晨读
剖析使Go语言高效的5个特性(1):变量的处理和存储。本文是 David 在 2014 年参加日本东京的 Gocon 会议的演讲的中文翻译。虽然时间有点久,但相信 David 大神的讲解,会让你收益颇多。 我要晨读