go使用trpc案例

2024-02-24 09:52
文章标签 go 使用 案例 trpc

本文主要是介绍go使用trpc案例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.go下载trpc

go install trpc.group/trpc-go/trpc-cmdline/trpc@latest

有报错的话尝试配置一些代理(选一个)

go env -w GOPROXY=https://goproxy.cn,direct
go env -w GOPROXY=https://goproxy.io,direct
go env -w GOPROXY=https://goproxy.baidu.com/ 
go env -w GOPROXY=https://mirrors.aliyun.com/goproxy/
cmd运行trpc version#打印版本号就是成功了
trpc-group/trpc-cmdline version: v1.0.5

2.下载protoc

下载地址:Release Protocol Buffers v25.3 · protocolbuffers/protobuf · GitHub

 把protoc加入环境变量

不会加环境变量的自己百度。我都懒得写

cmd查看版本:

protoc --version


3.编写一个proto文件

syntax = "proto3";  /
option go_package="./;baomin1";package baomin;service Helloserver {rpc SayHello (HelloRequest) returns (HelloReply) {}
}message HelloRequest {string name = 1;
}message HelloReply {string message = 1;
}

然后执行

trpc create -p trpcDemo.proto -o out
// -o 指定文件存放目录,proto文件中,option go_package="./;baomin1"; 已经指定了文件的存放目录,如果使用-o 指定为out,会覆盖./目录。out目录会自动创建

 生成out文件,内容如下:

  3.1 proto文件解释

syntax  用于制定protoc的版本,proto2或proto3,新版本proto3中必填。

option go_package = "path;name";
        path 表示生成的go文件的存放地址,会自动生成目录的。
        name 表示生成的go文件所属的包名。


package baomin; 指定文件包名,优先级会高于上面的name,所以报名会是baomin,不是baomin1。

message: protobuf中定义一个消息类型式是通过关键字 message字段指定的。消息就是需要传输的数据格式的定义message关键字 类似于C++中的class,JAVA中的class,go中的struct。

        字段规则

                

        required: 消息体中必填字段,不设置会导致编码异常。

                        在protobuf2中使用,在protobuf3中被删去

        optional : 消息体中可选字段。protobuf3没有了required,

                       optional等说明关键字,都默认为optional

        repeate: 消息体中可重复字段,重复的值的顺序会被保留在go中

                     重复的会被定义为切片。

          消息号  :    

                   在消息体的定义中,每个字段都必须要有一个唯一的标识号

                   标识号是[1,2^29-1]  范国内的一个整数     

                

                必须是正整数(1 到 2^29-1)。

                标签不能重复出现在同一个消息中。

                标签的顺序可以是任意的。不需要连续,可以跳过一些数值。

  

        嵌套消息 :可以在其他消息类型中定义、使用消息类型,

                        在下面的例子中,person消息就定义在Personlnfo消息内如

        

message PersonInfo{message Person{string name = 1;int32 height =2;repeated int32 weight = 3;}repeated Person info = 1;
}

如果要在它的父消息类型的外部重用这个消息类型,需要Personlnfo.Person的形式使用它,如:

message PersonMessage{PersonInfo.Person info = 1;
}

服务定义:

        

service $earchService{
# rpc 服务函数名 (参》返回(返回参)rpc Search(SearchRequest) returns (SearchResponse)
}

上面的proto文件是主要是给你解释用的,一般不建议代码存放用./当前位子,容易出错

改成下面

syntax = "proto3";
option go_package="tengxun/trpc/code";package baomin;service Helloserver {rpc SayHello (HelloRequest) returns (HelloReply) {}
}message HelloRequest {string name = 1;
}message HelloReply {string message = 1;
}

删除生成的out文件

再次执行

trpc create -p trpcDemo.proto -o out

服务端代码修改一下

out/main.go

package mainimport ("context""fmt"pb "tengxun/trpc/code"_ "trpc.group/trpc-go/trpc-filter/debuglog"_ "trpc.group/trpc-go/trpc-filter/recovery"trpc "trpc.group/trpc-go/trpc-go""trpc.group/trpc-go/trpc-go/log"
)type helloserver struct {pb.UnimplementedHelloserver
}func (s *helloserver) SayHello(ctx context.Context, req *pb.HelloRequest) (*pb.HelloReply, error) {fmt.Println("hello " + req.Name)return &pb.HelloReply{Message: "SayHello::::::::::: " + req.Name}, nil
}func main() {s := trpc.NewServer()pb.RegisterHelloserverService(s.Service("baomin.Helloserver"), &helloserver{})if err := s.Serve(); err != nil {log.Fatal(err)}
}

cd out

运行服务端 go run main.go

运行客户端  go run cmd/client/main.go

客户端截图

 服务端截图

这篇关于go使用trpc案例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/741724

相关文章

PyTorch核心方法之state_dict()、parameters()参数打印与应用案例

《PyTorch核心方法之state_dict()、parameters()参数打印与应用案例》PyTorch是一个流行的开源深度学习框架,提供了灵活且高效的方式来训练和部署神经网络,这篇文章主要介绍... 目录前言模型案例A. state_dict()方法验证B. parameters()C. 模型结构冻

Java中的ConcurrentBitSet使用小结

《Java中的ConcurrentBitSet使用小结》本文主要介绍了Java中的ConcurrentBitSet使用小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、核心澄清:Java标准库无内置ConcurrentBitSet二、推荐方案:Eclipse

Go语言结构体标签(Tag)的使用小结

《Go语言结构体标签(Tag)的使用小结》结构体标签Tag是Go语言中附加在结构体字段后的元数据字符串,用于提供额外的属性信息,这些信息可以通过反射在运行时读取和解析,下面就来详细的介绍一下Tag的使... 目录什么是结构体标签?基本语法常见的标签用途1.jsON 序列化/反序列化(最常用)2.数据库操作(

Java中ScopeValue的使用小结

《Java中ScopeValue的使用小结》Java21引入的ScopedValue是一种作用域内共享不可变数据的预览API,本文就来详细介绍一下Java中ScopeValue的使用小结,感兴趣的可以... 目录一、Java ScopedValue(作用域值)详解1. 定义与背景2. 核心特性3. 使用方法

spring中Interceptor的使用小结

《spring中Interceptor的使用小结》SpringInterceptor是SpringMVC提供的一种机制,用于在请求处理的不同阶段插入自定义逻辑,通过实现HandlerIntercept... 目录一、Interceptor 的核心概念二、Interceptor 的创建与配置三、拦截器的执行顺

C#中checked关键字的使用小结

《C#中checked关键字的使用小结》本文主要介绍了C#中checked关键字的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录✅ 为什么需要checked? 问题:整数溢出是“静默China编程”的(默认)checked的三种用

C#中预处理器指令的使用小结

《C#中预处理器指令的使用小结》本文主要介绍了C#中预处理器指令的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 第 1 名:#if/#else/#elif/#endif✅用途:条件编译(绝对最常用!) 典型场景: 示例

mysql_mcp_server部署及应用实践案例

《mysql_mcp_server部署及应用实践案例》文章介绍了在CentOS7.5环境下部署MySQL_mcp_server的步骤,包括服务安装、配置和启动,还提供了一个基于Dify工作流的应用案例... 目录mysql_mcp_server部署及应用案例1. 服务安装1.1. 下载源码1.2. 创建独立

Mysql中RelayLog中继日志的使用

《Mysql中RelayLog中继日志的使用》MySQLRelayLog中继日志是主从复制架构中的核心组件,负责将从主库获取的Binlog事件暂存并应用到从库,本文就来详细的介绍一下RelayLog中... 目录一、什么是 Relay Log(中继日志)二、Relay Log 的工作流程三、Relay Lo

使用Redis实现会话管理的示例代码

《使用Redis实现会话管理的示例代码》文章介绍了如何使用Redis实现会话管理,包括会话的创建、读取、更新和删除操作,通过设置会话超时时间并重置,可以确保会话在用户持续活动期间不会过期,此外,展示了... 目录1. 会话管理的基本概念2. 使用Redis实现会话管理2.1 引入依赖2.2 会话管理基本操作