认准该次提交,请直接忽略该功能其他次的提交

This commit is contained in:
风雨行
2023-05-31 00:10:38 +08:00
parent 1decddb6b1
commit e0963e88bd
3 changed files with 14 additions and 31 deletions

View File

@@ -1,24 +1,24 @@
package com.abin.mallchat.common.common.factory;
import com.abin.mallchat.common.common.handler.MyUncaughtExceptionHandler;
import com.abin.mallchat.common.common.handler.GlobalUncaughtExceptionHandler;
import lombok.AllArgsConstructor;
import lombok.NoArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.scheduling.concurrent.CustomizableThreadFactory;
import java.util.concurrent.ThreadFactory;
@Slf4j
@AllArgsConstructor
@NoArgsConstructor
public class MyThreadFactory implements ThreadFactory {
private String name;
public MyThreadFactory(String name){
this.name=name;
}
public MyThreadFactory(){}
@Override
public Thread newThread(Runnable r) {
Thread thread = new Thread(r);
thread.setUncaughtExceptionHandler(new MyUncaughtExceptionHandler(name));
thread.setUncaughtExceptionHandler(new GlobalUncaughtExceptionHandler(name));
return thread;
}
}

View File

@@ -1,17 +1,19 @@
package com.abin.mallchat.common.common.handler;
import lombok.AllArgsConstructor;
import lombok.NoArgsConstructor;
import lombok.extern.slf4j.Slf4j;
@Slf4j
@AllArgsConstructor
@NoArgsConstructor
public class GlobalUncaughtExceptionHandler implements Thread.UncaughtExceptionHandler {
private String name;
public GlobalUncaughtExceptionHandler(){}
public GlobalUncaughtExceptionHandler(String name){
this.name=name;
}
@Override
public void uncaughtException(Thread t, Throwable e) {
log.error("current thread name is",t.getName()," is error[{}]",e);
log.error("线程池名称:[{}],错误信息如下:",name);
e.printStackTrace();
}
}

View File

@@ -1,19 +0,0 @@
package com.abin.mallchat.common.common.handler;
import lombok.AllArgsConstructor;
import lombok.NoArgsConstructor;
import lombok.extern.slf4j.Slf4j;
@Slf4j
@AllArgsConstructor
@NoArgsConstructor
public class MyUncaughtExceptionHandler implements Thread.UncaughtExceptionHandler {
private String name;
@Override
public void uncaughtException(Thread t, Throwable e) {
log.error("线程池名称:[{}],错误信息如下:",name);
e.printStackTrace();
}
}