java ee的小程序_在Java EE应用程序中实现自动重试

java ee的小程序

最初,我想将此博客称为“ 具有拦截器驱动的重试策略灵活超时 ”,但后来我认为它太“繁重”。 该声明以及修改后的标题应该(希望)使您了解此帖子可能谈论的内容;-)

触发

这篇文章主要由我在较早的一篇文章中收到的评论/问题之一驱动,其中简短地讨论了超时机制以及如何使用它们为有状态和Singleton EJB定义“并发策略”。

题

问题

虽然超时是在EJB容器中强制执行并发策略和控制资源分配/使用的好方法,但是当超时不一致且不可预测时,就会出现问题。 那么,您如何配置超时策略呢?

当然,没有完美的解决方案。 但是,我想到的一项工作是“ 重试 ”失败的方法(这对于您的给定方案可能不适当或不可能,但如果用例允许,则可以应用)。 这是“ 跨领域 ”关注(换句话说就是“ 方面 ”)的一个很好的例子。 为此,Java EE的答案是– Interceptors 。 这些要比默认的“ 带有try-catch块的rinp-repeat-until-xyz ”更好,因为

  • 代码重用
  • 灵活性

要点(解决方案)

这是高级描述( 代码可在Github上获得 )

  • 定义一个简单的注释,表示“重试策略元数据”,例如重试次数

重试策略

  • 定义具有实现的重试器以重试目标方法-这将使用上述“重试策略”元数据并相应地执行操作

拦截器

  • 将此拦截器附加到所需的方法(调用方)

目标阶层

  • (可选)使用@InterceptorBinding

样例代码

  • 使用Singleton EJB模拟示例服务,并通过显而易见的Thread.sleep()引入延迟(当然,这在Java EE容器中是禁止的)
  • 使用JAX-RS资源,该资源注入并调用Singleton EJB,并且是根据“策略”进行“重试”的候选对象
  • 可以通过在任何兼容Java EE(6或7)的服务器上部署并使用Apache JMeter模拟并发客户端/请求进行测试(在http:// serverip:port / FlexiTimeouts / test上调用HTTP GET)

如果没有重试(拦截器)配置,则测试(针对并发请求)将导致HTTP超时(408)。

不用重试

一旦重试拦截器被激活,就会有一些延迟,因为一旦失败,任务将自动重试。 当然,这将取决于(并发请求的)数量,并且需要相应地调整阈值–对于高度并发的环境,阈值较高(通常,并非理想情况)

其他想法

  • 在代码中定义阈值或重试策略不是强制性的。 也可以将其外部化(以使事情更灵活),例如,使用@RetryPolicy指向包含所需策略元数据的文件
  • 重试阈值不是唯一可配置的属性。 您可以具有其他条件,并在拦截器逻辑中使用它
  • 可以公开与成功/失败/重试有关的统计信息。 最好以异步方式执行此操作(通过@Async EJB将其推送到JMX?),这样就不会妨碍Interceptor自身的性能。

干杯!

翻译自: https://www.javacodegeeks.com/2015/11/implementing-auto-retry-in-java-ee-applications.html

java ee的小程序

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

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

相关文章

Java变长数组笛卡尔积_Java 8中的流作为流的笛卡尔积(仅使用流)

小编典典在示例中传递流永远比传递列表更好:private static Stream cartesian(BinaryOperator aggregator, List... lists) {...}并像这样使用它:Stream result cartesian((a, b) -> a b,Arrays.asList("A", "B"),Arrays.asLis…

jboss eap 7_EAP 7 Alpha和Java EE 7入门

jboss eap 7红帽JBoss企业应用程序平台7(JBoss EAP 7)是基于开放标准构建并符合Java Enterprise Edition 7规范的中间件平台。 它建立在WildFly等经过验证的创新开源技术之上,这将使Java EE 7的开发更加容易。 这是有关如何开始使用最新ALPHA…

php 返回页面重复提交,php防止表单重复提交

后端防止重复提交的基本原理:服务器返回表单页面时,会先生成一个subToken保存于session,并把该subToen传给表单页面。当表单提交时会带上subToken,服务器获取表单信息判断session保存的subToken和表单提交subToken是否一致。若不一致或sessio…

spark在服务器运行示例_创建示例HTTPS服务器以获取乐趣和收益

spark在服务器运行示例通常,在开发或/和针对真实场景进行测试期间,我们(开发人员)面临着运行成熟的HTTPS服务器的需求,可能同时进行一些模拟。 在JVM平台上,除非您知道适合此工作的正确工具,否则…

为什么说php单线程,php单线程的缺点是什么?

PHP即“超文本预处理器”,是一种通用开源脚本语言。PHP是在服务器端执行的脚本语言,与C语言类似,是常用的网站编程语言。PHP独特的语法混合了C、Java、Perl以及 PHP 自创的语法。利于学习,使用广泛,主要适用于Web开发领…

sidecar_Spring Cloud Sidecar –节点初始化

sidecar在上一篇博客文章中,我描述了Sidecar应用程序如何用于在Eureka中注册Cassandra节点,更一般地,它可以用于在Eureka中注册任何非JVM应用程序。 在本文中,我将介绍应用程序如何查询Sidecar注册节点。 发现注册节点–初始化后…

php 对象 final,PHP7_OOP_对象重载以及魔术方法_对象遍历_final关键字

//对象遍历:class MyClass{public$var1 "value 1";public$var2 "value 2";public$var3 "value 3";protected$protected "pro var";private $private "privar";functioninterateVisible(){echo "MyClas…

供给测结构性改革内容_智能包装结构,提高可测性

供给测结构性改革内容有很多方法可以将整个应用程序分成多个包。 关于按功能或按层打包的优缺点的讨论可以在许多编程博客和论坛上找到。 我想从可测试性开始讨论这个主题,看看它是否会带来任何有意义的结果。 首先,让我们尝试描述我们通常希望跨不同层…

openshift_在OpenShift上扩展Java EE微服务

openshift这个小系列的前两个部分介绍了如何使用WildFly Swarm构建一个小型的JAX-RS服务并将其打包到Docker映像中 。 您学习了如何将此示例部署到OpenShift ,现在是时候对其进行一些扩展了。 为什么扩展很重要 基于微服务的体系结构的关键方面之一是分解为高性能的…

php 异步post,php – 使用POST的异步cURL

我正在制作一个命令行应用程序.在执行登录过程后,我需要同时通过cURL发出多个POST请求 – 这意味着传出请求必须发送会话ID等.事件链如下:>我用curl_init打开cURL连接>我使用curl_exec登录远程站点发送POST请求,并获得返回的HTML代码作为响应>我同时向同一…

log4j2 logger_简单一致的Log4j2 Logger命名

log4j2 logger在“ 带有Java 7方法句柄的可移植记录器名称”一文中 ,我写了关于使用Java 7的方法句柄来命名类的记录器的文章。 我在那篇文章中说过,这种方法的优点包括记录器命名的一致性,并避免了意外的代码复制和粘贴,这可能导…

java 子类tostring,JAVA中Object类的toString()方法,objecttostring

JAVA中Object类的toString()方法,objecttostringtoStringpublic String toString()返回该对象的字符串表示。通常,toString 方法会返回一个“以文本方式表示”此对象的字符串。结果应是一个简明但易于读懂的信息表达式。建议所有子类都重写此方法。Objec…

openshift 部署_在OpenShift上部署Java EE微服务

openshift 部署我昨天用WildFly Swarm在博客上发布了有关简单JAX-RS微服务的博客。 您学习了如何使用Maven构建所谓的“胖子”,还使用Maven Docker插件对我们的微服务进行了Docker化并在Docker Machine上本地运行。 这是在本地测试事物的好方法。 到目前为止&#x…

在程序中实现java源文件编译,在程序中实现对java源文件编译的3种方法

一般情况下对java源文件的编译均是在代码完成后使用javac编译的,不管是使用 IDE还是直接使用命令行。这里要说的情况是比较特别的,就是在代码内动态的编译一些代码。比如你想通过在某个目录下通过放置一些源代码的方式来实现对程序功能的动态扩展&#x…

apache.camel_Apache Camel 2.16发布–十大亮点

apache.camelApache Camel 2.16于上周五发布。 这篇博客文章是我尝试在此新版本中进行前10名(加1作为奖励)的亮点。 1.动态到 来自骆驼用户的最常见的常见问题是,如何将消息发送到端点,uri应该使用消息中的动态值(例…

设计模式示例_责任链设计模式示例

设计模式示例本文是我们名为“ Java设计模式 ”的学院课程的一部分。 在本课程中,您将深入研究大量的设计模式,并了解如何在Java中实现和利用它们。 您将了解模式如此重要的原因,并了解何时以及如何应用模式中的每一个。 在这里查看 &#x…

edmonds算法matlab,匈牙利算法的matlab实现

匈牙利算法算法简介算法原理算法实现(附代码)测试算法简介下面摘用百度百科中的解释。匈牙利算法(Hungarian method)是由匈牙利数学家Edmonds于1965年提出,因而得名。匈牙利算法是基于Hall定理中充分性证明的思想,它是二分图匹配最常见的算法&#xff0c…

php sqlsrv 分页,Php+SqlServer如何实现分页显示

PhpSqlServer如何实现分页显示$idmssql_connect("ddy","sa"," ") or die("连接不上");$dbmssql_select_db("ddy",$id);$query"select * from lr00 order by lr0012 desc";$resultmssql_query($query);if($result)…

java jooq_将Java EE与jOOQ结合使用的初学者指南

java jooqJava EE附带了自己的持久性API:JPA。 当您想要将RDBMS实体(表/关系)映射到Java实体(类)时,JPA最强大,主要遵循1:1映射策略。 其背后的思想是,业务逻辑通常不像关…

java ee编译器_Java EE 8 MVC:控制器的详细介绍

java ee编译器Java EE MVC是为Java EE 8计划并在JSR-371中指定的基于动作的新MVC框架。 这是我的Java EE 8 MVC教程的第二篇文章。 第一篇文章介绍了基础知识,并展示了如何开始使用 Java EE 8 MVC参考实现Ozark 。 在本文中,我们将更详细地介绍MVC控制器…