activej框架学习伊始——综述

2021SC@SDUSC

前言

虽已学习编程已有一定时间,但却一直没能耐下性子来真正地阅读一份项目的源代码并对其进行解析。也借着这一次的课程机会,锻炼自己的阅读源代码能力并学习可以在github上收获star的项目的代码艺术。
那么说完这些,更重要的,是何为ActiveJ?

Java framework for modern web, cloud, high-load, and microservices solutions

这个是ActiveJ官方对于自己的定义是一个全功能的现代java平台,是用于现代网络、云、高负载和微服务解决方案的java框架,并以作为Spring/Mirconauts/Netty/Jetty的替代品为目标从头创建。老实说在写项目时常常能耳濡目染到spring使用的广泛,才更对ActiveJ这个项目的自信感到好奇。

而近期的web frameworks benchmark中也指出开源web框架中平均每秒处理请求数第一名的就是activej,无疑也验证了其自信的根本。下面可以是一些关于activej平均每秒处理请求的一些对比图:在这里插入图片描述

ActiveJ关键功能

如此快的平均每秒处理请求,所依靠的绝不只是某一算法的优化,而是由整体的各个部分的共同作用导致。
ActiveJ共分为以下8个主要模块:

Async-IO
———异步I/O处理 ,包含Promise,Eventloop,Net,具有高性能的事件循环、承诺和流协议的高性能异步IO。
HTTP
———高效的异步HTTP服务,并且可以作为独立的组件使用。适用于每秒处理数百万次的请求。
Inject
———轻量级的、强大的依赖注入库,具有极强的性能,没有第三方的依赖性。更对多线程友好。
Serializer
———基于注解的序列化,动态生成的序列化器。支持子类、集合的特殊集合。也是基于运行时字节码生成的世界最快JVM串行器。
Codegen
———排除复杂的直接字节操作的动态字节生成器 ,在ObjectWeb ASM库的基础上动态生成字节码。
Specializer
———由JVM优化而加速代码构建的ActiveJ技术,通过自动重写了类,用静态方法调用代替动态创新,提高类的运行性能。
FS
———远程文件操作的有力工具,是在普通文件操作之上的微小的的异步抽象。包括本地或远程文件存储,以及大数据的集群存储。
RPC
———在分布式应用和微处理领域的轻量而快速的二进制协议,是用于高负荷分布式应用的库。

项目分工

git clone https://github.com/activej/activej

在github上将源代码克隆下来后,并且下载相关的jar包之后,可以看到其中的代码分包如图所示:
在这里插入图片描述
其中我负责的部分主要为FSRPC两个部分,虽然接触的不多,但同样可以从其中的包名揣测出每一个部分的用途方便对其的理解:
在这里插入图片描述
而关于这些相关代码的分析将在之后的一学期逐渐展现。

结语

在缺乏阅读相关的源代码的情况下,加之网上有关activej框架的相关信息少之又少,为了保证有一定的路径可以帮助我顺利地对其进行理解并且对源码进行解析,也计划通过与其类似的springboot等类似框架的阅读代码流程一步步剖析activej,并且将其消化并在之后的项目开发中使用。
虽然现在activej还只是一个在github中300多star的开源项目,但有着如此豪言的web框架,实在是好奇它的未来发展。
毕竟,谁不想成为一个流行框架使用的先行以及优化者呢?
在activej已在benchmark中名列前茅的情况下,我也相信他的潜力能继续向前。还有什么能比成为未来流行框架的先行者更让人热血沸腾!
希望能在接下来的时间里用尽全力将activej生动形象地展示出来,为未来某天对activej有兴趣的读者指出一条更加方便快捷的路,正如千千万万个csdn创作者一般。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值