Java排查接口调用记录、请求参数、响应结果、执行时长

简介

  • 在Web应用当中记录接口调用记录、请求参数、响应结果、执行时长是再常见不过的事情了,记录的方式有很多。
  • 最近阅读之前的历史代码发现以前一些接口的统计时长、记录调用记录、请求参数都是合代码逻辑并存,严重影响了代码可读性。
  • 而记录接口调用记录、请求参数、响应结果、执行时长这些操作完全可以抽象出来,用 AOP 横向拦截去处理,实现解耦、提高代码可读可维护性。这篇文章将介绍如何实现。

实现思路

代码实现

废话不多说,直接上代码。

定义@AroundLog注解,用于标识需要记录的接口。

@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD})
@Documented
public @interface AroundLog {
    String flag() default "";
}

切面实现

@Aspect
@Slf4j
@Component
public class AroundLogAspect {

    @Around("@annotation(aroundLog)")
    public Object aroundLog(ProceedingJoinPoint point, AroundLog aroundLog) {

        StringBuilder sb = new StringBuilder();
        StopWatch started = new StopWatch();

        try {
            MethodSignature signature = (MethodSignature) point.getSignature();
            Method method = signature.getMethod();

            sb.append("\n<===================================START===================================>\n");
            sb.append("call time:>").append(LocalDateTime.now()).append("\n");
            ObjectMapper mapper = new ObjectMapper();

            String methodName = method.getName();
            sb.append("method name:> ").append(methodName).append("\n");

            sb.append("log flag:> ").append(aroundLog.flag()).append("\n");

            Parameter[] parameters = method.getParameters();
            Object[] args = point.getArgs();
            sb.append("request:>\n");
            if (args != null) {
                for (int i = 0; i < args.length; i++) {
                    String paramName = parameters[i].getName();
                    String argStr= null;
                    try {
                        argStr  = mapper.writeValueAsString(args[i]);
                    } catch (Exception e) {
                        argStr = "无法解析";
                    }
                    sb.append(paramName).append(":").append(argStr).append("\n");
                }
            }

            started.start();
            Object proceed = point.proceed();

            sb.append("response:>\n").append(mapper.writeValueAsString(proceed)).append("\n");

            return proceed;
        } catch (RuntimeException e) {
            sb.append("RuntimeException:>").append(e.getMessage()).append("\n");
            throw e;
        } catch (Throwable throwable) {
            sb.append("Throwable:>").append(throwable.getMessage()).append("\n");
            throw new RuntimeException("系统异常!");
        }finally {
            started.stop();
            sb.append("call total time(ms) :> ").append(started.getTime()).append("\n");
            sb.append("<====================================END====================================>\n");
            log.info(sb.toString());
        }
    }
}

调用接口测试,日志输出如下

<===================================START===================================>
call time:>2021-08-30T19:34:47.062
methodName:>pay
log flag:> 
request:>
response:>
{"status":true,"code":null,"message":"success","errorMsg":null,"data":null}
call total time(ms) :>21
<====================================END====================================>

这样一来就实现了记录接口调用记录、请求参数、响应结果、执行时长与逻辑解耦。

  • 原文链接:https://blog.csdn.net/weixin_43950568/article/details/120003896
### Java 后端发送 HTTP 请求时遇到状态码 504 Gateway Timeout 的解决方案 当Java后端程序尝试通过HTTP请求与其他服务通信时,如果返回`504 Gateway Timeout`错误,则表明中间服务器作为网关或代理,在等待上游服务器响应的过程中超出了设定时间[^1]。 #### 增加客户端请求超时设置 可以通过调整发起HTTP请求的客户端库来延长其默认的读取和连接超时参数。例如使用Apache HttpClient: ```java import org.apache.http.client.config.RequestConfig; import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.HttpClients; RequestConfig config = RequestConfig.custom() .setConnectTimeout(5000) // 设置连接超时时长为5秒 .setSocketTimeout(30000)// 设置数据传输超时时长为30秒 .build(); CloseableHttpClient httpClient = HttpClients.custom().setDefaultRequestConfig(config).build(); ``` #### 调整Nginx或其他反向代理配置 如果是由于前端使用的Nginx等反向代理软件造成的504错误,可以适当增加这些组件内部定义的最大处理时间和缓冲区大小限制: ```nginx http { ... proxy_read_timeout 60s; # 修改成更合理的数值 fastcgi_read_timeout 60s; # 如果涉及到FastCGI协议的话也需要相应修改 } ``` #### 检查并优化目标系统的性能表现 确保被调用的服务本身能够高效运作非常重要。可以从以下几个方面着手改进: - **数据库查询效率**:审查SQL语句是否存在低效操作; - **缓存机制引入**:利用Redis/Memcached减少重复计算量; - **异步任务调度**:对于耗时较长的任务考虑采用消息队列等方式实现非阻塞执行; #### 定期监控与日志记录 建立完善的监控体系有助于提前发现潜在风险点,并且一旦出现问题也能迅速定位根本原因所在。建议开启详细的访问日志以及异常堆栈跟踪功能以便后续排查问题之需。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值