当前位置: 首页 > news >正文

基于go-zero的rpc服务示例

以下是一个基于 go-zero 框架的简单 RPC 服务示例,该示例包括一个服务端和一个客户端通过 gRPC 进行通信。

服务端

1、定义 .proto 文件

在 rpc/add 目录下创建 adder.proto 文件,定义 RPC 服务:

syntax = "proto3";package adder;service Adder {rpc Add(AddRequest) returns (AddResponse) {}
}message AddRequest {int32 a = 1;int32 b = 2;
}message AddResponse {int32 result = 1;
}

2、生成代码

使用 protoc 工具生成 Go 代码:

protoc --go_out=plugins=grpc:. adder.proto

3、实现服务

创建 adder_grpc.go 文件,实现 Adder 服务:

package adderimport ("context"
)type AdderServer struct{}func (s *AdderServer) Add(ctx context.Context, req *AddRequest) (*AddResponse, error) {result := req.GetA() + req.GetB()return &AddResponse{Result: result}, nil
}

4、启动服务

创建 server.go 文件,启动 gRPC 服务:

package mainimport ("flag""fmt""net""github.com/zeromicro/go-zero/core/conf""github.com/zeromicro/go-zero/core/logx""github.com/zeromicro/go-zero/zrpc""github.com/your/path/to/rpc/add"
)var configFile = flag.String("f", "etc/config.yaml", "the config file")func main() {flag.Parse()var c zrpc.RpcServerConfconf.MustLoad(*configFile, &c)server := zrpc.MustNewServer(c)defer server.Stop()adderServer := &add.AdderServer{}add.RegisterAdderServer(server.Server, adderServer)fmt.Printf("Starting rpc server on %s...\n", c.ListenOn)server.Start()
}

5、配置文件

在 etc 目录下创建 config.yaml 文件,配置服务地址和端口:

Name: adder
ListenOn: 127.0.0.1:8080

6、启动服务端

运行 server.go 文件,启动 RPC 服务:

go run server.go

客户端

1、创建客户端

创建 client.go 文件,创建 gRPC 客户端:

package mainimport ("context""fmt""time""github.com/zeromicro/go-zero/zrpc""github.com/your/path/to/rpc/add"
)func main() {client := zrpc.MustNewClient("127.0.0.1:8080")defer client.Conn.Close()adderClient := add.NewAdderClient(client.Conn)ctx, cancel := context.WithTimeout(context.Background(), time.Second)defer cancel()req := &add.AddRequest{A: 5,B: 7,}resp, err := adderClient.Add(ctx, req)if err != nil {fmt.Println("Error:", err)} else {fmt.Println("Result:", resp.GetResult())}
}

2、运行客户端

运行 client.go 文件,调用 RPC 服务:

go run client.go

输出结果:

Result: 12

至此,一个基于 go-zero 框架的简单 RPC 服务示例完成。

相关文章:

基于go-zero的rpc服务示例

以下是一个基于 go-zero 框架的简单 RPC 服务示例,该示例包括一个服务端和一个客户端通过 gRPC 进行通信。 服务端 1、定义 .proto 文件 在 rpc/add 目录下创建 adder.proto 文件,定义 RPC 服务: syntax "proto3";package add…...

【算法】奇偶游戏(带权并查集)

题目 小 A 和小 B 在玩一个游戏。 首先,小 A 写了一个由 0 和 1 组成的序列 S,长度为 N。 然后,小 B 向小 A 提出了 M 个问题。 在每个问题中,小 B 指定两个数 l 和 r,小 A 回答 S[l∼r] 中有奇数个 1 还是偶数个 …...

补充:linux rsyslog配置多端口监听(基于UDP)

rsyslog默认udp监听端口为514,我们可以配置rsyslog基于udp的多端口监听,实现监控的丰富性 1.环境信息 环境信息 HostnameIpAddressOS versionModuleNotersyslog1192.168.10.246Red Hat Enterprise Linux Server release 7.7 (Maipo)rsyslogd 8.24.0-38.el7linux基础配置 Li…...

详解StringBuilder和StringBuffer(区别,使用方法,含源码讲解)

目录 一.为什么要使用StringBuilder和StringBuffer 字符串的不可变性 性能损耗 二.StringBuilder和StringBuffer StringBuffer源码讲解 使用方式 三.常用方法总结 示例: 四.StringBuilder和StringBuffer的区别 一.为什么要使用StringBuilder和StringBuffe…...

九、sdl显示bmp图片

前言 SDL中内置加载BMP的API,使用起来会更加简单,便于初学者学习使用SDL 如果需要加载JPG、PNG等其他格式的图片,可以使用第三方库:SDL_image 测试环境: ffmpeg的4.3.2自行编译版本windows环境qt5.12sdl2.0.22&…...

ROS设置DHCP option121

配置时,了解格式很关键,16进制填写格式如下: 将要访问的IPV4地址:192.168.100.0/24 192.168.30.254 转换为:掩码 目标网段 网关 0x18c0a864c0a81efe,0不用填写 ROS配置如下图: 抓…...

④【Set】Redis常用数据类型: Set [使用手册]

个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~ 个人主页:.29.的博客 学习社区:进去逛一逛~ Redis Set ④Redis Set 操作命令汇总1. sadd …...

助力企业前行——ScalaSpark最佳实践课程

时间飞逝,转眼间我们的Scala&Spark培训课程已经圆满结束!在这段精彩的学习旅程中,你们展现了坚韧、决心和追求卓越的品质。 scala(Scalable Language)是一种多范式的编程语言,其设计的初衷是要集成面向对象编程和函数式编程的…...

pikachu靶场Table pikachu.member doesn’t exist:解决

背景: 第一次搭建pikachu靶场,搭建好后访问index.php后,尝试练习,发现界面显示Table pikachu.member doesn t exist,后来找了很多教程,没有解决,后来发现是自己没有进行初始化,给大家…...

Github Copilot AI编码完成工具

目录 一、GitHub Copilot 1、简介 2、工作原理 3、功能 二、GitHub Copilot X 1、什么是 GitHub Copilot X 2、GitHub Copilot X 的功能 三、支持、使用 1、支持 2、使用 四、实际研究、验证(代码方向) 1、代码生成 2、代码提示 3、生成测试用例 4、代码解释 5…...

android 9 adb安装过程学习(二)

一、PackageInstalllerService流程分析 下面来分析下 PackageInstallerService 中的逻辑,我们先来看看 PackageInstallerService 的创建,当然,这部分的逻辑是在开机的时候,这里我们再回顾下: 位置:./frame…...

Java面试-框架篇-Mybatis

Java面试-框架篇-Mybatis MyBatis执行流程延迟加载使用及原理一, 二级缓存来源 MyBatis执行流程 读取MyBatis配置文件: mybatis-config.xml加载运行环境和映射文件构造会话工厂SqlSessionFactory会话工厂创建SqlSession对象(包含了执行SQL语句的所有方法)操作数据库的接口, Ex…...

java基础-集合

1、集合 在java中,集合(Collection)指的是一组数据容器,它可以存储多个对象,并且允许用户通过一些方法来访问与操作这些对象。j 集合的实现原理都基于数据结构和算法,如下: 数据结构&#xff1…...

【C++11】auto与decltype关键字使用详解

系列文章目录 C11新特性使用详解-持续更新 文章目录 系列文章目录前言一、auto关键字1.根据变量的初始化表达式来推导变量的类型2.const与引用 二、decltype关键字1.推断表达式的类型2.const与引用 三、总结 前言 auto和decltype是C11引入的俩个重要的新关键字,用…...

Servlet实现一个简单的表白墙网站

文章目录 前言效果展示事前准备HTML、CSS、JavaScript分别负责哪些HTML和CSS构架出页面的基本结构和样式JavaScript 实现行为和交互实现服务器端的业务代码整理pom.xmlweb.xmlmessageWall.htmlMessageServlet.java 前言 前面我们学习了 Java 中知名的 HTTP 服务器 tomcat 的安…...

mysql 集群恢复

准备使用集群的时候发现集群起不来, 发现抱错集群各个节点都是readonly 状态,找了很多资料,由于集群处于不一致的情况需要防止不同的节点数据写入脏数据 取消节点readonly 方法如下: MySQL 取消 super read only 直接关闭read…...

基于STM32的色彩识别与分类算法优化

基于STM32的色彩识别与分类算法优化是一项与图像处理和机器学习相关的研究任务,旨在实现高效的色彩识别和分类算法在STM32微控制器上的运行。本文将介绍基于STM32的色彩识别与分类算法优化的原理和实现步骤,并提供相应的代码示例。 1. 色彩识别与分类概…...

阿里云发送短信

官方代码如下: // This file is auto-generated, dont edit it. Thanks. package com.aliyun.sample;import com.aliyun.tea.*;public class Sample {/*** 使用AK&SK初始化账号Client* param accessKeyId* param accessKeySecret* return Client* throws Excep…...

关于用css设置input输入框hover的时候的样式以及当input为disabled的时候,不要让hover样式生效

效果如果&#xff1a; 编辑状态下的时候&#xff1a; 只读状态下的时候&#xff1a; 代码如图&#xff1a; <input type"text" name"dataForm.exportCode" id"exportCodeItem" required :disabled"editDisabled" />input:not(…...

hadoop在本地创建文件,然后将文件拷贝/上传到HDFS

1.要$cd {对应目录}进入到对应目录&#xff0c;一般为 cd /usr/local/hadoop/ 2.创建文件&#xff0c;$sudo gedit {文件名}&#xff0c;例 sudo gedit test.txt 然后在弹出的txt文件输入内容&#xff0c;点击右上角的保存之后&#xff0c;关闭即可。 3.拷贝本地文件到HDF…...

Laravel Octane + AI Streaming响应中断率高达37%?——Swoole协程下LLM流式输出的内存泄漏根因分析(Valgrind+Xdebug双轨追踪报告)

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;Laravel Octane AI Streaming响应中断率高达37%&#xff1f;——Swoole协程下LLM流式输出的内存泄漏根因分析&#xff08;ValgrindXdebug双轨追踪报告&#xff09; 在高并发AI推理服务中&#xff0c;L…...

开发者在多模型间进行A B测试时Taotoken提供的便利

开发者在多模型间进行A B测试时Taotoken提供的便利 1. 统一接入降低切换成本 当算法工程师或产品经理需要评估不同大模型的实际效果时&#xff0c;传统方式往往需要为每个模型单独对接API、管理不同的密钥和计费体系。Taotoken通过提供OpenAI兼容的统一接口&#xff0c;使得开…...

别再死记硬背了!用Python的NumPy和Matplotlib亲手画一遍反双曲函数图像,理解立马翻倍

用Python可视化反双曲函数&#xff1a;从数学公式到动态图像的探索之旅 数学公式总是让人望而生畏&#xff0c;尤其是那些带着"反"字头的函数——反三角函数、反双曲函数&#xff0c;光是名字就足以让大多数人头疼。但如果你见过它们的图像&#xff0c;一切就会变得直…...

告别官方代码!手把手教你为YOLOv8-Seg模型定制ONNX导出,适配RKNN/Horizon/TensorRT部署

深度定制YOLOv8-Seg模型&#xff1a;从PyTorch到边缘计算芯片的高效部署指南 在计算机视觉领域&#xff0c;实时语义分割一直是工业应用中的关键技术挑战。YOLOv8-Seg作为最新一代的实时分割网络&#xff0c;其性能与效率平衡令人印象深刻。然而&#xff0c;当我们需要将其部署…...

告别龟速下载!手把手教你用最新淘宝镜像加速npm安装(附新旧域名切换指南)

极速开发实战&#xff1a;2024年npm国内镜像配置全攻略与避坑指南 每次执行npm install时盯着缓慢滚动的进度条&#xff0c;你是否也经历过那种焦灼&#xff1f;特别是在紧急修复生产环境bug时&#xff0c;每一秒的等待都像被无限拉长。作为国内开发者&#xff0c;我们完全没必…...

Windows 10/11下QFIL刷机报‘系统找不到指定的文件‘?可能是这个路径权限坑

Windows 10/11下QFIL刷机报"系统找不到指定的文件"&#xff1f;深入解析路径权限问题 最近在技术论坛上看到不少用户反馈&#xff0c;使用QFIL工具刷写高通芯片设备时&#xff0c;频繁遇到"系统找不到指定的文件"或"FireHose Fail"错误。这些报错…...

LLM服务性能压测实战:从原理到工具应用与优化分析

1. 项目概述&#xff1a;为什么我们需要一个专业的LLM性能测试工具&#xff1f; 在部署和优化大语言模型服务时&#xff0c;我们经常会遇到一些灵魂拷问&#xff1a;我的服务器到底能扛住多少并发请求&#xff1f;响应延迟的瓶颈在哪里&#xff1f;是GPU算力不足&#xff0c;还…...

华硕笔记本性能调优新选择:G-Helper轻量控制方案深度解析

华硕笔记本性能调优新选择&#xff1a;G-Helper轻量控制方案深度解析 【免费下载链接】g-helper G-Helper is a fast, native tool for tuning performance, fans, GPU, battery, and RGB on any Asus laptop or handheld - ROG Zephyrus, Flow, Strix, TUF, Vivobook, Zenbook…...

SAM 3技术解析:开放词汇分割与多模态AI验证

1. SAM 3技术解析&#xff1a;开放词汇分割的范式革新计算机视觉领域正在经历一场从封闭集识别到开放集理解的范式转变。传统图像分割方法受限于预定义的类别词汇表&#xff0c;而SAM 3通过引入多模态大语言模型&#xff08;MLLM&#xff09;和创新的AI验证机制&#xff0c;实现…...

NVIDIA Profile Inspector:解锁显卡驱动隐藏性能的专业解决方案

NVIDIA Profile Inspector&#xff1a;解锁显卡驱动隐藏性能的专业解决方案 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector 当您在NVIDIA控制面板中找不到所需的游戏优化选项时&#xff0c;当游戏画面撕…...