项目未解之谜

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容器生命周期等知识点
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值