All Projects → sofastack → Sofa Bolt

sofastack / Sofa Bolt

Licence: apache-2.0
SOFABolt is a lightweight, easy to use and high performance remoting framework based on Netty.

Programming Languages

java
68154 projects - #9 most used programming language
lua
6591 projects

Projects that are alternatives of or similar to Sofa Bolt

Sofa Rpc
SOFARPC is a high-performance, high-extensibility, production-level Java RPC framework.
Stars: ✭ 3,479 (+69.13%)
Mutual labels:  sofastack, sofa-rpc, sofa-bolt
Sofa Jraft
A production-grade java implementation of RAFT consensus algorithm.
Stars: ✭ 2,618 (+27.27%)
Mutual labels:  sofastack, sofa-bolt
sofa-bolt-cpp
The C++ implementation of the SOFABolt protocol.
Stars: ✭ 21 (-98.98%)
Mutual labels:  sofastack, sofa-bolt
Pdf Books
📚 PDF 书籍库
Stars: ✭ 134 (-93.49%)
Mutual labels:  netty
Raincat
强一致分布式事务框架
Stars: ✭ 1,785 (-13.22%)
Mutual labels:  netty
Mango
A high-performance, open-source java RPC framework.
Stars: ✭ 150 (-92.71%)
Mutual labels:  netty
Rsocket Java
Java implementation of RSocket
Stars: ✭ 2,099 (+2.04%)
Mutual labels:  netty
Cleanstone
Springboot based Minecraft Server
Stars: ✭ 133 (-93.53%)
Mutual labels:  netty
Vert.x
Vert.x is a tool-kit for building reactive applications on the JVM
Stars: ✭ 12,544 (+509.82%)
Mutual labels:  netty
Carmelo
Carmelo is a fast, scalable Java server framework designed for online games. It uses Netty and Fastjson for highly efficient network transmission and supports both TCP/HTTP protocols.
Stars: ✭ 148 (-92.81%)
Mutual labels:  netty
Wechat
仿QQ即时通讯系统客户端
Stars: ✭ 144 (-93%)
Mutual labels:  netty
Him Vue
开源的H5即时聊天系统 spring-boot + netty + protobuf + vue ~
Stars: ✭ 142 (-93.1%)
Mutual labels:  netty
Okra
High performance game server framework by netty and disruptor
Stars: ✭ 152 (-92.61%)
Mutual labels:  netty
Java Kcp
基于java的netty实现的可靠udp网络库(kcp算法),包含fec实现,可用于游戏,视频,加速等业务
Stars: ✭ 137 (-93.34%)
Mutual labels:  netty
Nasus
Zero-configuration command-line async HTTP files server in Clojure. Like Python's SimpleHTTPServer but scalable.
Stars: ✭ 158 (-92.32%)
Mutual labels:  netty
Fpush
📶即时消息推送服务(即时通讯),基于Netty+protobuf-- Instant Messaging push service based on Netty+protobuf
Stars: ✭ 134 (-93.49%)
Mutual labels:  netty
Agentx
Shadowsocks升级版,支持协议伪装和流量压缩,易于扩展,可统计流量
Stars: ✭ 154 (-92.51%)
Mutual labels:  netty
Nettyrpc
A simple RPC framework based on Netty, ZooKeeper and Spring
Stars: ✭ 1,975 (-3.99%)
Mutual labels:  netty
Sofa Common Tools
sofa-common-tools is a library that provide some utility functions to other SOFA libraries.
Stars: ✭ 141 (-93.15%)
Mutual labels:  sofastack
Netty Learning Example
🥚 Netty实践学习案例,见微知著!带着你的心,跟着教程。我相信你行欧。
Stars: ✭ 2,146 (+4.33%)
Mutual labels:  netty

SOFABolt Project

Build Status Coverage Status license version Percentage of issues still open

1. 介绍

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

  • 为了让 Java 程序员能将更多的精力放在基于网络通信的业务逻辑实现上,而不是过多的纠结于网络底层 NIO 的实现以及处理难以调试的网络问题,Netty 应运而生。
  • 为了让中间件开发者能将更多的精力放在产品功能特性实现上,而不是重复地一遍遍制造通信框架的轮子,SOFABolt 应运而生。

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

2. 功能介绍

intro

SOFABolt 的基础功能包括:

  • 基础通信功能 ( remoting-core )
    • 基于 Netty 高效的网络 IO 与线程模型运用
    • 连接管理 (无锁建连,定时断链,自动重连)
    • 基础通信模型 ( oneway,sync,future,callback )
    • 超时控制
    • 批量解包与批量提交处理器
    • 心跳与 IDLE 事件处理
  • 协议框架 ( protocol-skeleton )
    • 命令与命令处理器
    • 编解码处理器
    • 心跳触发器
  • 私有协议定制实现 - RPC 通信协议 ( protocol-implementation )
    • RPC 通信协议的设计
    • 灵活的反序列化时机控制
    • 请求处理超时 FailFast 机制
    • 用户请求处理器 ( UserProcessor )
    • 双工通信

用法1

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

invoke_type

用法2

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

msg_protocol

4. 如何贡献

开放代码允许在签署协议之后,提交贡献代码。具体参考如何参与贡献 SOFABolt 代码

对 SOFABolt 代码的修改和变更,需要遵守版权协议

5. 多语言

6. 用户

蚂蚁集团 网商银行 恒生电子 数立信息
Paytm 天弘基金 中国人保 信美相互
南京银行 民生银行 重庆农商行 中信证券
富滇银行 挖财 拍拍贷 OPPO金融
运满满 译筑科技 杭州米雅信息科技 邦道科技
申通快递 深圳大头兄弟文化 烽火科技 亚信科技
成都云智天下科技 上海溢米辅导 态赋科技 风一科技
武汉易企盈 极致医疗 京东 小象生鲜
北京云族佳 欣亿云网 山东网聪 深圳市诺安赛威
上扬软件 长沙点三 网易云音乐 虎牙直播
中国移动 无纸科技 黄金钱包 独木桥网络
wueasy 北京攸乐科技 易宝支付 威马汽车
亿通国际 新华三 klilalagroup

7. 联系我们

  • 微信

    • 公众号:金融级分布式架构(Antfin_SOFA):致力于打造一流的分布式技术在金融场景应用实践的技术交流平台,专注于交流金融科技行业内最前沿、可供参考的技术方案与实施路线。

      Wechat
  • 钉钉

    • 钉钉交流群:

      • 金融级分布式架构 SOFAStack 1群,群号:23127468 已满

      • 金融级分布式架构 SOFAStack 2群,群号:23195297 已满

      • 金融级分布式架构 SOFAStack 3群,群号:23390449 已满

      • 金融级分布式架构 SOFAStack 4群,群号:23372465 已满

      • 金融级分布式架构 SOFAStack 5群,群号:30315793 已满

      • 金融级分布式架构 SOFAStack 6群,群号:34197075

        DingTalk
    • 钉钉交流群:SOFAStack 金牌用户服务群,如果您已经在生产环境使用了 SOFAStack 相关组件,还请告知我们,我们将会邀请您加入到此群中,以便更加快捷的沟通和更加高效的线上使用问题支持。

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].