当前位置: 首页 > news >正文

重庆做网站建设团队免费广告发布平台

重庆做网站建设团队,免费广告发布平台,网站建设的评分细则,.net网站开发环境某天搬砖时遇到一个问题#xff0c;我创建了一个线程池执行任务#xff0c;刚开始的时候还是一切#xff0c;结果第二天发现有些任务没有正常执行。一看日志才发现是高峰期时线程池给我占用慢了#xff0c;任务被丢掉了。 ​ 举个例子#xff0c;我创建了一个线程池#… 某天搬砖时遇到一个问题我创建了一个线程池执行任务刚开始的时候还是一切结果第二天发现有些任务没有正常执行。一看日志才发现是高峰期时线程池给我占用慢了任务被丢掉了。 ​ 举个例子我创建了一个线程池最大线程数是10等待队列最大量是1000结果高峰期时一下给我来了2000个任务这个时候自然是顶不住的。解决办法肯定是有的比如改一下线程池的最大等待队列扩大到2000以上但是这种办法肯定不是完美的如果任务量再次增涨我又得去改一此代码吗这样肯定不行。于是我把多余的任务存储到数据库中弄个定时器去专门执行重跑。 ​ 下面是我写的一个例子 import lombok.Data;import java.util.*; import java.util.concurrent.*;public class MyTest {// 创建线程池static ThreadPoolExecutor executorService new ThreadPoolExecutor(2, 3, 2L, TimeUnit.MINUTES, new ArrayBlockingQueue(5), Executors.defaultThreadFactory(), new ThreadPoolExecutor.AbortPolicy());// 创建一个map假设它是数据库static ConcurrentHashMapInteger, Integer dbMap new ConcurrentHashMap();public static void main(String[] args) {// 用户通过正常操作流程来了一批任务executeTasks();// 启动定时任务redoTask();}static void executeTasks() {// 一次性安排30个任务for (int i 0; i 30; i) {// 获取剩余队列的数量int queueCapacity executorService.getQueue().remainingCapacity();if (queueCapacity 1) {// 当前队列数不足记录到数据库dbMap.put(i, i);continue;}System.out.println(当前队列数 queueCapacity);executorService.submit(new MyThread(i));}}Datastatic class MyThread implements Runnable {int taskId;public MyThread(int taskId) {this.taskId taskId;}Overridepublic void run() {try {// 模拟处理一个任务需要5秒TimeUnit.SECONDS.sleep(5);System.out.println(执行任务\ taskId \完毕);} catch (InterruptedException e) {e.printStackTrace();}}}/*** 模拟一个定时器不断扫描数据库中需要重跑的任务* 正式开发肯定网上找一个定时器用起来我家里穷用不起就自己随便写一个*/static void redoTask() {while (true) {// 判断数据库中是否有需要重跑的任务if (dbMap.size() 0) {System.out.println(开始执行重跑任务);int queueCapacity executorService.getQueue().remainingCapacity();// 当前队列剩余大于一半// 是否是大于一半的时候才运行重跑看具体情况if (queueCapacity 2) {System.out.println(当前队列资源足够执行重跑);ListInteger ids new LinkedList();// 从数据库中取重跑任务dbMap.forEach((k, v) - {// 因为从数据库里取任务是需要消耗一定时间的为防止资源再次被占满再获取一次队列剩余大小int queueCapacity2 executorService.getQueue().remainingCapacity();// 为避免把资源全部占用留一点给正常流程来的任务// 因为这里测试开的队列比较小只留了1根据实际情况而定if (queueCapacity2 1) {// 记录已经重跑过的任务idids.add(k);// 重跑任务executorService.submit(new MyThread(v));} else {// 如果资源占用太多则什么都不执行等待下一次扫描再执行// 有可能会出现一个问题某个任务等待了很久也轮不到它建议按时间排个序}});// 删除已经执行重跑的任务for (Integer id : ids) {dbMap.remove(id);}} else {System.out.println(当前队列资源不足跳过这次重跑);}}try {// 等待30秒继续判断TimeUnit.SECONDS.sleep(30);} catch (InterruptedException e) {}}} }​ 当然除了入库以外还有其他的办法我在网上搜索了一下延迟队列也可以解决 延迟队列解决方法不过相比之下我个人更喜欢入库的方案因为入库之后每个失败的任务我都能记录日志方便后期做分析统计。
http://www.w-s-a.com/news/660288/

相关文章:

  • 模板网站建设明细报价表做网站第一
  • 公司网站建设系统软件开发 上海
  • 怎么让公司建设网站固安县建设局网站
  • 360免费建站官网入口手机网站建设设计
  • 商城网站建站系统dw如何做网页
  • 网站建设的公司收费我有网站 怎么做淘宝推广的
  • 网站建设策划书事物选题手机兼职app
  • html5 微网站模版wordpress博客速度很慢
  • 怎么做五个页面网站网络推广如何收费
  • 上虞宇普电器网站建设江西建筑人才网
  • 在吗做网站商城一个网站需要服务器吗
  • 先做网站再备案吗中山微网站建设报价
  • 树莓派可以做网站的服务器吗网站建设与设计ppt
  • 网站访问速度分析网站怎么做让PC和手机自动识别
  • 网站建设要考西宁网站建设多少钱
  • 网站开发公司东莞网站推广计划书具体包含哪些基本内容?
  • 素材天下网站惠州网站建设行业
  • 网站做a视频在线观看网站天津建站
  • 自己做的网站怎么链接火车头采集一个网站可以做几级链接
  • 济南网站制作哪家专业做网站怎样投放广告
  • 辽宁网站推广短视频运营培训学费多少
  • 拼多多网站怎么做翻译 插件 wordpress
  • 做网站运营的职业生涯规划wordpress分类显示图片
  • 网站建设与制作总结沈阳百度广告
  • 网站管理系统 手机会员制网站搭建wordpress
  • 做物品租赁网站清新wordpress主题
  • 优秀专题网站家居企业网站建设市场
  • 中山市有什么网站推广wordpress轻应用主机
  • 洗头竖鞋带名片改良授权做网站不贵整个世界
  • 设计电子商务网站建设方案微信如何开发自己的小程序