背景
项目中,有一个批量处理并保存到数据库的功能接口,在处理的时候因为数据量比较大,导致接口响应时间比较久。同事在优化这个功能的时候使用了多线程处理,接口响应速度提升上去了,但是有个createBy字段时必填项,这个值一值是null。
排查
经过排查发现,,该值又是通过拦截器获取token解析出的,放在ThreadLocal中的。因为ThreadLocal是线程私有的,使用多线程就会出现父子线程,子线程获取不到父线程ThreadLocal中的值。
解决
问题定位了,下面是解决这个问题。解决这个问题可以有多种方式。
方式一 手动传递 ThreadLocal 的值。
在创建自线程的时候将父线程中ThreadLocal的值手动传递给子线程。
package com.wyz.demo;
public class ThreadLocalExample {
private static final ThreadLocal<String> threadLocal = new ThreadLocal<>();
public static void main(String[] args) {
threadLocal.set("Parent Thread Value");
// 获取父线程的 ThreadLocal 值
String parentValue = threadLocal.get();
// 创建子线程并传递父线程的 ThreadLocal 值
Thread childThread = new Thread(() -> {
// 在子线程中设置父线程的值
threadLocal.set(parentValue);
System.out.println("Child Thread: " + threadLocal.get());
});
childThread.start();
try {
childThread.join()