微服务是一种架构理念而不是具体的框架项目,许多编程语言都可以实现,但有的语言对微服务开发具备天生的优势,Golang 便是其中之一。 (推荐学习:go)

Golang 本身十分轻量级,运行效率极高,同时对并发编程有着原生的支持,从而能更好的利用多核处理器。内置 net 标准库对网络开发的支持也十分完善。

此外,Golang 社区有一个很棒的开源微服务框架 go-mirco。

go-micro是go语言下的一个很好的rpc微服务框架,功能很完善。

Go Micro是一个插件化的基础框架,基于此可以构建微服务。Micro的设计哲学是『可插拔』的插件化架构。在架构之外,它默认实现了consul作为服务发现,通过http进行通信,通过protobuf和json进行编解码。我们一步步深入下去。

Go Micro是:

一个用Golang编写的包

一系列插件化的接口定义

基于RPc

Go Micro为下面的模块定义了接口:

服务发现

编解码

服务端、客户端

订阅、发布消息