首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在生产环境中执行java ee应用的详细日志

在生产环境中执行java ee应用的详细日志
EN

Stack Overflow用户
提问于 2016-06-17 21:35:48
回答 2查看 358关注 0票数 2

我想知道是否有可能记录生产中的java ee应用程序的方法中所有指令的执行情况。这应该提供属性的值以及指令是否已正确执行。

我知道glassfish等应用程序服务器提供的基本日志,但我希望获得以前任何时候变量的值的详细执行历史。

诚挚的问候

EN

回答 2

Stack Overflow用户

发布于 2016-06-20 23:39:54

@AroundInvoke拦截器很容易地涵盖了您所描述的内容,它是CDI所支持的少数拦截器之一。它仍然基于面向方面的方法,类似于AspectJ的另一个答案。日志记录是说明这类拦截器的首选示例,因此让我们考虑以下MethodLogger

  1. 定义了一个类MethodLogger。这是您将实际日志记录委托给的类。同样在这个类中,您可以访问您正在寻找的信息(方法名称、执行完成、参数e.t.c)。

公共类MethodLogger{私有日志记录器= Logger.getLogger("com.you.MethodLogger");@AroundInvoke公共对象日志(InvocationContext iCtxt)抛出异常{ logger.entering(iCtxt.getTarget().toString(),iCtxt.getMethod().getName(),iCtxt.getParameters());try{ return iCtxt.proceed();//重要!否则,方法调用将不会继续} catch(Exception ex){ //只要在此过程中发生异常,就可以随心所欲地执行任何操作} logger.exiting(iCtxt.getTarget().toString(),iCtxt.getMethod().getName());}

  • 将拦截器应用于您的EJB

@Stateless @Interceptors(MethodLogger.class) //应用此注释来拦截此EJB公共类YourEJB上的每个方法调用{ @Interceptors(MethodLogger.class) //如果只希望跟踪特定的方法,请在此处应用此注释public void doSomething();@ExcludeClassInterceptors //应用此注释以阻止拦截器影响此方法的public void doSomethingElse();}

在EJB3.1中,您还可以选择指定全局拦截器。如此定义的拦截器将应用于应用程序中的所有EJB,而与注释的使用无关。所以在ejb-jar.xml中

代码语言:javascript
复制
<assembly-descriptor>
  <interceptor-binding>
     <ejb-name>*</ejb-name>
     <interceptor-class>com.you.MethodLogger</interceptor-class>
  </interceptor-binding>
</assembly-descriptor>

进一步阅读

票数 6
EN

Stack Overflow用户

发布于 2016-06-20 13:18:07

我认为面向方面的编程(AOP)是你应该尝试的。如果您熟悉Spring框架,那么它有一组相当广泛的AOP特性。

当我想要查看传入的参数时创建的一个示例(只是为了避免在Eclipse中调试的痛苦)

代码语言:javascript
复制
    @Around("execution(public void getPersonCount())")
    public void thirdAdvice(final ProceedingJoinPoint joinPoint) throws Throwable
    {
        final int numberOfArguments = joinPoint.getArgs().length;
        final String functionName = joinPoint.getSignature().getName();
        System.out.println("Number of arguments = " + numberOfArguments);
        System.out.println("Function name = " + functionName);
        joinPoint.proceed();
    }

您可以阅读更多关于AOP here的内容。

此外,在我的示例中,我已经将值输出到标准输出。你可以把它和时间一起输出到磁盘上的一个文件中。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37883022

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档