文章详情页
java - 定时任务轮询数据库压力如何解决
问题描述
有很多定时任务,而且是分布在不同的服务器上的。要轮询数据库中符合条件(状态)的数据,然后在进行处理。 这样成百上千的定时任务去轮询数据库,直接导致数据库压力剧增。
这种情况如何处理呢?怎样减少数据库压力。
问题解答
回答1:把相似或类似的轮询任务合并,以减少轮询任务的数量
降低轮询任务的执行频率
优化轮询任务内部的SQL语句,降低数据库查询压力
平摊轮询任务的执行时间,不要都集中在某个时间段
不使用轮询任务
升级数据库
回答2:试试把要轮询的数据id单独存放,任务轮询id表,然后在根据id去单条的查询
回答3:另外数据库也可以设置多个从库,定时任务可以从不同的从库里轮询得到数据,这样数据库的压力就小很多
标签:
java
相关文章:
1. PHP中的$this代表当前的类还是方法?2. javascript - vue2.0中使用vue2-dropzone的demo,vue2-dropzone的github网址是什么??百度不到。3. html5 - 目前 公司App 嵌入H5页面 做个 手机支付功能 没有做过 所以 请求各位有经验的 给个思路4. IOS app应用软件的id号怎么查询?比如百度贴吧的app-id=4779278135. javascript - 用swiper.js实现h5多篇文章滑动 点击文章跳转全文是另外的页面 点击返回滑动界面怎么定位到相应的swiper_slide6. javascript - avalon.js ms-on 事件绑定无效 ?7. java - butterknife怎么绑定多个view8. 鼠标过导航标签时,无效果,请问如何查找问题9. html - 这种错位的时间轴怎么布局,然后用css实现?10. java - spring-data Jpa 不需要执行save 语句,Set字段就可以自动执行保存的方法?求解
排行榜