SOFABolt 正在参加 2021 年度 OSC 中国开源项目评选,请投票支持!
SOFABolt 在 2021 年度 OSC 中国开源项目评选 中已获得 {{ projectVoteCount }} 票,请投票支持!
2021 年度 OSC 中国开源项目评选 正在火热进行中,快来投票支持你喜欢的开源项目!
2021 年度 OSC 中国开源项目评选 >>> 中场回顾
SOFABolt 获得 2021 年度 OSC 中国开源项目评选「最佳人气项目」 !
授权协议 Apache 2.0
开发语言 Java
操作系统 跨平台
软件类型 开源软件
开源组织 蚂蚁金服
地区 国产
投 递 者 王练
适用人群 未知
收录时间 2018-04-19

软件简介

SOFABolt 是蚂蚁金融服务集团开发的一套基于 Netty 实现的网络通信框架。

  • 为了让 Java 程序员能将更多的精力放在基于网络通信的业务逻辑实现上,而不是过多的纠结于网络底层 NIO 的实现以及处理难以调试的网络问题,Netty 应运而生。

  • 为了让中间件开发者能将更多的精力放在产品功能特性实现上,而不是重复地一遍遍制造通信框架的轮子,SOFABolt 应运而生。

Bolt 名字取自迪士尼动画-闪电狗,是一个基于 Netty 最佳实践的轻量、易用、高性能、易扩展的通信框架。 这些年我们在微服务与消息中间件在网络通信上解决过很多问题,积累了很多经验,并持续的进行着优化和完善,我们希望能把总结出的解决方案沉淀到 SOFABolt 这个基础组件里,让更多的使用网络通信的场景能够统一受益。 目前该产品已经运用在了蚂蚁中间件的微服务 (SOFARPC)、消息中心、分布式事务、分布式开关、以及配置中心等众多产品上。

功能介绍

SOFABolt 的基础功能包括:

  • 基础通信功能 ( remoting-core )

    • 基于 Netty 高效的网络 IO 与线程模型运用

    • 连接管理 (无锁建连,定时断链,自动重连)

    • 基础通信模型 ( oneway,sync,future,callback )

    • 超时控制

    • 批量解包与批量提交处理器

    • 心跳与 IDLE 事件处理

  • 协议框架 ( protocol-skeleton )

    • 命令与命令处理器

    • 编解码处理器

    • 心跳触发器

  • 私有协议定制实现 - RPC 通信协议 ( protocol-implementation )

    • RPC 通信协议的设计

    • 灵活的反序列化时机控制

    • 请求处理超时 FailFast 机制

    • 用户请求处理器 ( UserProcessor )

    • 双工通信

用法1

将 SOFABolt 用作一个远程通信框架,使用者可以不用关心如何实现一个私有协议的细节,直接使用我们内置的 RPC 通信协议。可以非常简单的启动客户端与服务端,同时注册一个用户请求处理器,即可完成远程调用。同时,像连接管理、心跳等基础功能特性都默认可以使用。 当前支持的调用类型如下图所示:

用法2

将 SOFABolt 用作一个协议框架,使用者可以复用基础的通信模型、协议包含的接口定义等基础功能。然后根据自己设计的私有协议自定义 Command 类型、Command 处理器、编解码处理器等。如下图所示,RPC 和消息的 Command 定义结构:

展开阅读全文

代码

的 Gitee 指数为
超过 的项目

评论

点击加入讨论🔥(4) 发布并加入讨论🔥
发表于软件架构专区
2020/07/24 18:51

SOFABolt 发布 v1.6.2 版本 | 蚂蚁集团开源网络通信框架

修改内容包括: 所有MR以及issue见milestone1.6.2 兼容性 兼容1.6.1版本 v1.6.2的pom依赖 <!-- 日志门面使用slf4j,日志实现可以选择log4j、log4j2、logback,可参考:https://github.com/alipay/sofa-bolt/wiki/log_implementation_jar --> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.7.21</version> </dependency> <dependency> <groupId>io.netty...

1
11
发表于软件架构专区
2019/06/10 14:18

SOFABolt 发布 v1.6.0 版本 | 蚂蚁金服开源网络通信框架

发布 SOFABolt v1.6.0 版本,主要变更如下: 兼容性 兼容 1.5.5 版本 v1.6.0 的 pom 依赖 <!-- 日志门面使用slf4j,日志实现可以选择log4j、log4j2、logback,可参考:https://github.com/alipay/sofa-bolt/wiki/log_implementation_jar --> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.7.21</version> </dependency> <dependency> <groupId>io.netty...

2
21
发表于软件架构专区
2019/05/30 10:08

SOFABolt 发布 v1.5.5 版本 | 蚂蚁金服开源网络通信框架

1、发布 SOFABolt v1.5.5 版本,主要变更如下: 1)兼容性 兼容1.5.4版本 v1.5.5的pom依赖 <!-- 日志门面使用slf4j,日志实现可以选择log4j、log4j2、logback,可参考:https://github.com/alipay/sofa-bolt/wiki/log_implementation_jar --> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.7.21</version> </dependency> <dependency> <groupId>io.net...

7
23
没有更多内容
加载失败,请刷新页面
点击加载更多
加载中
下一页
发表了博客
{{o.pubDate | formatDate}}

{{formatAllHtml(o.title)}}

{{parseInt(o.replyCount) | bigNumberTransform}}
{{parseInt(o.viewCount) | bigNumberTransform}}
没有更多内容
暂无内容
发表了问答
{{o.pubDate | formatDate}}

{{formatAllHtml(o.title)}}

{{parseInt(o.replyCount) | bigNumberTransform}}
{{parseInt(o.viewCount) | bigNumberTransform}}
没有更多内容
暂无内容
暂无内容
4 评论
134 收藏
分享
OSCHINA
登录后可查看更多优质内容
返回顶部
顶部