1.consul启动
#consul agent -dev
# 为了在外部可访问,否则只能使用127.0.0.1:8500查看consul的管理页面
consul agent -dev -client 0.0.0.0
2.srv服务启动
go get -u github.com/golang/protobuf/{proto,protoc-gen-go}
go get -u github.com/micro/protoc-gen-micro
cd $GOPATH/src/micro/rpc/srv
protoc --proto_path=.:$GOPATH/src --go_out=. --micro_out=. proto/srv/srv.proto
go run main.go
目前go-micro已经更新到v2版本,此版本删除了对consul 的支持,但支持etcd、mdns作为服务发现,但是老版本的go-micro仍支持consul,但是有些地方做了调整。
使用Ctrl + c 进行退出
支持consul:
原生成的main.go文件为:
package main
import (
"github.com/micro/go-micro/util/log"
"github.com/micro/go-micro"
"micro/rpc/srv/handler"
"micro/rpc/srv/subscriber"
srv "micro/rpc/srv/proto/srv"
)
func main() {
// New Service
service := micro.NewService(
micro.Name("go.micro.srv.srv"),
micro.Version("latest"),
)
// Initialise service
service.Init()
// Register Handler
srv.RegisterSrvHandler(service.Server(), new(handler.Srv))
// Register Struct as Subscriber
micro.RegisterSubscriber("go.micro.srv.srv", service.Server(), new(subscriber.Srv))
// Register Function as Subscriber
micro.RegisterSubscriber("go.micro.srv.srv", service.Server(), subscriber.Handler)
// Run service
if err := service.Run(); err != nil {
log.Fatal(err)
}
}
修改main.go内容如下【中文注释部分即为修改部分】
package main
import (
"micro/rpc/srv/handler"
"micro/rpc/srv/subscriber"
"github.com/micro/go-micro"
"github.com/micro/go-micro/util/log"
srv "micro/rpc/srv/proto/srv"
"github.com/micro/go-micro/registry" // 添加注册插件
"github.com/micro/go-plugins/registry/consul" // 添加注册插件的consul支持
)
func main() {
// consul注册
consulReg := consul.NewRegistry(
registry.Addrs("127.0.0.1:8500"),
)
// New Service
service := micro.NewService(
micro.Name("go.micro.srv.srv"),
micro.Version("latest"),
micro.Registry(consulReg), // micro添加consul的注册
)
// Initialise service
service.Init()
// Register Handler
srv.RegisterSrvHandler(service.Server(), new(handler.Srv))
// Register Struct as Subscriber
micro.RegisterSubscriber("go.micro.srv.srv", service.Server(), new(subscriber.Srv))
// Register Function as Subscriber
micro.RegisterSubscriber("go.micro.srv.srv", service.Server(), subscriber.Handler)
// Run service
if err := service.Run(); err != nil {
log.Fatal(err)
}
}
重新run
go run main.go
consul的web页面:
go mod 如下:
module micro/rpc/srv
go 1.14
require (
github.com/golang/protobuf v1.4.0
github.com/micro/go-micro v1.18.0
github.com/micro/go-plugins v1.5.1 // indirect
google.golang.org/protobuf v1.21.0
)
3.web服务启动
cd $GOPATH/src/micro/rpc/web
go run main.go
这是由于micro使用了go mod 导致的问题,需要解决,提供三种解决方案:
涉及go mod 的问题:
- 方案1:关闭go mod ,全部重新导包,全部下载(不容易下载,不推荐)
- 方案2:将proto生成的go 文件目录提交到托管平台,github.com /gitlab.com 等等(没必要)
- 方案3:推荐:go mod 导入本地包【推荐】
4.web服务启动问题【go mod】
重点推荐go mod 导入本地包的方式
1.consul 以开发者模式启动
consul agent -dev
2.创建目录,剥离pb文件
mkdir -p $GOPATH/src/micro/rpc/pb
3.srv创建
micro new --type "srv" micro/rpc/srv
go get -u github.com/golang/protobuf/{proto,protoc-gen-go}
go get -u github.com/micro/protoc-gen-micro
4.进入proto 文件所在,进行编译
cd $GOPATH/src/micro/rpc/srv
protoc --proto_path=.:$GOPATH/src --go_out=$GOPATH/src/micro/rpc/pb --micro_out=$GOPATH/src/micro/rpc/pb proto/srv/srv.proto
5.另开一个终端找到 protob 生成的go 文件目录,并go mod init 初始化
tree $GOPATH/src/micro/rpc
cd $GOPATH/src/micro/rpc/pb/proto/srv && go mod init micro/rpc/pb/proto/srv && cd $GOPATH/src/micro/rpc/srv
6.查看$GOPATH/src/micro/rpc/srv/handler/srv.go中导入的包的位置:
srv "micro/rpc/srv/proto/srv"
7.查看$GOPATH/src/micro/rpc/srv/subscriber/srv.go中导入的包的位置:
srv "micro/rpc/srv/proto/srv"
8.查看$GOPATH/src/micro/rpc/srv/main.go中导入的包的位置:
srv "micro/rpc/srv/proto/srv"
9.修改$GOPATH/src/micro/rpc/srv/go.mod 追加【本地只能是相对路径】
require "micro/rpc/srv/proto/srv" v0.0.0
replace "micro/rpc/srv/proto/srv" => "../pb/proto/srv"
10.修改consul启动,$GOPATH/src/micro/rpc/srv/main.go
package main
import (
"micro/rpc/srv/handler"
"micro/rpc/srv/subscriber"
"github.com/micro/go-micro"
"github.com/micro/go-micro/util/log"
srv "micro/rpc/srv/proto/srv"
"github.com/micro/go-micro/registry" // 添加注册插件
"github.com/micro/go-plugins/registry/consul" // 添加注册插件的consul支持
)
func main() {
// consul注册
consulReg := consul.NewRegistry(
registry.Addrs("127.0.0.1:8500"),
)
// New Service
service := micro.NewService(
micro.Name("go.micro.srv.srv"),
micro.Version("latest"),
micro.Registry(consulReg), // micro添加consul的注册
)
// Initialise service
service.Init()
// Register Handler
srv.RegisterSrvHandler(service.Server(), new(handler.Srv))
// Register Struct as Subscriber
micro.RegisterSubscriber("go.micro.srv.srv", service.Server(), new(subscriber.Srv))
// Register Function as Subscriber
micro.RegisterSubscriber("go.micro.srv.srv", service.Server(), subscriber.Handler)
// Run service
if err := service.Run(); err != nil {
log.Fatal(err)
}
}
11.go run main
cd $GOPATH/src/micro/rpc/srv
go run main.go
12.web 创建
cd $GOPATH/src
micro new --type "web" micro/rpc/web
13.修改$GOPATH/src/micro/rpc/web/go.mod 追加【本地只能是相对路径】
require "micro/rpc/srv/proto/web" v0.0.0
replace "micro/rpc/srv/proto/web" => "../pb/proto/srv"
14.进入web项目修改$GOPATH/src/micro/rpc/web/handler/handler.go的导包
// web "path/to/service/proto/web"
web "micro/rpc/srv/proto/web"
15.进入web项目修改$GOPATH/src/micro/rpc/web/handler/handler.go的webclient的创建
// webClient := web.NewWebService("go.micro.srv.web", client.DefaultClient)
webClient := web.NewSrvService("go.micro.srv.srv", client.DefaultClient)
16.修改consul启动,web端口固定,$GOPATH/src/micro/rpc/web/main.go
package main
import (
"net/http"
"github.com/micro/go-micro/util/log"
"micro/rpc/web/handler"
"github.com/micro/go-micro/registry" // 添加注册插件
"github.com/micro/go-micro/web"
"github.com/micro/go-plugins/registry/consul" // 添加注册插件的consul支持
)
func main() {
// consul注册
consulReg := consul.NewRegistry(
registry.Addrs("127.0.0.1:8500"),
)
// create new web service
service := web.NewService(
web.Name("go.micro.web.web"),
web.Version("latest"),
web.Registry(consulReg), // web添加consul的注册
web.Address(":8080"), // 固定web访问端口号
)
// initialise service
if err := service.Init(); err != nil {
log.Fatal(err)
}
// register html handler
service.Handle("/", http.FileServer(http.Dir("html")))
// register call handler
service.HandleFunc("/web/call", handler.WebCall)
// run service
if err := service.Run(); err != nil {
log.Fatal(err)
}
}
17.go run main
cd $GOPATH/src/micro/rpc/web
go run main.go
18.consul 的web 页面查看
http://127.0.0.1:8500
19.web服务访问
http://127.0.0.1:8080