php多线程如何保证日志打印,可保持线程日志统一输出,多线程不混乱

可保持线程日志统一输出,多线程不混乱,比如多个请求时,每个请求的日志都是同时输出,而不是掺和成你一行我一行。但是可配置性没那么灵活,如果需要,请自行完善

日志文件目录格式为

info.log

2019-07/info_2019-07-05_150518-849.log

/info_2019-07-05_150518-849.log

2019-08/info_2019-08-05_150518-849.log

/info_2019-08-05_150518-849.log

把代码直接放入项目中

核心功能 把同一线程的日志,同时写入日志文件,默认是一条日志一次写入

但是要手动开启,拦截器的例子

@Component

public class CommonIntercetpor implements HandlerInterceptor{

private static Logger logger = LoggerFactory.getLogger(CommonIntercetpor.class);

@Override

public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {

LogUtil.autoFlush.set(false);

logger.info(request.getServletPath()+JSON.toJSONString(request.getParameterMap()));

return true;

}

public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable Exception ex) throws Exception {

LogUtil.flushLine();

}

}

如果有异步任务,也要使用aop进行开启多条日志同时写入文件的功能

@Component

@Aspect

public class AsyncAop {

@Pointcut("execution(public void com.YibuJob.*(..))")

public void aspect() {}

@Before("aspect()")

public void before(JoinPoint joinpoint) {

LogUtil.autoFlush.set(false);

}

@After("aspect()")

public void after(JoinPoint joinpoint) {

LogUtil.flushLine();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值