基于Java AIO实现的异步通信框架,smart-socket「终于解决」

Java (82) 2023-07-23 19:12

Hi,大家好,我是编程小6,很荣幸遇见你,我把这些年在开发过程中遇到的问题或想法写出来,今天说一说基于Java AIO实现的异步通信框架,smart-socket「终于解决」,希望能够帮助你!!!。

smart-socket是一款国产开源的Java AIO框架,追求代码量、性能、稳定性、接口设计各方面都达到极致。如果smart-socket对您有一丝帮助,请Star一下我们的项目并持续关注;如果您对smart-socket并不满意,那请多一些耐心,smart-socket一直在努力变得更好。

版本说明

系列最新版文档说明1.31.3.25暂停维护企业级,已稳定运行在众多企业的生产环境上1.41.4.5《smart-socket技术小册》暂无

特色:

  1. 代码量极少,可读性强。核心代码仅1千行左右。
  2. 学习门槛低,二次开发只需实现两个接口。
  3. 资源利用率高,性能爆表,充分压榨CPU、带宽。
  4. 提供丰富的插件式服务,包括:心跳插件、断链重连插件、服务监控插件、黑名单插件、内存池监测插件。

哪些项目在用smart-socket?

  1. smart-http 国内首款基于smart-socket实现的Http服务器
  2. irtu-gps 基于iRTU项目,实现GPS数据的接收和展示

社区互助

如果您在使用的过程中碰到问题,可以通过下面几个途径寻求帮助,同时我们也鼓励资深用户给新人提供帮助。

  1. 加入QQ群:830015805
  2. Email:zhengjunweimail@163.com
  3. 开源问答

参与贡献

我们非常欢迎您的贡献,您可以通过以下方式和我们一起共建

基于Java AIO实现的异步通信框架,smart-socket「终于解决」_https://bianchenghao6.com/blog_Java_第1张

  • 在您的公司或个人项目中使用 smart-socket。
  • 通过 Issue 报告 bug 或进行咨询。
  • 提交 Pull Request 改进 smart-socket 的代码。
  • 在开源中国发表smart-socket相关的技术性文章。

更新:

smart-socket 是一个 AIO 通信框架,可以快速、轻松地开发 Client/Server 网络应用程序。它大大简化了网络编程难度和复杂度,可广泛应用与各类TCP/UDP的通信场景。

smart-socket 是从许多协议(Http、WebSocket、MQTT、二进制私有协议)的实践中积累了大量宝贵经验,从而凝练成了一款极简、易用、高性能的通信框架。

极简

  • 支持各种传输类型、协议,且仅围绕着两大核心接口(MessageProcessor、Protocol)编程开发。
  • 灵活且可扩展的状态机设计,可以清晰地分离关注点。
  • 核心包代码 1500行,编译后的jar包仅 44kb(如果对此无明显感触,可以比较其他同类项目)。

易用

  • 文档丰富的 Javadoc 、用户指南和示例。
  • 没有额外的依赖,只要求JDK 8及以上版本。
  • 高度可定制化的插件。已内置一些非常实用且开箱即用的插件:SSL/TLS通信、心跳、断链重连、服务指标统计、黑名单、内存池监测。

高性能

  • 更好的吞吐量,更低的延迟
  • 更少的资源消耗
  • 最尽肯能减少不必要的内存拷贝

更新内容

  1. 引入 BufferFactory 的设计简化客户端/服务端内存池的配置。
  2. 完成 SSL/TLS 通信能力的插件化改造,彻底废除了SslAioSession、AioSSLQuickServer、AioSSLQuickClient。
  3. 服务端 AioQuickServer 支持共享外部内存池。即一个进程中启动多个服务端或者客户端,可以共用同一个内存池,提升资源利用率。
  4. 调整 NetMonitor 的接口设计。
  5. 默认禁用内存池。对性能无极致要求的场景可忽略内存池,降低学习成本。

Maven

<dependency>
    <groupId>org.smartboot.socket</groupId>
    <artifactId>aio-pro</artifactId>
    <version>1.4.10</version>
</dependency>

性能测试

  • 环境准备测试项目:smart-http通信协议:Http压测工具:wrk测试机:MacBook Pro, 2.9Ghz i5, 4核8G内存测试命令:wrk -H 'Host: 10.0.0.1' -H 'Accept: text/plain,text/html;q=0.9,application/xhtml+xml;q=0.9,application/xml;q=0.8,*/*;q=0.7' -H 'Connection: keep-alive' --latency -d 15 -c 1024 --timeout 8 -t 4 http://127.0.0.1:8080/plaintext -s pipeline.lua -- 16
  • 测试结果:smart-socket的性能表现基本稳定维持在 100MB/s 左右。连接数Requests/secTransfer/sec512775909.66108.03MB1024748988.74104.29MB2048728809.24101.48MB4096732603.27102.01MB

发表回复