Golang 微服务框架 - 2. Micro 安装 & 运行示例

Micro 介绍

官方网站: micro.mu
官方文档: micro.mu/docs
源码仓库: github.com/micro/micro

Micro 是一个工具集合, 通过将微服务架构抽象成一组工具。隐藏了分布式系统的复杂性,为开发人员提供了更简洁的概念。

依赖关系

通常 micro 会依赖两个项目

  1. consul - 服务发现
  2. protoc-gen-micro - 代码生成

consul 安装运行:

source:
    go get -u -v github.com/hashicorp/consul && consul agent -dev
docker:
    docker run consul

protoc-gen-micro 安装:

go get -u -v github.com/micro/protoc-gen-micro

开发环境

  • 开发微服务的框架:
go get -u -v github.com/micro/go-micro
  • 管理工具:
source:
    go get -u -v github.com/micro/micro
docker:
    docker pull microhq/micro

运行示例

  • 获取示例源码:
go get -u -v github.com/micro/examples
  • 运行 greeter 示例服务:
    –registry_address=127.0.0.1:8500 用来指定服务发现的地址, 就是上面的 consul 的地址, consul 默认端口是 8500
go get github.com/micro/examples/greeter/srv && srv --registry_address=127.0.0.1:8500
  • 通过命令行验证:

获取服务列表

–registry_address=127.0.0.1:8500 用来指定服务发现的地址, 就是上面的 consul 的地址, consul 默认端口是 8500

$ micro --registry_address=127.0.0.1:8500 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"
}

你可能感兴趣的:(micro,golang,微服务)