java拦截器项目应用_使用拦截器分析Java EE应用程序的性能下降/提高

java拦截器项目应用

在开发具有某些性能要求的Java EE应用程序时,必须在每个发行版之前验证是否满足这些要求。 您可能会想到,哈德森的一项工作每天晚上在某些特定的硬件平台上执行一系列测试测量。

您可以检查已实现的时间并将它们与给定的要求进行比较。 如果测量值偏离要求太多,则可以中断构建或至少向团队发送电子邮件。

但是,您如何衡量代码的执行时间呢? 最初的想法可能是在您的代码库中添加数千个时间测量代码。 但这不仅是很多工作,而且还会影响代码的性能,因为现在时间测量也已在生产中执行。 为了摆脱许多插入,您可能需要利用面向方面的框架(AOP),该框架引入了用于在编译时进行时间测量的代码。 使用这种方式,您至少可以拥有两个版本的应用程序:一个有版本,一个没有额外的开销。 要在某些生产现场评估性能,仍然需要重新部署代码。 而且,您必须确定在编译时已经要观察的方法。

因此,Java EE提供了一种易于使用的替代方案:拦截器。 这是当时控制模式反转发挥其优势的原因。 当Application Server调用bean方法/ Web服务调用时,它很容易拦截这些调用,并为您提供了在每次调用之前和之后添加代码的方式。

这样,使用拦截器就相当容易了。 您可以在目标方法或引用拦截器实现的类中添加注释,也可以使用部署描述符添加拦截器:

@Interceptors(PerformanceInterceptor.class)
public class CustomerService {
...
}

部署描述符中提供的相同信息如下所示:

<interceptor-binding><target-name>myapp.CustomerService</target-name><interceptor-class>myapp.PerformanceInterceptor.class</interceptor-class>
</interceptor-binding>

拦截器本身可以是简单的POJO类,其方法带有@AroundInvoke和一个参数:

@AroundInvoke
public Object measureExecutionTime(InvocationContext ctx) throws Exception {long start = System.currentTimeMillis();try {return ctx.proceed();} finally {long time = System.currentTimeMillis() - start;Method method = ctx.getMethod();RingStorage ringStorage = RingStorageFactory.getRingStorage(method);ringStorage.addMeasurement(time);}
}

在try块之前和finally块中,我们添加了用于时间测量的代码。 从上面的代码可以看出,我们还需要一些内存中的位置来存储最后的测量值,以便计算例如平均值和与平均值的偏差。 在此示例中,我们有一个简单的环形存储实现,该实现会在一段时间后覆盖旧值。

但是如何将这些价值观暴露给外界? 由于通过JMX接口公开了Application Server的许多其他值,因此我们可以实现一个简单的MXBean接口,如以下代码片段所示:

public interface PerformanceResourceMXBean {long getMeanValue();
}public class RingStorage implements PerformanceResourceMXBean {private String id;public RingStorage(String id) {this.id = id;registerMBean();...}private void registerMBean() {try {ObjectName objectName = new ObjectName("performance" + id + ":type=" + this.getClass().getName());MBeanServer platformMBeanServer = ManagementFactory.getPlatformMBeanServer();try {platformMBeanServer.unregisterMBean(objectName);} catch (Exception e) {}platformMBeanServer.registerMBean(this, objectName);} catch (Exception e) {throw new IllegalStateException("Problem during registration:" + e);}}@Overridepublic long getMeanValue() {...}...
}

现在,我们可以启动jconsole并查询暴露的MXBean的平均值:

控制台

编写一个小的JMX客户端应用程序,例如将采样值写入CSV文件,使您以后可以处理这些值并将它们与以后的测量值进行比较。 这使您可以大致了解应用程序性能的发展。

结论

通过使用拦截器,可以轻松地通过部署描述符性能评估功能向现有Java EE应用程序动态添加功能。 如果通过JMX公开了测量值,则可以在以后应用这些值的进一步处理。

翻译自: https://www.javacodegeeks.com/2014/09/analysing-the-performance-degradationimprovements-of-a-java-ee-application-with-interceptors.html

java拦截器项目应用

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

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

相关文章

iis web.config 配置 经典模式_django部署在iis下,webconfig错误

django部署在iis下&#xff0c;webconfig错误错误原因&#xff1a;iis7以后&#xff0c;web.config管理机制更安全了默认情况下&#xff0c;会锁住配置项&#xff0c;不许修改怎么办&#xff1f;如何求解以上问题呢&#xff1f;D:django_websiteshello>%windir%C:Windows 不…

如何在Java中验证电话号码(正则表达式+ Google libphonenumber)

关于如何在不同国家&#xff08;例如美国&#xff0c;美国&#xff09;使用Java验证电话号码的快速指南。 带有正则表达式和Google libphonenumber API的示例程序。 1.简介 在本教程中&#xff0c;我们将学习如何在java中验证电话号码 。 这主要是为了验证美国和印度的国家/地…

mysql该账户已存在_mysql 查看函数的所属用户和已存在的函数

复现方式&#xff1a;Delete FROM user Where Usertest and Host%;flush privileges;修复流程&#xff1a;1.用root用户删除两个函数&#xff0c;语句分别为DROP FUNCTION IF EXISTS currval;DROP FUNCTION IF EXISTS nextval;2.然后用程序用户(sharding_slave)创建函数&#x…

joo工作流_不要错过使用jOOλ或jOOQ编写Java 8 SQL单行代码的机会

joo工作流越来越多的人通过为他们的业务采用功能性编程来赶上我们平台的最新更新。 在Data Geekery &#xff0c;我们将Java 8用于jOOQ集成测试&#xff0c;因为将新的Streams API与lambda表达式一起使用使生成临时测试数据变得非常容易。 但是&#xff0c; 我们并不认为JDK提…

session mysql登录实现_PHP+MYSQL+MYSQL+SESSION实现用户登录的实例

这是我写的用户登录界面。session_start();include(menu2.php);require(configywcl.php);//加载配置文件require(functions.php);?>请登录系统if ($username){$passwordmd5($password);$sql"select * from user where username$username and password$password";…

使用OpenSSL加密,使用Java解密,使​​用OpenSSL RSA公钥

抽象 在2017年&#xff0c;我撰写了一个由三部分组成的系列文章&#xff0c;内容涉及选择最佳的哈希和加密算法。 在对该系列进行研究时&#xff0c;我学到了很多有关哈希和加密的知识。 我学到的最重要的事情是&#xff0c;尽管我必须对如何使用最安全的算法进行自我教育&…

axture动画原型制作_Axure制作原型-基础操作

产品原型从类型可以分为手稿、线框图、低保真、高保真几种效果&#xff0c;在制作的时候分为不同场景来决定我们的输出物类型。比如在会议中为了快速的确定产品规划方向&#xff0c;迅速的记录及表达出当前灵感的碰撞&#xff0c;这个时候通常使用手稿的形式快速绘制&#xff0…

有效Java第三版的源代码已更新为使用较新的功能

那些已经阅读了有效Java 第三版的人可能知道与该书相关的源代码可以在GitHub上获得 。 jbloch / efficiency-java-3e-source-code项目拥有1700多个星星&#xff0c;截至撰写本文时&#xff0c;它已被分叉了近800次。 在有效Java的第三版中&#xff0c; Java的版本主要是JDK 8&a…

mysql 远程连接取消权限_MYSQL远程登录权限设置

Mysql默认关闭远程登录权限&#xff0c;如下操作允许用户在任意地点登录&#xff1a;1. 进入mysql&#xff0c;GRANT ALL PRIVILEGES ON *.* TO root% IDENTIFIED BY WITH GRANT OPTION;IDENTIFIED BY后跟的是密码&#xff0c;可设为空。2. FLUSH privileges; 更新Mysql为了安…

spring和spring_Spring WebApplicationInitializer和ApplicationContextInitializer的混淆

spring和spring我偶尔会混淆这两个概念-WebApplicationInitializer和ApplicationContextInitializer&#xff0c;并希望描述它们中的每一个&#xff0c;以便为我自己澄清它们。 我以前曾在这里写过有关WebApplicationInitializer的博客。 它仅在符合Servlet 3.0规范的Servlet容…

mybatis mysql demo_SpringBoot(入门Demo,整合mybatis,连接mysql)

1.简介SpringBoot提供一种固定的、约定优于配置风格的框架&#xff0c;使开发者更快地创建基于spring的应用和程序。可以高效的创建基于Spring的应用服务(SpringBoot不是对spring功能的增强&#xff0c;而是可以更快速使用spring)。为微服务spring cloud铺路&#xff0c;可整合…

HttpClient 4 API –获取状态码-getStatusLine()。getStatusCode()示例

在HttpClient API中获取状态代码的快速指南。 getStatusLine&#xff08;&#xff09;。getStatusCode&#xff08;&#xff09;示例和相关的错误。 1.简介 在这个非常快速的教程中&#xff0c;我将展示如何使用HttpClient 4获取和验证HTTP响应的StatusCode。 2. Maven依赖 要…

css table嵌套内部table不受外部影响_HTML+CSS网页一揽子(4)

CSS重要属性之浮动基本属性&#xff1a;float:left&#xff1b;左浮动float:right&#xff1b;右浮动float:none&#xff1b;不浮动(一般应用于覆盖既有浮动属性时使用)clear:both&#xff1b;清除浮动对其他元素带来的影响应用场景&#xff1a;(1)网站大的结构布局&#xff1a…

ejb构建_如何使用单例EJB和MBean构建和清除参考数据缓存

ejb构建在我的一个项目中&#xff0c;我需要使用EclipseLink作为ORM框架从Java EE 6 WebLogic环境中的多个源中加载参考数据。 由于我在Java EE世界中找不到与Spring YET的Cacheable相当的注释&#xff0c;因此我不得不编写自己的缓存解决方案。 尽管参考数据几乎不会随时间变化…

mysql ticks_【原创】C# 计时周期数(Ticks)在不同数据库上的实现

动手之前&#xff0c;先来看看 Ticks 在微软官方文档上的定义&#xff1a;注解一个计时周期表示一百纳秒&#xff0c;即一千万分之一秒。1 毫秒内有 10,000 个计时周期&#xff0c;即 1 秒内有 1,000万个计时周期。此属性的值表示自0001年1月1日午夜12:00:00 0:00:00 (公历日期…

在Spring Boot测试中使用Testcontainer进行数据库集成测试

在此博客文章中&#xff0c;我想演示如何在Spring Boot测试中集成Testcontainer以便与数据库一起运行集成测试。 我没有使用Testcontainers的Spring Boot模块。 如何与他们合作&#xff0c;我将在另一篇博客文章中进行介绍。 所有示例都可以在GitHub上找到 。 为什么要使用测试…

php模块安装 pdo_mysql_关于php插件pdo_mysql的安装

今天在做一个商城的连接的时候&#xff0c;需要MpDO验证。需要安装pdo_mysql模块&#xff0c;刚开始按照php扩展模块的安装按照这个安装ZIP,curl都成功了但是安装pdo_mysql却不行&#xff0c;在./configure --with-php-config/usr/local/php/bin/php-config是出现错误。如下che…

java8串行和并行的区别_垃圾收集器–串行,并行,CMS,G1(以及Java 8中的新增功能)...

java8串行和并行的区别4个Java垃圾收集器–错误的选择如何严重影响性能 在2014年&#xff0c;对于大多数开发人员来说&#xff0c;还有两件事仍然是个谜&#xff1a;垃圾收集和了解异性。 由于我对后者知之甚少&#xff0c;所以我认为我会对前者大吃一惊&#xff0c;尤其是因为…

python函数参数学习_python学习笔记-11.函数参数和返回值进阶

1. 函数参数和返回值的作用函数根据有没有参数以及有没有返回值&#xff0c;可以相互组合&#xff0c;共有4种形式&#xff1a;无参数&#xff0c;无返回值无参数&#xff0c;有返回值有参数&#xff0c;无返回值有参数&#xff0c;有返回值定义函数时&#xff0c;是否接收参数…

java spr_Java中的42行代码中的URL缩短器服务(Java(?!)Spring Boot + Redis

java spr显然&#xff0c;编写URL缩短服务是新的“ Hello&#xff0c;world&#xff01; ”在IoT /微服务/时代的世界中。 一切始于在45行Scala中的URL缩短服务 -整洁的Scala&#xff0c;以Spray和Redis进行调味以进行存储。 紧随其后的是&#xff0c; 在35行Clojure中提供了ur…