内容简介:面板地址:http://127.0.0.1:8500
服务编写
1.定义proto文件
//示例为elc日志
syntax = "proto3";
//service name is kibana
service Kibana {
//service method is write
rpc Write(WriteRequest) returns (WriteResponse) {}
}
//writer request struct
message WriteRequest {
string tag = 1;
string info = 2;
string level = 3;
}
//writer response struct
message WriteResponse {
int32 code = 1;
string message = 2;
map<string, string> data = 3;
}
2.将定义的proto编译为 go 文件
protoc --proto_path=.:. --micro_out=. --go_out=. kibana.proto
3.编写服务
package main
import (
proto "micro-srv/service/kibana/proto"
"micro-srv/service/kibana/logics"
"fmt"
"micro-srv/common"
"golang.org/x/net/context"
)
//定义服务
type Kibana struct{}
const (
//服务监听端口
SRV_PORT = 50061
//服务名称
SRV_NAME = "kibana"
)
//服务中的方法必须要全都实现
func (k *Kibana) Write(ctx context.Context, req *proto.WriteRequest) (rsp *proto.WriteResponse, err error) {
rsp.Code = 0
rsp.Message = "success"
rsp.Data = map[string]string{"tag":req.Tag,"info":req.Info,"level":req.Level}
err = logics.WriteLog(req.Tag, req.Info, req.Level)
return rsp, err
}
func main() {
//将服务注册到consul
server, listener, err := common.Register(SRV_NAME, SRV_PORT)
if err != nil {
fmt.Println(err.Error())
}
proto.RegisterKibanaServer(server, &Kibana{})
err = server.Serve(listener)
if err != nil {
fmt.Println(err.Error())
}
}
微服务运行 (本地环境示例)
启动consul
consul agent -dev &
面板地址:http://127.0.0.1:8500
启动并注册服务
cd kibana && go run main.go &
可以看到我们服务以及运行起来了 接下来我们在consul面板看看
源码: go-grpc-getway
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
系统分析与设计方法
惠滕 / 孙慧、肖刚 / 机械工业出版社 / 2004-9 / 69.00元
本书是介绍信息系统分析和设计原理、方法、技术、工具和应用的力作,自问世以来,广受欢迎,以至于一版再版,延续至今。 本书采用一个完整的案例研究,以整个信息系统构件(基于Zachman框架)和信息系统开发生命周期(FAST方法学)为主线,详细探讨了系统开发生命周期的前期、中期和后期以及跨生命周期的活动。另外,书中第一章都提供了大量的练习题、讨论题、研究题和小型案例,以加深读者对书中所述理论的实际应用和......一起来看看 《系统分析与设计方法》 这本书的介绍吧!