熟读这5个开源项目就是合格的GO语言工程师!

岳永 · · 2601 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

写代码同写文章一样,既是技术活,又是艺术活。不是懂了语法能够写出优秀的代码,也正如不是认识字就能够写出优美的文章一样。那个作家饱读史书,那个架构师不是在代码堆里和Bug堆里泡出来的。

因此,程序员刚入门除了读书外,阅读好的代码很重要。阅读优秀的代码可以了解大牛开发的思路,软件架构和语言技巧等。因此,本文针对Go语言,推荐大家5个非常优秀的开源项目,这些开源项目不仅应用广泛,而且其中所用的技术有很多基础技术,是做其它任何项目都不可或缺的。

image

Codis

Codis是一个分布式Redis解决方案,与官方的纯P2P模式不同,Codis采用的是Proxy-based的方案。可以将Codis理解成为Web服务领域的Nginx,它实现了对Redis的反向代理和负载均衡。Redis本身就是就是一个高性能的缓存系统,可见Codis的性能更是没法说。

image

推荐阅读该开源项目源代码的原因在于应用广泛、高性能和网络协议。通过学习其代码相信对Go语言的如下方面能有很大的提升:

网络编程: Codis本身就是一个高性能网络软件,因此阅读其代码对于Go语言下的网络编程会有很大的帮助

协程: 作为网络软件,在Go语言协程使用上发挥的淋漓尽致,充分使用了其协程的特性
数据结构与算法: Codis为了配合Redis的多种数据类型支持,在内部实现上充分使用了现有的数据结构

Etcd

Etcd是CoreOS团队于2013年6月发起的开源项目,它的目标是构建一个高可用的分布式键值(key-value)数据库。Etcd内部采用raft协议作为一致性算法,etcd基于Go语言实现。阅读其代码对理解Go语言中的网络编程、分布式算法和数据结构等方面的内容有非常大的帮助。可以了解世界级大牛的开发思路和编码风格。

image

Kubernetes

相信做过Web开发或者玩过容器的同学都接触过,最起码听过这个软件。这个软件是纯Go语言开发。这里就不过多介绍了,Google设计并开发的东东,相信能从中学到很多内容。这里就不过多介绍了。

Caddy

Caddy服务器(或者CaddyWeb)是一个开源的,使用Golang 编写,支持HTTP/2 的Web 服务端。 它使用Golang 标准库提供HTTP 功能。 Caddy 一个显著的特性是默认启用HTTPS。 它是第一个无需额外配置即可提供HTTPS 特性的Web 服务器。学习该软件的代码对高性能架构、网络编程和HTTP协议会有更加深入的理解。

image

Go-MySQL

程序开发无非业务、数据结构算法、网络和存储,前面介绍了很多数据结构和网络的开源软件,本软件是最后一部分。本软件是Go语言实现的处理MySQL网络协议和复制的功能,可以作为MySQL的从端,实现数据的进一步的处理。学习本软件的代码对MySQL会有更加深入的理解,另外对数据中心容灾也会有所帮助。

image

有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:岳永

查看原文:熟读这5个开源项目就是合格的GO语言工程师!

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

2601 次点击  
加入收藏 微博
被以下专栏收入,发现更多相似内容
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传