小研究 - J2EE 应用服务器的软件老化测试研究

软件老化现象是影响软件可靠性的重要因素,长期运行的软件系统存在软件老化现象,这将影响整个业务系统的正常运行,给企事业单位带来无可估量的经济损失。软件老化出现的主要原因是操作系统资源消耗殆尽,导致应用系统的性能下降甚至崩溃或宕机。文中监测J2EE 应用服务器系统资源的使用情况,考虑外界的负载变化,检测系统中软件老化现象,分析系统资源消耗何时达到临界值,从而帮助软件工程人员及时采取预维护手段,预防运行时系中重大故障的发生。

目录

1  引 言

2  J2EE 应用服务器老化测试和分析

2.1  实验环境

2.2  J2EE 应用服务器的老化测试

3  结束语


1  引 言

大型软件系统在持续平稳运行一段时间之后,系统资源大量消耗,服务性能和质量下降甚至挂起或宕机,称为软件老化现象。软件老化可能造成安全关键系统的重大损失,甚至人员伤亡。引起软件老化的原因有内存泄漏、各种类型的逻辑错误、致命的安全缺陷、死锁、状态冲突等。

目前,很多计算系统中已经检测到软件老化现象。文件系统中存在软件老化现象,发现存储空间碎片较多的文件系统存取吞吐量较正常情况下降低 40%。文献中,第一次提出了基于测量方法估测软件老化情况,首先监测导致系统低效或宕机的资源,如内存使用、交换区使用、CPU 占用率、空闲通信通道等,然后用统计学模型估算和验证软件老化,根据不同的策略决定是否及何时进行软件维护。文献中,采用统计模式识别方法,检测在线事务处理服务器系统中的软件老化现象。文中,以响应时间和响应率为系统性能的衡量依据,考虑负载变化因素,提出 Web 服务器系统中软件老化的检测方法。文献中,通过收集 Apache Web 服务器中对换区数据、内存使用量以及响应时间等信息,利用非参数统计学方法进行老化预测。通过收集 Web 服务器中的资源使用参数,发现系统性能逐步下降,然后计算系统平均负载时间序列的最大李亚普诺夫指数,证明系统的老化现象具有混沌性。针对 SunHotSpot Java 虚拟机系统,考察系统负载对老化的影响以及系统内存资源和吞吐量的变化,采用统计分析的方法评估系统的老化趋势。一种基于AOP(Aspect - Oriented Programming)技术的系统性能监测机制,通过监测服务器系统中每个组件的资源使用情况,从而分析判定引起软件老化的组件。文献分析并研究云计算系统中存在软件老化现象的影响因素,通过监测系统虚拟内存和物理内存的使用情况,发现系统内存资源逐渐消耗、CPU 占有量逐步增加,并且系统响应时间随之增长。此外,常用软件如Netscape 和 XRN 中也存在软件老化现象。

2 J2EE 架构的应用服务器系统

应用服务器是中间件最大的一个分支,其基于组件的中间层集成框架,为组件的运行提供运行时环境、基础服务和管理等功能。应用服务器位于企业应用与操作系统之间,屏蔽底层操作系统、网络以及数据库的异构性和复杂性,通过组件容器方式提供应用部署、运行平台。图 1 是一个基于 J2EE 平台的应用服务器结构示意图。客户端向应用服务器端提交服务请求,负载分配器根据服务请求的类型分配到合适的 HTTP 服务器上,然后将服务请求转交给应用服务器上,该应用服务器查询数据库,分析处理服务请求后将结果返回给客户端。J2EE 架构的应用服务器建立在 JVM(Java虚拟机)之上,JVM 的内存泄露是导致应用服务器老化的一个重要原因,因此需要对 JVM 的内存管理与内存泄漏进行分析。

JVM 内存区域,也叫运行时数据区,分为方法区、堆、栈、寄存器、本地码栈,在 JVM 运行程序时,存储字节码、对象、参数、返回值局部变量以及中间结果等数据。内存堆用来存放 Java 程序运行时创建的类实例或数组。每个虚拟机实例中只存在一个堆空间。JVM可以为新对象分配内存,但释放内存的任务由垃圾回收机制完成。垃圾回收机制回收不再被引用的无用对象,即当一个对象不再被引用的时候,内存回收它占用的空间,以便腾出空间被后来的新对象使用。但是有些可达的无用对象也可能成为不能回收的垃圾对象,如图 2 所示,垃圾回收机制这种潜在的缺陷造成内存泄漏的出现。

内存泄漏问题如果不加解决,随着时间的积累,造成 JVM 的内存使用量的持续增加,当 JVM 内存使用达到其最大堆栈大小时,JVM 自动的垃圾回收机制会进行垃圾收集。但每次执行垃圾收集后,无用对象所占的内存释放的百分比相对较小,最终会导致 JVM 连续地进行垃圾回收,占用大量的 CPU 时间,即 CPU 使用率持续增加。而系统资源是有限的,JVM 内存和 CPU使用率持续增加,最终将导致系统低效或宕机等老化现象。因此,需要专门的工具来实现 JVM 内存监测,提取内存相关信息,程序开发者能比较容易地判断程序是否有内存泄漏及其产生的原由,从而更好地进行软件老化现象的分析。

2  J2EE 应用服务器老化测试和分析

2.1  实验环境

测试的实验环境包括 J2EE 应用服务器和数据库服务器,运行在同一个局域网内,通过 100 Mbps 局域网连接,每个机器的配置为 P4 2. 4 G Intel CPU,运行环境采用 Sun JDK Hotspot 1. 4. 1_02 - b06。测试时首先在 IBM 的应用服务器 Websphere Application Server5. 1 上部署测试用例 Petstore 1. 3. 1 - 02,同时模拟多用户请求的应用客户端远程调用 EJB 模块中业务逻辑方法,业务逻辑方法包括了对数据库服务器中的数据的增加、删除、更新等操作,数据库系统是 IBM 的CloudScape4. 0。客户端负载发生器开始发送 SOAP/HTTP 服务请求时,在客户端实时地记录响应时间等系统性能参数信息,同时激活服务器端 Tivoli 性能查看器,记录应用服务器动态参数,基本的调用过程如图3 所示。负载发生器尽量模拟用户真实情况,采用一个星期为一个周期的形式,区分实际情况工作日和休息日的各个时段负载密度不同,模拟客户在某个小时间段内服从泊松分布,产生泊松序列的种子可自己设定。

数据采集工具使用 WAS 自带的 Tivoli 性能查看器(Tivoli Performance Viewer),它可以监控系统资源的使用情况,也可以从 WAS 内部获取 J2EE 架构的服务器中相关参数。采集的数据来自四个模块:JVM 运行时模块,提取 JVM 内存的总大小和使用内存的大小;系统数据模块,提取 CPU 使用率和系统可用内存;Web 线程模块,提取创建的线程总数、破坏的线程总数、并发活动的线程数及线程池的大小;事务管理器,提取开始的全局事务、活动的全局事务、全局事务持续时间及全局事务回滚等。其中,JVM 运行时模块和系统数据模块是最为重要的两个模块。Tivoli 性能查看器和 WAS 同时运行在应用服务器上,占用系统部分资源,采用这种方法得到的老化预测模型实际上是数据采集软件和 J2EE 应用服务器的老化现象叠加。由于Tivoli 性能查看器占用的系统资源很少,影响程度可以忽略,可把结果看作是 J2EE 应用服务器老化的结果。

2.2  J2EE 应用服务器的老化测试

为了测试 J2EE 应用服务器中是否存在软件老化现象,分析导致应用服务器老化的原因,设计了不同强度的负载情况,监测应用服务器的运行时参数情况,并进行老化分析。这里,单位时间发送请求的数量和平均服务持续时间是影响负载强度的两个重要因素。应用服务器的负载峰值是指应用服务器在单位时间内能够响应的最大用户数量。首先在较短周期内向服务器发送等值强度的请求任务,同时在客户端记录响应时间等参数信息,若客户端的请求全部得到响应,则增加负载强度,直到出现应用服务器无法响应所有请求时停止,此时的负载强度即为负载峰值。在老化测试时,根据服务器负载峰值设计发送请求的负载强度。

1)重负载测试。

重负载测试中,平均负载强度设定为负载峰值的30%,其中负载任务高峰期时的负载强度设定为负载峰值的 50%。JVM 内存使用量的初始大小为 128 M,最大值为 256 M。如图 4 所示,随着系统运行时间的推移,应用服务器系统内存使用量逐步增加,最终系统在运行 43 小时后,JVM 内存使用量临近 256 MB,导致JVM 内存资源不足而出现宕机,此时系统无法响应客户端请求。图 4 中内存使用量变化呈锯齿状,是 JVM垃圾回收机制作用的结果,当可用内存出现暂时不足,不能满足程序的内存需求时,系统将自动调用垃圾回收机制,释放更多的可用内存空间。然而,随着应用服务器的长期运行,其性能不断下降,JVM 自动内存管理机制所起的作用越来越小,最终导致系统宕机。

为验证应用服务器是否存在老化现象,即系统性能是否随时间的推移而缓慢下降,采用一元线性回归方法,分析 JVM 内存使用量 Y(单位:kB)和应用服务器运行时间 X(单位:min)的关系,得到式(1)描述的拟合直线方程。

Y = 25.852 7*X + 137 920 (1)

式(1)中回归直线的斜率为正,表示 JVM 内存使用量随着应用服务器运行时间的推移而增加,应用服务器存在老化现象。

2)轻负载测试。

轻负载测试中,平均负载强度和负载任务高峰期时的负载强度都设定为重负载测试中的 20%。应用服务器 JVM 内存使用情况如图 5 所示。

图 5 轻负载情况下应用服务器 JVM 内存使用量从图中可以看出,与重负载老化测试时情况相似,JVM 内存使用占250 M 左右时,应用服务器宕机,无法响应客户端请求,此时系统运行 140 小时。可得到内存使用量与服务器运行时间的一元线性关系式:

Y =11.736 5 * X +139 380 (2)

式(2)中回归直线的斜率为正,意味着内存耗尽引起服务器系统出现软件老化。此外,轻负载老化测试中负载强度减少,应用服务器运行时间增加三倍,可见负载强度是影响软件老化的主要因素。

3)延长平均服务持续时间的老化测试。此次老化测试中,平均服务持续时间为原来的六倍,且单位时间内发送请求的数量与轻负载测试中相同。应用服务器 JVM 内存使用情况如图 6 所示。

与前两种老化测试情况相同,JVM 内存使用量在250 M 左右时,应用服务器系统运行 8 小时后宕机,此时系统无法响应客户端请求。JVM 内存使用量与应用服务器运行时间的一元线性关系如式(3)。

Y =174.847 2 * X + 160 260 (3)

式(3)中回归直线的斜率为正,且斜率较上述两种情况增幅较大。这是因为延长服务持续时间,意味着应用服务器中 EJB 容器需为用户较长时间保留系统资源,这将加速耗尽应用服务器的系统资源,从而加快软件老化速度。

3  结束语

文中监测 J2EE 应用服务器系统中的资源使用情况,考虑外界负载变化,收集系统资源消耗的数据,检测系统的老化现象,分析系统资源消耗何时达到临界值,以帮助软件工程人员及时采取预维护手段,预防运行时系统中未来重大故障的发生。

下一步工作包括对系统老化机理和软件再生随机模型的研究。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/111285.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

读书笔记——《万物有灵》

前言 上一本书是《走出荒野》,太平洋步道女王提到了这本书《万物有灵》,她同样是看一点撕一点的阅读。我想,在她穿越山河森林,听见鸟鸣溪流的旅行过程中,是不是看这本描写动物有如何聪明的书——《万物有灵》&#xf…

YOLOv5引入FasterNet主干网络,目标检测速度提升明显

目录 一、背景介绍1.1 目标检测算法简介1.2 YOLOv5简介及发展历程 二、主干网络选择的重要性2.1 主干网络在目标检测中的作用2.2 YOLOv5使用的默认主干网络 三、FasterNet简介与原理解析3.1 FasterNet概述3.2 FasterNet的网络结构3.2.1 基础网络模块3.2.2 快速特征融合模块3.2.…

docker network

docker network create <network>docker network connect <network> <container>docker network inspect <network>使用这个地址作为host即可 TODO&#xff1a;添加docker-compose

最新企业网盘产品推荐榜发布

随着数字化发展&#xff0c;传统的文化存储方式已无法跟上企业发展的步伐。云存储的出现为企业提供了新的文件管理存储模式。企业网盘作为云存储的代表性工具&#xff0c;被越来越多的企业所青睐。那么在众多企业网盘产品中&#xff0c;企业该如何找到合适的企业网盘呢&#xf…

idea上利用JDBC连接MySQL数据库(8.1.0版)

1.了解jdbc概念 JDBC(Java DataBase Connectivity,java数据库连接)是一种用于执行SQL语句的Java API&#xff0c;可以为多种 关系数据库提供统一访问&#xff0c;它由一组用Java语言编写的类和接口组成。JDBC提供了一种基准&#xff0c;据此可以构建 更高级的工具和接口&#…

顺序表链表OJ题(1)——【LeetCode】

W...Y的主页 &#x1f60a; 代码仓库分享 &#x1f495; 前言&#xff1a; 今天我们来回顾一下顺序表与链表&#xff0c;针对这一块我们也有许多OJ题目供大家参考。当我们学习完顺序表链表后避免不了一些习题的练习&#xff0c;这样才能巩固我们学习的内容。 话不多说&#xf…

Javaweb基础学习(4)

Javaweb基础学习&#xff08;4&#xff09; 一、JSP学习1.1 JSP的简介概述1.2 JSP快速入门1.3 JSP原理1.4 JSP脚本1.5 JSP缺点1.6 EL表达式1.7 JSL标签1.7.1 JSL快速入门 1.8 MVC 模式和三层架构1.9 三层架构 三、会话跟踪技术3.1 会话跟踪技术介绍3.2 Cookie的基本使用3.3、Co…

python-图片之乐-ASCII 文本图形

ASCII&#xff1a;一个简单的字符编码方案 pillow模块&#xff1a;读取图像&#xff0c;访问底层数据 numpy模块&#xff1a;计算平均值 import sys, random, argparse import numpy as np import math from PIL import Image定义灰度等级和网格 定义两种灰度等级作为全局值…

Linux环境离线安装MySQL8.0.33

目录 一、准备 1、检查libaio.so.1 2、卸载删除原有的mariadb 3、删除my.cnf 4、下载mysql安装包 二、安装 1、上传mysql 2、建立mysql所需目录 3、建立配置文件my.cnf 4、创建mysql用户并授权 5、初始化数据库 6、启动MySQL数据库 7、常见启动报错处理 8、配置M…

VMware标准虚拟交换机和分布式交换机

一、虚拟交换机 初期的网络虚拟化&#xff0c;是非常狭义的概念&#xff0c;主要指的是因为计算资源虚拟化&#xff0c;每台物理宿主机上安装了虚拟化软件&#xff0c;同时会部署了虚拟交换机&#xff0c;负责物理机上面承载的VM&#xff08;虚拟机&#xff09;之间与对外的通…

用心维护好电脑,提高学习工作效率

文章目录 一、我的电脑1.1 如何查看自己的电脑硬件信息呢&#xff1f; 二、电脑标准保养步骤和建议2.1 保持清洁2.2 定期升级系统和软件2.3 安全防护2.4 清理磁盘空间2.5 备份重要数据2.6 优化启动项2.7 散热管理2.8 硬件维护2.9 电源管理2.10 注意下载和安装2.11 定期维护 三、…

数据结构:单向循环链表

单向循环链表和单向链表差不多&#xff0c;只需要记录头节点的位置把单向链表判断NULL的地方改为判断头节点即可 dxxhlb.h dxxhlb.cmain.c 结果

聚类分析 | MATLAB实现基于AHC聚类算法可视化

聚类分析 | MATLAB实现基于AHC聚类算法可视化 目录 聚类分析 | MATLAB实现基于AHC聚类算法可视化效果一览基本介绍程序设计参考资料 效果一览 基本介绍 AHC聚类算法&#xff0c;聚类结果可视化&#xff0c;MATLAB程序。 Agglomerative Hierarchical Clustering&#xff08;自底…

ArrayList与顺序表

文章目录 一. 顺序表是什么二. ArrayList是什么三. ArrayList的构造方法四. ArrayList的常见方法4.1 add()4.2 size()4.3 remove()4.4 get()4.5 set()4.6 contains()4.7 lastIndexOf()和 indexOf(&#xff09;4.8 subList()4.9 clear() 以上就是ArrayList的常见方法&#xff01…

【科研论文配图绘制】task6直方图绘制

【科研论文配图绘制】task6直方图绘制 task6 主要掌握直方图的绘制技巧&#xff0c;了解直方图含义&#xff0c;清楚统计指标的添加方式 1.直方图 直方图是一种用于表示数据分布和离散情况的统计图形&#xff0c;它的外观和柱形图相近&#xff0c;但它所 表达的含义和柱形图…

串口联网通信数据监听视监控侦测协议规约破解方案

作为物联网数据采集解决方案专业提供商,数采物联网小编daq-iot 在这里做以下内容介绍,并诚挚的欢迎大家讨论和交流。 本方案主要用于监听和侦测 串口通信数据报文&#xff0c;主要用于协议报文分析 破解领域。 例如破解摄像头控制道闸开启的命令等。 监控和分析通信数据代表的含…

设计模式-职责链模式

文章目录 职责链模式模式概述主要角色适用场景实现步骤优点注意事项 定义职责链结构示例总结 职责链模式 职责链模式是一种行为设计模式&#xff0c;它可以将请求的发送者和请求的处理者解耦&#xff0c;并按照预定义的顺序处理请求。职责链模式常用于需要逐级审批或转交处理的…

网络编程——套接字和字节序

目录 一、BSD套接字接口1.1 套接字类型1.2 套接字的位置 二、字节序2.1 大小端2.2 大小端判断2.3 主机字节序和网络字节序2.4 字节序转换函数 一、BSD套接字接口 BSD套接字接口是BSD的进程间通信的方式&#xff0c;它不仅支持各种形式的网络应用而且它还是一种进程间通信的机制…

汽车类 ±0.25°C SPI 温度传感器,TMP126EDBVRQ1、TMP126EDCKRQ1、TMP127EDBVRQ1引脚配置图

一、概述 TMP126-Q1 是一款精度为 0.25C 的数字温度传感器 &#xff0c; 支持的环境温度范围为 -55C 至 175C 。TMP126-Q1 具 有 14 位 &#xff08; 有符号 &#xff09; 温度分辨率(0.03125C/LSB)&#xff0c;并且可在 1.62V 至 5.5V 的电源电压范围内工作。TMP126-Q1 具有转…

Linux-crontab使用问题解决

添加定时进程 终端输入&#xff1a; crontab -e选择文本编辑方式&#xff0c;写入要运行的脚本&#xff0c;以及时间要求。 注意&#xff0c;如果有多个运行指令分两种情况&#xff1a; 1.多个运行指令之间没有耦合关系&#xff0c;分别独立&#xff0c;则可以直接分为两个…