跨语言RPC框架Focus发布V1.2.0

原创
2024/02/01 19:03
阅读数 96

2024-02-01 Focus 发布了 V1.2.0。

Focus 是下一代跨语言、轻量级RPC框架。旨在帮助程序员快速的开发微服务应用程序,简化多运行环境下的RPC编程,可以很轻松的实现云端编程和移动端编程。

改进的特性:

  • 删除了RPC协议层类Call,Reply,Attach,重构了RPC异常处理机制
  • 添加RPC协议层类Invocation,重构了Handler API
  • 修复了TelemetryInterceptor在异常情况下的bug
  • 给Invocation添加了访问Service/Method config的方法
  • 给Invocation添加了调用Context
  • 重构了ServiceLocater到ServiceLocator,优化了服务发现ServiceLocator类DiscoveryServiceLocator支持Nacos and Consul service locator

Focus简介

Focus 是下一代跨语言、轻量级RPC框架。旨在帮助程序员快速的开发微服务应用程序,简化多运行环境下的RPC编程,可以很轻松的实现云端编程和移动端编程。

通常,评价一个 RPC 框架是否优秀、高效能,有 3 个基本标准:

  • 简单易用,无侵入:不需要过多的研究使用文档,查看快速开始或 API 就能快速用起来,框架代码无需侵入业务代码就能完成调用。

  • 抽象适度,可扩展:框架分层耦合合理、模块职责内聚、实现简洁易懂,能覆盖绝大多数场景,对特殊场景可通过设置或扩展来满足需求。

  • 性能优越,可演进:“高性能”永远是一个绕不开的关注点,框架的实现也是编码能力的体现,保持 API 不变,但实现可持续迭代改进。

Focus 框架在高效能方面做了很多的努力,贯彻最小侵入性设计理念,坚持面向对象的SOLID原则,追求极简协议和代码简洁,能够让开发者和企业更轻松地集成和使用RPC框架。

对于希望使用和学习RPC框架的同学来说,选择一个高效、易用、灵活和可扩展的框架非常重要。Focus框架可以为他们提供更多的参考和选择,帮助他们更好地了解和掌握RPC框架的使用技巧和最佳实践。

特性

  • 跨语言支持。同时支持多种串行化协议:Jackson和Protobuff。
  • 模块化API。模块化的客户端和服务端API,可扩展的系统架构核心小于1 MB。
  • 分层架构。合理严谨的分层(包括API层、代理层、调用层、协议层、传输层)使得依赖最小化、可控,适用于更多运行环境。
  • 可插拔的服务发现机制。支持 Consul,Nacos,Polaris等常见注册中心。
  • 可插拔的调用拦截机制。可实现Logging、Tracing、Metrics、限流、熔断等服务安全、可观测性、服务治理功能。
  • 支持同步调用、异步调用、泛化调用。满足各种场景下的不同诉求。
  • 高效的自定义协议。二进制消息交换协议PhotonFocus的RPC协议。
  • 不同级别的服务控制。全局级别、服务级别的序列化、压缩、超时、重试设置,方法级别的超时、重试设置。
  • Spring boot 集成支持友好。简化Spring应用的集成、开发难度。

快速开始

更多的例子可以参考例子工程 focus-examples

运行快速启动的最低要求是:

  • JDK 1.8 及以上
  • Maven 或 Gradle 工程管理工具
展开阅读全文
加载中
点击引领话题📣 发布并加入讨论🔥
0 评论
0 收藏
0
分享
返回顶部
顶部