日志问题困惑,如何保证一个很长方法的日志记录顺序
1、现在问题是这样的,比如我有A方法,里面记录日志,但是A方法执行完的时间需要15秒,还有一个B方法,B方法执行完的时间却是10秒,这样就导致了日志的顺序打乱问题,比如说2台机器前后查一秒的去请求A和B方法,A比B快一秒请求,我想要的日志信息是这样的:
1、A请求开始,参数
2、A调用第三方接口,请求参数
3、A请求结束
4、B请求开始,参数
5、B调用第三方接口,请求参数
6、B请求结束
但是实际可能是这样:
1、A请求开始,参数
2、B请求开始,参数
3、B调用第三方接口,请求参数
4、A调用第三方接口,请求参数
5、B请求结束
6、A请求结束
详细代码如下,求大神门有什么好的方案,感激不尽,刚用没多少分。
public void A(){
logger.error("A请求开始,参数:{}",p1);
....
...
logger.error("A调用第三方接口,请求参数:{},p2);//这里用了8
...
...
logger.error("A请求结束");
|
public void B(){
logger.error("B请求开始,参数:{}",p1);
....
...
logger.error("B调用第三方接口,请求参数:{},p2);//这里用了7
...
...
logger.error("B请求结束");
|