news 2026/2/10 12:45:36

MPRPC项目(第九天,新增服务以及controller实现)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MPRPC项目(第九天,新增服务以及controller实现)

一、新增服务提供

两个都与用户登录没有什么区别

1、friend.proto

syntax = "proto3"; package fixbug; option cc_generic_services = true; message ResultCode{ int32 errcode = 1; bytes errmsg = 2; } message GetFriendListRequest{ uint32 userid = 1; } message GetFriendListResponse{ ResultCode result = 1; repeated bytes friends = 2; } service FriendServiceRpc{ rpc GetFriendList(GetFriendListRequest) returns(GetFriendListResponse); }

要新建一个proto文件。

2、服务端

#include<iostream> #include<string> #include"friend.pb.h" #include"mprpcapplication.h" #include"rpcprovider.h" #include<vector> class FriendService : public fixbug::FriendServiceRpc { public: std::vector<std::string> GetFriendList(uint32_t userid){ std::cout << "do GetFriendList service" << std::endl; std::vector<std::string> vec; vec.push_back("zhangsan"); vec.push_back("lisi"); vec.push_back("wangwu"); return vec; } void GetFriendList(::google::protobuf::RpcController* controller, const ::fixbug::GetFriendListRequest* request, ::fixbug::GetFriendListResponse* response, ::google::protobuf::Closure* done){ uint32_t userid = request->userid(); std::vector<std::string> friendlist = GetFriendList(userid); response->mutable_result()->set_errcode(0); response->mutable_result()->set_errmsg(""); //把好友列表序列化,写入到response的friends字段中,返回给客户端 //inline std::string* GetFriendListResponse::add_friends(); for(std::string &name : friendlist){ std::string *p = response->add_friends(); *p = name; } done->Run(); } }; int main(int argc, char **argv){ //调用框架的初始化操作 MprpcApplication::Init(argc,argv); //provider是一个rpc网络服务对象,把FriendService对象发布到rpc节点上 RpcProvider provider; provider.NotifyService(new FriendService()); //启动rpc服务发布节点 Run以后,进程进入阻塞状态,等待远程的rpc调用请求 provider.Run(); return 0; }

3、消费端

#include<iostream> #include "friend.pb.h" #include"mprpcapplication.h" int main(int argc,char **argv){ //整个程序启动后,想用mprpc框架调用rpc服务,一定要先调用框架的初始化函数(只初始化一次) MprpcApplication::Init(argc,argv); //演示远程调用发布的rpc方法 Login fixbug::FriendServiceRpc_Stub stub(new MprpcChannel()); fixbug::GetFriendListRequest request; request.set_userid(1); //RPC方法的响应 fixbug::GetFriendListResponse response; MprpcController controller; //发起rpc方法的调用 同步的rpc调用过程 MprpcChannel::callmethod stub.GetFriendList(&controller, &request, &response, nullptr); //一次rpc调用完整,读取调用结果 //0表示成功,非0表示错误 如404,not found if(controller.Failed()){ std::cout<<controller.ErrorText()<<std::endl; }else{ if(response.result().errcode() == 0){ std::cout<<"rpc GetFriendList response success! "<<std::endl; for(int i = 0; i < response.friends_size(); i++){ std::cout<<"name"<<i<<": "<<response.friends(i)<<std::endl; } }else{ std::cout<<"rpc GetFriendList response failed: "<<response.result().errcode()<<" msg: "<<response.result().errmsg()<<std::endl; } } return 0; }

这里新增了controller,让服务端能够获得错误信息,无论是出现在服务端还是消费端的。

二、controller实现

该对象是Protobuf RPC框架中用于错误报告和调用控制的核心组件,它使得上层应用能够获知RPC调用过程中发生的各种错误情况,是RPC调用结果反馈的重要机制。

类似于以下用法,在mprpcchannel.cc里修改错误输出,设置出错后,在消费端就能获得。

char errtxt[512] = {0}; sprintf(errtxt,"connect failed!errno : %d",errno); controller->SetFailed(errtxt);

1、mprpccontroller.h

#pragma once #include<google/protobuf/service.h> #include<string> class MprpcController:public google::protobuf::RpcController{ public: MprpcController(); void Reset(); bool Failed() const; std::string ErrorText() const; void SetFailed(const std::string& reason); //目前未实现具体的功能 void StartCancel(); bool IsCanceled() const; void NotifyOnCancel(google::protobuf::Closure* callback); private: bool m_failed;//RPC方法执行过程中的状态 std::string m_errText;//rpc方法执行过程中的错误信息 };

2、mprpccontroller.cc

#include "mprpccontroller.h" //初始化 MprpcController::MprpcController(){ m_failed = false; m_errText = ""; } //重置 void MprpcController::Reset(){ m_failed = false; m_errText = ""; } //判断是否成功 bool MprpcController::Failed() const{ return m_failed; } //返回错误信息 std::string MprpcController::ErrorText() const{ return m_errText; } //发生错误 void MprpcController::SetFailed(const std::string& reason){ m_failed = true; m_errText = reason; } //目前未实现具体的功能 void MprpcController::StartCancel(){} bool MprpcController::IsCanceled() const{return false;} void MprpcController::NotifyOnCancel(google::protobuf::Closure* callback){}

====

这里附上代码,这两次的都没添加

https://github.com/wky-2004/exp1/tree/master/MPRPC

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/2 19:36:06

Proteus下载安装指南:单片机仿真入门必看教程

从零开始玩转Proteus&#xff1a;单片机仿真环境搭建全攻略 你是不是也遇到过这样的窘境&#xff1f;想学单片机&#xff0c;却连一块开发板都买不起&#xff1b;写好了代码&#xff0c;却因为硬件接错线烧了芯片&#xff1b;调试时反复插拔下载器&#xff0c;结果USB口松了……

作者头像 李华
网站建设 2026/2/10 1:14:06

将PyTorch模型权重上传至GitHub Release便于他人复现

将 PyTorch 模型权重上传至 GitHub Release&#xff1a;构建可复现的 AI 开发闭环 在深度学习项目中&#xff0c;你是否遇到过这样的场景&#xff1f;——某篇论文声称达到了 98% 的准确率&#xff0c;你兴致勃勃地克隆代码、安装依赖&#xff0c;结果运行时却报出 ImportError…

作者头像 李华
网站建设 2026/2/9 4:56:38

Markdown文档记录实验过程:搭配Miniconda环境变量说明

基于 Miniconda 与 Markdown 的 AI 实验可复现实践 在今天的人工智能研究中&#xff0c;一个让人哭笑不得的常见场景是&#xff1a;某位同学兴冲冲地展示训练结果&#xff0c;“模型准确率达到了98%&#xff01;”——但当其他人尝试复现时&#xff0c;却卡在环境依赖上&#x…

作者头像 李华
网站建设 2026/2/9 4:51:51

LeetCode 67. Add Binary:从面试思路到代码细节

在字符串题里&#xff0c;Add Binary 是一个非常典型、同时又非常适合考察模拟 指针 进位处理的面试题。leetcode 很多同学第一次见到时&#xff0c;直觉解法就是"转成十进制相加再转回二进制"&#xff0c;但面试官往往希望你自己模拟二进制加法的全过程。 本文会从…

作者头像 李华
网站建设 2026/2/8 21:35:09

audio2face Connection reset by peer

目录 权限报错&#xff1a; audio2face Connection reset by peer 报错&#xff1a; Traceback (most recent call last):File "/usr/local/lib/python3.10/dist-packages/nimlib/nimutils.py", line 48, in download_modelsmodel_manifest.download_models()File…

作者头像 李华
网站建设 2026/2/7 5:33:43

Keil5编译器5.06下载后无法编译问题一文说清

Keil5编译器5.06下载后无法编译&#xff1f;一文彻底解决常见构建失败问题你是不是也遇到过这种情况&#xff1a;兴冲冲地从官网完成keil5编译器5.06下载&#xff0c;安装完毕打开老项目一点“Build”&#xff0c;结果弹出一堆红色错误&#xff1a;Fatal error: Cannot find ar…

作者头像 李华