1. 安装指南

1.1. 依赖

我们需要服务发现,所以让我们启动Consul(默认),或者通过go-plugins替换。

1.1.1. Consul

brew install consul
consul agent -dev

或者

docker run consul

1.1.2. Multicast DNS

我们可以使用Multicast DNS进行零依赖的服务发现

--registry=mdns传递给任何命令,例如micro --registry = mdns list services

1.2. Go Micro

Go Micro是Go开发微服务的RPC框架

1.2.1. 安装

go get github.com/micro/go-micro

1.2.2. Protobuf

如果您使用代码生成,您还需要使用protoc-gen-go

go get github.com/micro/protobuf/{proto,protoc-gen-go}

访问github.com/micro/go-micro了解更多。

1.3. 工具包

Micro工具包提供了访问微服务的各种方法

1.3.1. 安装

go get github.com/micro/micro

1.3.2. Docker

可用预制docker images

docker pull microhq/micro

1.3.3. 尝试CLI

运行greeter服务

go get github.com/micro/examples/greeter/srv && srv

服务清单

$ micro list services
consul
go.micro.srv.greeter

获取服务

$ micro get service go.micro.srv.greeter
service  go.micro.srv.greeter

version 1.0.0

Id    Address    Port    Metadata
go.micro.srv.greeter-34c55534-368b-11e6-b732-68a86d0d36b6    192.168.1.66    62525    server=rpc,registry=consul,transport=http,broker=http

Endpoint: Say.Hello
Metadata: stream=false

Request: {
    name string
}

Response: {
    msg string
}

查询服务

$ micro query go.micro.srv.greeter Say.Hello '{"name": "John"}'
{
    "msg": "Hello John"
}

results matching ""

    No results matching ""