1. LogHelper–在当前请求的线程中传递参数
- 每一个请求进入,tomcat都会开启一个线程处理这个请求,从controller到service到mapper都是同一个线程,同一个线程共享数据
- ThreadLocalMap<ThreadLocal, value>
- 拿到ThreadLocal的对象引用,调用set方法,就可以往当前线程里放值(具体实现可以查看set的源码实现)
- 工具类
public final class LogHelper {
private static ThreadLocal<String> logPrefix = new ThreadLocal();
public LogHelper() {
}
public static String prefix() {
return (String)logPrefix.get() + " ";
}
public static void prefix(final String prefix) {
logPrefix.set(prefix);
}
public static void remove() {
logPrefix.remove();
}
}
@GetMapping(value = "/list")
public void list(XxxQueryDTO queryDTO) {
try {
LogHelper.prefix(UUID.randomUUID().toString());
xxxService.list(queryDTO));
} finally {
LogHelper.remove();
}
}
@Override
public void list(XxxQueryDTO queryDTO) {
log.info("{} xxx xxx: {}", LogHelper.prefix(), xxx.xxx);
}
2. application.name 不一致也能负载均衡
3. Kafka 发送消息失败的补偿机制
- 设置kafka发送消息失败的回调方法,该方法将失败的消息等信息保存在redis,再由另一个Listener监听Event,去redis里获取失败的消息,进行重试
- 在redis里设置重试次数,每重试一次次数+1,超过指定次数则不再重试
- 去redis里获取失败的消息可以采用多线程,捞取失败数据进行重试
- 此处涉及多线程、spring listener、ioc容器生命周期等知识点