Voovan 高性能异步网络框架和 WEB 服务器框架
Voovan 是一个高性能异步网络框架和WEB服务器框架,同时支持HTTP客户端抓取、动态编译支持、数据库访问封装以及DateTime、String、Log、反射、对象工具、流操作、文件操作、异步双向通道等功能。旨在提供可靠、方便、可单元测试的代码。它是极少依赖的独立工具包,希望能够方便广大开发者快速的实现应用。
极简并且优雅的编码是 Voovan 的宗旨和目标。
Maven 中央库支持
<dependency> <groupId>org.voovan</groupId> <artifactId>voovan-framework</artifactId> <version>4.3.8</version> </dependency>
Web 模块
- WebServer 对注解形式路由的支持, 类似一个轻量化的 Spring MVC
- WebServer 增加热部署支持, 修改类和 jar 中的类,无须重启 web 服务
- WebServer 增加扫描新类和 jar 到 ClassPath 的支持,新增类和 jar 无须重启 web 服务
- WebServer 路径变量抽取算法优化, 以获得性能提升
- WebServer 实现基于 redis 的 session 共享形式的集群
- WebServer 提供对基于 Websocket 协议的 socket.io 和 engine.io 的支持
Network 模块
- 提高了 Voovan 对于并发性能的支持,测试结果并发性能提升为10%-15%
- 优化ByteBufferChannel增加 shrink \ read \ write 的通用方法
- IoSession 的状态模型重构
- 增加心跳控制
Common 模块
- 新增时间轮定时任务,并且支持异步任务的方式,Voovan 内部所有定时器全部都替换为时间轮的方式,以提升性能
- 增加了动态编译以及沙盒对于加载类的安全控制
- 动态类的的支持,参见:org.voovan.tools.compiler.clazz.DynamicClass - 动态函数的的支持,参见:org.voovan.tools.compiler.function.DynamicFunction - 动态编译部分的沙盒安全支持: /Voovan/Common/src/main/resources/sandbox.properties
- 提供通用的热部署支持,使任何 JVM 应用都能够支持热部署, 参见: org.voovan.tools.hotswap.Hotswaper
JDK 支持
- 推荐使用 JDK1.8,懒人专用。
- 目前自2.0.1开始所有版本在发布前都会进行 jdk1.7的测试。
- 如果 WebServer 使用lambda 需要 JDK1.8,不使用 lambda 需要 JDK1.7。
- 有能力的同学可以通过很简单几行修改使 WebServer 和 HTTPClient使用 NIO 那么就是 JDK1.6。
框架特点介绍
- 使用 JDK8 的 lambda 表达式,快速实现 HTTP/WebSocket 服务的开发。【演示】/【TFB性能测试】
- 异步通信框架解决粘包问题,过滤器链等。
- 独立无依赖的代码。
- 源码注释丰富,方便码友学习、调试、使用。
一、高性能异步通信(NIO异步通信) [voovan-network]
类似 Netty 和 MINA 的异步 Socket 通信框架.但有有所不同。
- 可灵活解决Socket通信粘包的支持(源码中包含 HTTP协议,字符串换行,定长报文的粘包实现)。
- 支持 SSL/TLS 加密通信。
- 提供线程池依据系统负载情况自动动态调整。
- 采用非阻塞方式的异步传输。
- 事件驱动(Connect、Recive、Sent、Close、Exception),采用回调的方式完成调用。
- 可灵活的加载过滤器机制。
二、HTTP客户端和WEB服务器[voovan-web] HTTP客户端特性
- 基于 Voovan 异步通信框架实现。
- 客户端可以灵活自定义请求报文。
- 同步实现 HTTP请求(需要同步实现可参考)。
- 实现 WebSocket 客户端调用,可以连接任何支持 WebSocket Version 13的 WebSocket 服务。
WEB服务器特性 [voovan-web]
- 支持 WebSocket Version 13,并且保持 WebSocket请求参数。
- 使用 Lambda 实现更加方便的 Http 响应实现。
- 支持路径参数自动抽取 当路径定义/:name,在使用/jonh地址访问时,可以通过 name 参数获取 jonh 字符串。
- 重定向支持。
- 可灵活实现session共享。
- 异常统一展示支持。
- MIME 配置支持。
- 支持基于 HTTP1.1 的 HTTPS 访问,默认采用TLS模式.
- 支持性能监控. [HTTP服务端性能监控演示]
三、动态编译支持 [voovan-common]
在内存中编一个保存有 java 代码的字符串,并将编译后的 byte 字节加入到 classloader 中,可灵活的动态定义类和使用。
四、数据库操作帮助类 [voovan-database]
提供类似Spring JDBCTemplate 的数据访问支持,但提供了更好更灵活易用的函数设计。
- 支持的参数类型:
- Map 参数
- 不定参数
- 对象作为参数
- 支持存储过程调用。
- 支持批量更新。
- 数据库事务的支持。
- 支持自动移除无匹配参数的条件。
- 结果转换对象的时候使用模糊匹配。
五、DateTime、String、Log、反射、对象工具、流操作、文件操作、异步双向通道等 [voovan-common]
- 简单的 JSON 序列化和反序列化,效率比不过专业的序列化工具(如:FastJson),但重在轻量级好用。
- 日期类型和字符串和日期类型互转,日期类型加减操作。
- 反射的快捷实现,可直接通过反射取属性值,调用方法,实例化对象,判断类的继承及实现。
- 简单的日志记录类,支持指定输出流,日志报文自定义等。
- 简单的自推导的对象类型强制转换,根绝参数类型,运算类型自动退定强制转换类型。
- 流操作,读取定长、按行读取、基于byte的split操作等。
- 使用 ByteBuffer 实现的一个双向通道。
- 属性文件操作。
- 文件路径拼接、从绝对路径读取、从相对路径读取、从包路径读取、指定起始和结束位置内容读取等。
- List 和 Map 的快速初始化。
- 热部署
- 动态函数和类
包结构说明
包名 | 名称 |
---|---|
org.voovan.db | 数据库操作类 |
org.voovan.http | HTTP工具包 |
org.voovan.dynamicComplier | 动态编译包 |
org.voovan.network | 网络异步通信包 |
org.voovan.tools | 基本工具包 |
Voovan 在异步通信的范畴内的同类框架
- t-io: 长连接异步通信框架,提供心跳和连接保持的支持.
- netty: 老牌异步通信框架和voovan有面对相同的场景, 两者相比的话 voovan 开发更易上手,针对 Socket 通信中粘包的处理 Voovan 提供了更加优雅的方式.
大家可以根据自己的需要适应的场景选择不同框架。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论