Coder Social home page Coder Social logo

joyrpc's Introduction

JOYRPC

GitHub release GitHub

JOYRPC是一款基于 Java 实现的 RPC 服务框架,是在总结内部服务框架经验的基础上,完全重新设计、支持全异步、微内核和插件化。

JOYRPC Architecture

主要特性

  • 微内核: 全插件化的RPC框架,我们只是补充了默认实现,所有的核心模块都支持用户自定义。
  • 纯异步: 接口完全支持CompletableFuture类型返回值,Provider端业务逻辑可以异步执行,提升服务端吞吐量与调用端吞吐量,Filter调用链全异步化。
  • 协商机制: 在连接建立成功后,Consumer和Provider进行协商逻辑,确认协议版本、序列化可用列表、压缩算法列表,保障同协议中,多版本的编解码、序列化、压缩等插件实现的兼容性。
  • 多注册中心: Provider端支持多注册中心同时注册,注册中心插件化,默认提供memory注册中心实现,zk、etcd注册中心实现,使用方可自行扩展。
  • 插件化多协议: 提供协议插件,默认提供joyrpc协议、http协议、grpc协议(支持与原生grpc相互调用,不用修改java接口,就可以支持grpc调用,(暂不支持grpc的流式调用),使用方可自行扩展。
  • 优雅上下线: Provider发布,将启动与注册逻辑完全分开,先启动,后注册,同时支持接口预热,做到优雅上线。Provider下线,会给Consumer端发送下线通知,后续不会接收到请求,并在处理剩余请求之后关闭端口,做到优雅下线,Consumer端无感知。
  • 插件化编解码、序列化、压缩: 解码、序列化、压缩算法全部插件化可扩展,同时使用方可自定义序列化, joyrpc协商机制可保证兼容性。默认hessian协议序列化,兼容性更好。 提供了性能更高的protostuff协议序列化,但对接口设计有要求。
  • 预热权重: Provider端支持接口预热,通过自主实现并配置预热插件,Provider启动时,触发预热插件,调用预热逻辑。Consumer端支持预热权重,通过配置,在新Provder节点启动时,权重逐渐增大,流量也会逐渐增大,保证Consumer端的服务调用可用率
  • 增强重试: 更加合理的重试逻辑,做到安全重试,支持重试节点筛选插件,支持业务分组重试。更准确的超时时间,统一的超时时间,每次重试后超时时间递减。
  • 自适应负载均衡: Consumer可配置自适应负载均衡,根据Provider节点的TP指标、异常数进行自适应负载控制,保证Provider服务节点与Consumer端的服务调用可用率的稳定性。
  • 序列化安全:默认采用白名单方式,增强序列化安全
  • 分布式事务:集成了Seata分布式事务插件
  • 云原生:支持以应用的服务名称来进行注册,而不是以接口注册服务

快速开始

查看快速开始

配置参考手册

查看配置参考手册

使用示例

查看使用示例

常见问题

查看常见问题

发布历史

查看发布历史

joyrpc's People

Contributors

hexiaofeng avatar yiyanghua avatar dependabot[bot] avatar yeary avatar chenzhiguo avatar andyadc avatar cvedetect avatar levin80 avatar markuszcl99 avatar zhanghqgit avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.