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、限流、熔断等服务安全、可观测性、服务治理功能。
- 支持同步调用、异步调用、泛化调用。满足各种场景下的不同诉求。
- 高效的自定义协议。二进制消息交换协议Photon和Focus的RPC协议。
- 不同级别的服务控制。全局级别、服务级别的序列化、压缩、超时、重试设置,方法级别的超时、重试设置。
- Spring boot 集成支持友好。简化Spring应用的集成、开发难度。
快速开始
更多的例子可以参考例子工程 focus-examples。
运行快速启动的最低要求是:
- JDK 1.8 及以上
- Maven 或 Gradle 工程管理工具