HTTP 请求和 RPC 调用 区别

rpc字面意思就是远程过程调用,只是对不同应用间相互调用的一种描述。实现方式可以是tcp和http。

这里我说一种rpc实现,可以对照dubbo

rpc最关键的地方有请求体的封装,响应体的封装以及客户端调用的封装。

求体:服务类class(一般是接口名),方法名methodName,还有参数类型,参数变量

响应体:响应状态(可以用boolean,表示是否成功),返回结果可以是Object(可以存放正常的返回结果),还有可以定义message(如果报错了,打出异常信息返回回来)

客户端调用:既然是远程调用,就避免不了网络连接的建立,需要建立tcp或http连接。但是每个服务都都要去手写个连接,岂不累死?所以通常会用到代理模式解决这个问题(写框架的时候才会体会到设计模式的威力)。具体的做法就是写个工厂类,以服务的接口名为参数,生成一个代理对象。

至此,一个简单的rpc就是实现了。

什么是rpc?
我觉得就是基于tcp和http的请求封装

而基于http请求的方式,通过请求路径已经确定了,你要请求的服务的类,方法名,比我上面的说的方式更傻瓜化。
所以rpc为啥不http请求,取决于你的服务端支不支持http

另外,dubbo这样的rpc一般在公司内部系统使用,而对外的open API一般会rest或者http方式。因为dubbo这样的rpc会暴露服务地址,不安全,而http方式是基于域名,网络要更安全。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
RPC(Remote Procedure Call,远程过程调用)和HTTP调用都是客户端和服务端之间的通信方式,但它们之间有一些关键的区别: 1. **目的和用途**: - HTTP主要用于传输数据,尤其是基于RESTful设计的API,适合于无状态、轻量级的数据交换,如网页浏览和API接口调用。 - RPC旨在提供更复杂的功能支持,它可以执行远程服务的完整方法调用,类似于直接调用本地函数。 2. **协议及交互模型**: - HTTP基于TCP/IP协议,请求/响应模式,每个请求都独立且明确,通常包含状态码反馈。 - RPC通常采用自定义协议或已有协议如gRPC,可能包含二进制序列化的消息,允许更高效、复杂的操作,比如同步或异步调用。 3. **性能**: - HTTP由于需要解析HTTP头、序列化/反序列化数据等额外步骤,对于频繁的小数据交互可能效率较低。 - RPC由于减少了网络开销和中间处理,特别是对大型数据结构或计算密集型任务,性能通常更好。 4. **可扩展性和灵活性**: - HTTP协议广泛应用于互联网上,有更多的库和工具支持,并可通过浏览器直接访问。 - RPC可以根据应用需求定制,提供了更强的类型检查和错误处理,但可能没有HTTP那样容易扩展到大规模分布式系统。 5. **安全性和跨域限制**: - HTTP默认的同源策略限制了不同域间的通信,可能需要CORS或WebSocket等技术解决。 - RPC可以通过隧道协议(如HTTPS)来保证通信安全,而一些RPC框架会提供更好的权限管理和验证机制。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值