在迭代和MySQL

问题描述

嗨,我有以下陈述:

  1. 我们有1个后台线程,每5分钟从数据库(MySQL)读取数据,并将此数据加载到静态Map >
  2. 我们有一个主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 (将#修改为@)

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...