dubbogo-1 基础rpc服务

文章目录

基本环境处理

https://cn.dubbo.apache.org/zh-cn/overview/quickstart/go/install/

这里没有 protoc-gen-go --version

执行

bash 复制代码
 go get -u github.com/golang/protobuf/protoc-gen-go

进入到这个目录执行

bash 复制代码
go build
bash 复制代码
go install

这样就会出现在 go/bin 目录里面了,如果已经增加了这个环境变量了,就可以使用该命令了

分别验证

bash 复制代码
protoc --version

libprotoc 22.2

bash 复制代码
protoc-gen-go-triple --version

protoc-gen-go-triple 1.0.8

bash 复制代码
protoc-gen-go --version

protoc-gen-go: unknown argument "--version" (this program should be run by protoc, not directly)

这个错误先不管。

编译pb接口

bash 复制代码
protoc --go_out=. --go-triple_out=. ./samples_api.proto
  • --go_out=. 用到protoc-gen-go插件,生成文件到当前目录
  • --go-triple_out=. 使用 protoc-gen-go-triple插件,生成文件到当前目录

当然默认的样例工程其实已经包含了编译好的文件

开启rpc调用

回到项目根目录

bash 复制代码
go mod tidy

分别启动server端和client端

bash 复制代码
cd go-server/cmd
bash 复制代码
go run .
bash 复制代码
cd go-client/cmd
bash 复制代码
go run .

服务端效果

客户端效果

业务观察

这个的提供的样例模块

protoc的定义是

protoc 复制代码
message HelloRequest {
  string name = 1;
}

翻译出来的go代码对应核心的地方就是这里

client代码增加注释

go 复制代码
package main

import (
	"context"
)

import (
	"dubbo.apache.org/dubbo-go/v3/common/logger"
	"dubbo.apache.org/dubbo-go/v3/config"
	_ "dubbo.apache.org/dubbo-go/v3/imports"

	"helloworld/api"
)

// 创建一个grpc的实例
var grpcGreeterImpl = new(api.GreeterClientImpl)

// export DUBBO_GO_CONFIG_PATH= PATH_TO_SAMPLES/helloworld/go-client/conf/dubbogo.yaml
func main() {
	config.SetConsumerService(grpcGreeterImpl)
	if err := config.Load(); err != nil {
		panic(err)
	}

	logger.Info("start to test dubbo")
	// 传递参数
	req := &api.HelloRequest{
		Name: "laurence",
	}
	// grpc的调用
	reply, err := grpcGreeterImpl.SayHello(context.Background(), req)
	if err != nil {
		logger.Error(err)
	}
	logger.Infof("client response result: %v\n", reply) // reply是具体响应的信息
}

qa1 能取出protoc里面的字段值吗?

可以直接用reply.xxx 取值

go 复制代码
package main

import (
	"context"
)

import (
	"dubbo.apache.org/dubbo-go/v3/common/logger"
	"dubbo.apache.org/dubbo-go/v3/config"
	_ "dubbo.apache.org/dubbo-go/v3/imports"

	"helloworld/api"
)

// 创建一个grpc的实例
var grpcGreeterImpl = new(api.GreeterClientImpl)

// export DUBBO_GO_CONFIG_PATH= PATH_TO_SAMPLES/helloworld/go-client/conf/dubbogo.yaml
func main() {
	config.SetConsumerService(grpcGreeterImpl)
	if err := config.Load(); err != nil {
		panic(err)
	}

	logger.Info("start to test dubbo")
	// 传递参数
	req := &api.HelloRequest{
		Name: "laurence",
	}
	// grpc的调用
	reply, err := grpcGreeterImpl.SayHello(context.Background(), req)
	if err != nil {
		logger.Error(err)
	}
	logger.Infof("client response result: %v\n", reply) // reply是具体响应的信息
	logger.Infof("Name is %v \n", reply.Name)
	logger.Infof("Age is %v \n", reply.Age)
	logger.Infof("Id is %v \n", reply.Id)
}
相关推荐
weixin_604236676 小时前
华三 路由器 极简核心配置
运维·服务器·网络·h3c·h3c路由器
换个昵称都难10 小时前
webrtc 音频模块FEC模块
网络·音视频·webrtc
youngerwang10 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
zjun100111 小时前
TCP专栏-4.四次挥手
网络协议·tcp/ip
智慧光迅AINOPOL13 小时前
校园在线巡课系统方案:督导全覆盖
网络·全光网解决方案·全光网·校园全光网·校园全光网解决方案
酉鬼女又兒13 小时前
零基础入门计算机网络:网络层核心任务、三大关键问题、两种服务类型与 TCP/IP 网际层协议体系全解析
服务器·网络·网络协议·tcp/ip·计算机网络·php·求职招聘
Urbano13 小时前
工装制作全流程科普:从面料到自动化生产
网络·人工智能
2401_8685347814 小时前
网规笔记 | 真题解析:2018年11月软考网规-网络安全案例分析
网络
Gauss松鼠会14 小时前
【GaussDB】GaussDB重要通信参数汇总
服务器·网络·数据库·sql·性能优化·gaussdb·经验总结
超级无敌zhq14 小时前
后渗透痕迹清理:攻防对抗中的隐身术
网络·数据库·网络安全