问题描述
嗨,我有以下陈述:
- 我们有1个后台线程,每5分钟从数据库(MySQL)读取数据,并将此数据加载到静态Map
> - 我们有一个主while(true)迭代此Map
>,引用的获取方式如下: Manager.getInstance()。getDataMap();
执行以下代码:
Map<String,List<String>> data = Manager.getInstance().getDataMap();
data.forEach((s,values) -> {
logger.info("Info Key -> {}",s);
for (String value : values) {
executorService.execute(new TT(value));
}
});
如您所见,我们有一个执行程序服务,其定义如下:
BlockingQueue<Runnable> workQueue = new ArrayBlockingQueue<>(concurrent);
ThreadPoolExecutor executorService = new ThreadPoolExecutor(concurrent,concurrent,0L,TimeUnit.MILLISECONDS,workQueue);
// when the blocking queue is full,this tries to put into the queue which blocks
executorService.setRejectedExecutionHandler((r,executor) -> {
try {
// block until there's room
executor.getQueue().put(r);
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
throw new RejectedExecutionException("Producer thread interrupted",e);
}
});
此程序处理每个键的每个值,每个键可能要花费很多时间。 我要完成的事情是在对数据库进行更新时,例如删除或创建或修改新条目,然后更新迭代,以便在同一迭代中添加或删除值,因为我们最多需要N分钟的时间,因此引用的地图已更新。
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)