微服务是一种架构理念而不是具体的框架项目,许多编程语言都可以实现,但有的语言对微服务开发具备天生的优势,Golang 便是其中之一。
Golang 本身十分轻量级,运行效率极高,同时对并发编程有着原生的支持,从而能更好的利用多核处理器。内置 net 标准库对网络开发的支持也十分完善。
此外,Golang 社区有一个很棒的开源微服务框架 go-mirco。
go-micro是go语言下的一个很好的rpc微服务框架,功能很完善。
Go Micro是一个插件化的基础框架,基于此可以构建微服务。Micro的设计哲学是『可插拔』的插件化架构。在架构之外,它默认实现了consul作为服务发现,通过http进行通信,通过protobuf和json进行编解码。我们一步步深入下去。
Go Micro是:
一个用Golang编写的包
一系列插件化的接口定义
基于RPc
Go Micro为下面的模块定义了接口:
服务发现
编解码
服务端、客户端
订阅、发布消息