类似任务流程吧,代码大概是这样的:
Task task = new Task();
task.setStatus("任务开始");
task.setUpdateTime(new Date());
// 更新数据库记录的状态
DBUtils.save(task);
// 开始第一个阶段(耗时十几分钟左右)
TaskUtils.startOne(task);
task.setStatus("任务的第二阶段");
task.setUpdateTime(new Date());
// 更新数据库记录的状态
DBUtils.save(task);
// 开始第二个阶段
TaskUtils.startTwo(task);
我的疑问是:如果更新数据库很慢很慢(网络问题/没资源等),就会影响TaskUtils执行了,这种情况一般怎么解决呢?异步更新数据库是否可行?
首先确定一点,任务执行是否依赖数据库的更新数据,如果不依赖,则可以考虑异步,比如设置一个线程池,建立消息队列,往消息队列发送数据库更新请求
现在框架都给你做了,只要步骤失败,就会回滚,不会更新数据库,要么同时成功,要么同时失败,怎么可能你修改个数据要10几分钟. 修改肯定是需要有唯一标识的,不然你全表更新不符合业务逻辑,也不符合操作.
您好,我是有问必答小助手,你的问题已经有小伙伴为您解答了问题,您看下是否解决了您的问题,可以追评进行沟通哦~
如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~
ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632
非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!
速戳参与调研>>>https://t.csdnimg.cn/Kf0y