smart-socket 1.4.10 发布,SSL/TLS 插件化改造
smart-socket 是一个 AIO 通信框架,可以快速、轻松地开发 Client/Server 网络应用程序。它大大简化了网络编程难度和复杂度,可广泛应用与各类TCP/UDP的通信场景。
smart-socket 是从许多协议(Http、WebSocket、MQTT、二进制私有协议)的实践中积累了大量宝贵经验,从而凝练成了一款极简、易用、高性能的通信框架。
极简
- 支持各种传输类型、协议,且仅围绕着两大核心接口(MessageProcessor、Protocol)编程开发。
- 灵活且可扩展的状态机设计,可以清晰地分离关注点。
- 核心包代码 1500行,编译后的jar包仅 44kb(如果对此无明显感触,可以比较其他同类项目)。
易用
- 文档丰富的 Javadoc 、用户指南和示例。
- 没有额外的依赖,只要求JDK 8及以上版本。
- 高度可定制化的插件。已内置一些非常实用且开箱即用的插件:SSL/TLS通信、心跳、断链重连、服务指标统计、黑名单、内存池监测。
高性能
- 更好的吞吐量,更低的延迟
- 更少的资源消耗
- 最尽肯能减少不必要的内存拷贝
更新内容
- 引入 BufferFactory 的设计简化客户端/服务端内存池的配置。
- 完成 SSL/TLS 通信能力的插件化改造,彻底废除了SslAioSession、AioSSLQuickServer、AioSSLQuickClient。
- 服务端 AioQuickServer 支持共享外部内存池。即一个进程中启动多个服务端或者客户端,可以共用同一个内存池,提升资源利用率。
- 调整 NetMonitor 的接口设计。
- 默认禁用内存池。对性能无极致要求的场景可忽略内存池,降低学习成本。
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/sec Transfer/sec 512 775909.66 108.03MB 1024 748988.74 104.29MB 2048 728809.24 101.48MB 4096 732603.27 102.01MB
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Dcat Admin v1.2.0 发布,对后端开发友好的高颜值后台系统构建工具,开箱即用
Dcat Admin v1.2.0已发布,更新内容如下 功能新增及优化部分 集成editor-md作为内置markdown编辑器,并支持图片上传功能 表格过滤搜索增加panel布局方式 优化数据表格边框模式 工具表单增加buildSuccessScript方法 数据表格表头过滤器重置按钮优化 通过Form::action法设置url时自动拼接路由前缀 按钮样式优化 菜单配色及导航栏样式优化 快速创建功能样式优化 登陆页面优化 进度条样式优化 默认禁用滚动条插件 增加action以及`form生成命令对非`app`目录的支持 Bug修复部分 修复数据表格checkbox显示类型不兼容非数组字段值问题 修复登陆页面不兼容Laravel5.5问题 简介 Dcat Admin是一个基于laravel-admin二次开发而成的后台系统构建工具,只需很少的代码即可快速构建出一个功能完善的高颜值后台系统。内置丰富的后台常用组件,开箱即用,让开发者告别冗杂的HTML代码,对后端开发者非常友好。 在线演示站点|官方文档|Gitee主页|Github主页
- 下一篇
云服务器 ECS 建站教程:部署MySQL环境
在ECS上部署数据库 数据库是依照某种数据模型组织起来并存放二级存储器中的数据集合。这种数据集合具有如下特点:尽可能不重复,以最优方式为某个特定组织的多种应用服务,其数据结构独立于使用它的应用程序,对数据的增、删、改和检索由统一软件进行管理和控制. 阿里云有提供相应的高可用数据库架构RDS,但由于RDS具有一定的限制条件,可能无法满足部分生产环境的要求,例如需要使用Oracle数据库、需要使用SQL Server报表服务等,在这种情况下,我们需要考虑在ECS上搭建数据库的方式. 本文档介绍如何在云服务器ECS实例常用数据库(Oracle、MySQL、SQL Server)。 常用数据库简介 常用数据库包含以下三种:Oracle、MySQL、SQL Server; Oracle Oracle可以支持多种不同的硬件和操作系统平台,从台式机到大型和超级计算机,为各种硬件结构提供高度的可伸缩性,支持对称多处理器、群集多处理器、大规模处理器等,并提供广泛的国际语言支持。 Orcale是一个多用户系统,能自动从批处理或在线环境的系统故障中恢复运行。系统提供了一个完整的软件开发工具Developer...
相关文章
文章评论
共有0条评论来说两句吧...