activej框架学习伊始——综述

2023-10-12 14:50

本文主要是介绍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创作者一般。

这篇关于activej框架学习伊始——综述的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/196543

相关文章

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

Python的端到端测试框架SeleniumBase使用解读

《Python的端到端测试框架SeleniumBase使用解读》:本文主要介绍Python的端到端测试框架SeleniumBase使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录SeleniumBase详细介绍及用法指南什么是 SeleniumBase?SeleniumBase

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

C++ HTTP框架推荐(特点及优势)

《C++HTTP框架推荐(特点及优势)》:本文主要介绍C++HTTP框架推荐的相关资料,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Crow2. Drogon3. Pistache4. cpp-httplib5. Beast (Boos

SpringBoot基础框架详解

《SpringBoot基础框架详解》SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等,使用SpringBoot可以不用或者只需要很少的Spring配置就可以让企业项目快... 目录SpringBoot基础 – 框架介绍1.SpringBoot介绍1.1 概述1.2 核心功能2

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

Spring框架中@Lazy延迟加载原理和使用详解

《Spring框架中@Lazy延迟加载原理和使用详解》:本文主要介绍Spring框架中@Lazy延迟加载原理和使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、@Lazy延迟加载原理1.延迟加载原理1.1 @Lazy三种配置方法1.2 @Component

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1