问题原因:使用HuTool 的DbTtil 不能设置数据库连接超时时间,可能数据库挂了,会导致连接一直卡在那,也没有异常抛出,导致线程一直占着。所以给该段代码加超时时间处理。
public static void main(String[] args) {
ExecutorService executor = Executors.newCachedThreadPool();
FutureTask<String> future = new FutureTask<>(() -> {
System.out.println("运行中::" + LocalDateTime.now());
Thread.sleep(9000);
return "result";
});
executor.execute(future);
try {
System.out.println("结果前::" + LocalDateTime.now());
String res = future.get(10000, TimeUnit.MILLISECONDS);
System.out.println(res + "结果后:" + LocalDateTime.now());
} catch (Exception e) {
System.out.println("error:" + LocalDateTime.now());
future.cancel(true);
e.printStackTrace();
} finally {
executor.shutdown();
}
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)