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

实现rpc通信机制(待定)

一、概述

(1)rpc(remote procedure call, 远程接口调用),就像在本地调用函数一样,是应用组成服务内部分布式的基础功能。应用场景是在内网中的计算,比如:(a) 为上传的一张图片加水印、(b)在一款即时通讯软件内如想知道某个账户是否上线的状态、(c)查询端口是否可用、(d)查询防火墙的规则是否可用、(e)判断一个进程是否运行、使用的内存多大.....。

(2)rpc和http在使用中有什么区别和共同点?

答:共同点:两者都是用于2台机器间通信的,都是用于建立应用层偏业务的功能。

不同点:rpc更倾向于对内,内部的服务,书写风格是函数调用风格;http更倾向于客户端请求,适用在手机app或者浏览器请求服务端,对外的功能,由于有https多了层加密所以书写风格适合对外。rpc是一函数风格去调用,http是需要内部封装http请。

(3)市面上rpc的开源方案很多,比如百度的brpc,搜狗的zrpc,腾讯的Tars,淘宝的krpc,为什么不用现成的,而还要自己造rpc?

答:有可能实际需求只是其中很小的功能,但用开源rpc(a)学习成本高,有技术问题也不方便修改;(b)由于是自己的内部业务,只需要结合自己的功能,也不需要很全面的开源方案;

在server端实现类似函数
int  abc(int a){int c = a + 1;return c;
}在客户端可以直接用此函数
int main(){int ff = add(3);
}

备注

(1)size_t total_sent = send(...) 和 int total_sent = send(...) 的区别在于 变量类型 以及它们对返回值的处理影响?

答:size_t: 是无符号整型,用于表示大小或计数。通常用于表示非负数,例如数组的大小、内存的字节数等。int: 是有符号整型,可以表示正数、负数或零。通常用于表达普通整数。

(2)memset(变量名称, 0, (length + 1)) 与 ret = recv(connfd, 变量名称, length, 0)

(3)为什么对于字符串的copy不是每一次都考虑“\0”?比如

char *zrpc_method_zcat(char * a, char* b, char *c){char* str = (char *)malloc(strlen(a) + strlen(b) + strlen(c) + 1);strcpy(str, a);memcpy(str + strlen(a), b, strlen(b));memcpy(str + strlen(a) + strlen(b), c, strlen(c))
}

其中的strcpy()和memcpy()都没有复制“\0”。

答:字符串只要在结尾加“\0”就可以了,所以malloc()分配内存的时候 "+ 1",而中间位置不需要有“\0”。

(4)这个结构体占据多少字节?

#include<string.h>
#include <stdio.h>struct zrpc_func {char *method;char *params[16];char *types[16];int count;
};int main() {printf("Size of struct: %zu bytes\n", sizeof(struct zrpc_func));return 0;
}

(假设 64 位系统)

成员类型大小(字节)说明
methodchar*8指针(64 位系统)
paramschar*[16]16 × 8 = 12816 个指针,每个 8 字节
typeschar*[16]16 × 8 = 12816 个指针,每个 8 字节
countint4普通 int 类型

三、报错信息

(a)编译报错信息

出现“未找到.h头文件”

解决:找到含有头文件的文件夹路径,flag是“-I”,比如

gcc -o xxx xxx.c -I ./core/

出现“未定义undefine”

解决:这是没找到链接,所以先找到文件夹路径,然后是加上具体的链接名称flag是“-L”和“-lxxx”,比如

gcc -o xxx xxx.c -I ./core/  -L ./  -lxxx -lpthread -ldl

http://www.lryc.cn/news/2385837.html

相关文章:

  • MATLAB 2023b 配电柜温度报警系统仿真
  • 代码随想录打卡|Day45 图论(孤岛的总面积 、沉没孤岛、水流问题、建造最大岛屿)
  • SpringCloud实战:使用Sentinel构建可靠的微服务熔断机制
  • 张 Prompt Tuning--中文数据准确率提升:理性与冲动识别新突破
  • MySQL 中 information_schema.processlist 使用原理
  • 微信小程序学习基础:从入门到精通
  • 如何使用redis做限流(golang实现小样)
  • lanqiaoOJ 4185:费马小定理求逆元
  • 深度剖析ZooKeeper
  • 深入解析 MySQL 中的 SHOW_ROUTINE 权限
  • 电脑网络如何改ip地址?ip地址改不了怎么回事
  • 打开小程序提示请求失败(小程序页面空白)
  • C语言速成12之指针:程序如何在内存迷宫里找宝藏?
  • 一张纸决定的高度
  • IP查询基础介绍
  • 常见的gittee开源项目推荐
  • 日常效率工具【Tools】【持续更新】
  • PyTorch中TensorBoardX模块与torch.utils.tensorboard模块的对比分析
  • 数据结构与算法——链式二叉树
  • Android12 launcher3修改App图标白边问题
  • 【iOS】分类、扩展、关联对象
  • 内蒙古工程系列建设工程技术人才评审条件
  • Elasticsearch超详细安装部署教程(Windows Linux双系统)
  • 第十六章:数据治理之数据架构:数据模型和数据流转关系
  • 目标检测DINO-DETR(2023)详细解读
  • 基于 STM32 的蔬菜智能育苗系统硬件与软件设计
  • 实现一个带有授权码和使用时间限制的Spring Boot项目
  • SGlang 推理模型优化(PD架构分离)
  • TuyaOpen横空出世!涂鸦智能如何用开源框架重构AIoT开发范式?
  • Vue语法【2】