您现在的位置是:首页 > 文章详情

smart-socket 1.4.10 发布,SSL/TLS 插件化改造

日期:2020-04-25点击:491

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>

性能测试

  • 环境准备

    1. 测试项目:smart-http
    2. 通信协议:Http
    3. 压测工具:wrk
    4. 测试机:MacBook Pro, 2.9Ghz i5, 4核8G内存
    5. 测试命令:
     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/sec Transfer/sec
    512 775909.66 108.03MB
    1024 748988.74 104.29MB
    2048 728809.24 101.48MB
    4096 732603.27 102.01MB
原文链接:https://www.oschina.net/news/115166/smart-socket-1-4-10-released
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章