一个高可用、高性能、轻量级的分布式服务框架。支持容灾、负载均衡、集群。一个典型的应用场景是,将同一个服务部署在多个Server
上提供 request、response 消息通知。
使用RSF可以点对点调用,也可以分布式调用。部署方式上:可以搭配注册中心(详细..),也可以独立使用。
- 支持服务热插拔:支持服务动态发布、动态卸载
- 支持服务分组:支持服务分组、分版本
- 支持多种方式调用:同步、异步、回调、接口代理
- 支持多种模式调用:RPC模式调用、Message模式调用 RPC 模式: 远程调用会等待并返回执行结果。适用于一般方法。遇到耗时方法会有调用超时风险 Message 模式: 远程调用当作消息投递到远程机器,不会产生等待,可以看作是一个简单的 MQ。适合于繁重的耗时方法
- 支持点对点调用。RSF的远程调用可以点对点定向调用,也可以集群大规模部署集中提供同一个服务
- 支持虚拟机房。通过配置虚拟机房策略可以降低跨机房远程调用
- 支持泛化调用。简单的理解,泛化调用就是不依赖二方包,通过传入方法名,方法签名和参数值,就可以调用服务
- 支持隐式传参。可以理解隐式传参的含义为,不需要在接口上明确声明参数。在发起调用的时传递到远端
- 内置 Telnet 控制台,可以命令行方式直接管理机器
- 支持 offline/online 动作
- 支持第三方集成,可以独立使用,也可以和 Spring、Jfinal等第三方框架整合使用
- 支持拦截器RsfFilter,开发者可以通过扩展 Filter 实现更多需求
- 支持自定义序列化。默认使用内置 Hessian 4.0.7 序列化库
- 支持Telnet控制台自定义指令。通过扩展控制台指令,可以发挥更大想象空间
- 最大发并发请求数配置(默认:200)
- 最大发起请求超限制策略设置: A-等待1秒重试、B-抛异常(默认:B-抛异常)
- Netty线程数配置(默认: 监听请求线程数: 1,IO线程数: 8)
- 提供者调用队列容量配置(默认: 队列容量: 4096)
- Work线程数配置(默认: 处理调用线程数: 4)
- 请求超时设置。支持服务提供者,服务订阅者独立配置各自的超时参数(默认 6000毫秒)
- 双向通信。RSF会合理利用Socket连接,双向通信是指当A机器发起远程调用请求之后,RSF会建立长连接 -- 如果B机器有调用A机器的需求则直接使用这个连接不会重新创建新的连接,双向通信会大量降低集群间的连接数
- 支持优雅停机。应用停机,Center会自动通知整个集群。即便所有 Center 离线,RSF也会正确处理失效地址
- 每小时地址本动态备份。当所有注册中心离线,即便在没有注册中心的情况下应用程序重启,也不会导致服务找不到提供者的情况
- 当某个地址失效之后,RSF会冻结一段时间,在这段时间内不会有请求发往这个地址
- 支持请求、响应分别使用不同序列化规则
- 支持QoS流量控制。流控可以精确到:接口、方法、地址
- 支持动态路由脚本。路由可以精确到:接口、方法、参数
- 通过路由脚本可以轻松实现接口灰度发布
- 支持发布服务授权
- 支持服务订阅授权
- 支持匿名应用