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

免费观看电视剧网站线上营销工具

免费观看电视剧网站,线上营销工具,神箭手 wordpress,怎么做网页的二维码对于需要并行多公司并行处理的任务,方案是什么? 多线程、并行流、并发库(ExecutorService、Futrue、Callable),分布式计算(1)按照公司ID分片 (2)按照业务类型分片 处理…

对于需要并行多公司并行处理的任务,方案是什么?

多线程、并行流、并发库(ExecutorService、Futrue、Callable),分布式计算

(1)按照公司ID分片
(2)按照业务类型分片

处理某类任务,多个线程同时处理,拿到最先处理的完成接口

(1) 采用 CompletableFuture.anyOf(future1, future2, future3), 注意CompletableFuture使用自定义线程池,默认是ForkJoinPool线程池;案例

public class CompletableFutrueAnyOf {public static void main(String[] args) {ExecutorService executorService = Executors.newFixedThreadPool(3);CompletableFuture<String> future1 = CompletableFuture.supplyAsync(() -> {try {TimeUnit.SECONDS.sleep(3);} catch (InterruptedException e) {throw new RuntimeException(e);}return "futrue1 执行结果";},executorService);CompletableFuture<String> future2 = CompletableFuture.supplyAsync(() -> {try {TimeUnit.SECONDS.sleep(6);} catch (InterruptedException e) {throw new RuntimeException(e);}return "futrue2 执行结果";},executorService);CompletableFuture<String> future3 = CompletableFuture.supplyAsync(() -> {try {TimeUnit.SECONDS.sleep(2);} catch (InterruptedException e) {throw new RuntimeException(e);}return "futrue3 执行结果";},executorService);CompletableFuture<Object> objectCompletableFuture = CompletableFuture.anyOf(future1, future2, future3);try {System.out.println(objectCompletableFuture.get());} catch (InterruptedException e) {throw new RuntimeException(e);} catch (ExecutionException e) {throw new RuntimeException(e);}}
}

(2) Executor框架和Future接口实现
如果同时处理多个任务,只需要提交多个任务到线程池中即可。第一个完成的任务的结果会被get()方法返回

在并发查询某一类数据时,流量会全部打到存储,怎么优化该场景

(1)mybatis缓存,此方案只针对使用mybatis当作ORM框架,一级缓存是SqlSession级别的缓存
二级缓存:跨SqlSession级别,通常用于单表、多表会有脏数据
(2)缓存工具,比如redis,针对相同时间内的,相同查询条件,可以直接从结果返回数据;但是也有局限性:(比如分页),或者定时缓存到redis、后续直接从redis查,类似于热点数据缓存
(3)重复请求场景:前端限流,后端限流
(4)数据库层级的优化:索引、分片、查询语句优化、水平/垂直扩展等

Java ThreadPoolExecutor配置时,需要配置corePoolSize,maximumPoolSize、queueCapacity、以及拒绝策略,请描述随着线程池提交任务的增加,线程池创建线程的策略;

execute 执行原理

在这里插入图片描述
(1)提交任务后会首先进行当前工作线程数与核心线程数的比较,如果当前工作线程数小于核心线程数,则直接调用 addWorker() 方法创建一个核心线程去执行任务;
(2)如果工作线程数大于核心线程数,即线程池核心线程数已满,则新任务会被添加到阻塞队列中等待执行,当然,添加队列之前也会进行队列是否为空的判断;
(3)如果线程池里面存活的线程数已经等于核心线程数了,且阻塞队列已经满了,再会去判断当前线程数是否已经达到最大线程数 maximumPoolSize,如果没有达到,则会调用 addWorker() 方法创建一个非核心线程去执行任务;
(4)如果当前线程的数量已经达到了最大线程数时,当有新的任务提交过来时,会执行拒绝策略
整个顺序就是:优先核心线程、阻塞队列次之,最后非核心线程。

addWorker方法

可以看到execute中最关键的就是addWorker方法,它接受两个参数:
第一个参数是要执行的任务,如果为null那么会从等待队列中拉取任务;
第二个参数是表示是否核心线程,用来控制addWorker方法流程的;

在这里插入图片描述

线程池调用execute提交任务—>创建Worker(设置属性thead、firstTask)—>worker.thread.start()—>实际上调用的是worker.run()—>线程池的runWorker(worker)—>worker.firstTask.run();

http://www.hengruixuexiao.com/news/20764.html

相关文章:

  • 网站建设项目团队长沙网络优化产品
  • 网站标头设计seo技巧课程
  • 黄岩做网站广州外包网络推广公司
  • 如何自己搭建微信小程序疫情优化调整
  • qq网页版手机版seo快速排名关键词
  • 一个做音乐的网站如何制作网页游戏
  • 贪玩原始传奇官方网站b站推广
  • 公司对比网站方象科技的服务范围
  • 网站开发 加密保护相城seo网站优化软件
  • 网站建设公司石家庄seo全称是什么意思
  • 电商网站设计与制作总结热搜榜排名今日事件
  • 专业商城网站制作排名怎么优化快
  • wordpress演示版网络优化的工作内容
  • 如何给wordpress配置ssl证书搜索引擎优化培训
  • 软件界面谷歌seo查询
  • 北京比较好的网站公司长沙官网seo分析
  • 网站开发实验报告三什么是搜索引擎推广
  • 扬中网站建设流程什么网站可以免费推广
  • 网站开发费怎么做会计分录免费平台推广
  • 做网站开发用哪种语言好凡科建站
  • 51ppt模板网官网seo百度seo排名优化软件
  • 安庆商城网站开发百度seo和谷歌seo有什么区别
  • 做公司自主网站网络推广需要多少费用
  • 怎么向网站添加型号查询功能新媒体口碑营销案例
  • 做直播网站需要那些技术千锋教育北京校区
  • 网站开发教程云盘精准获客
  • 贵阳论坛网站建设河北seo
  • 网站管理服务seo搜狗排名点击
  • 做网站需要什么学历品牌网站建设哪家好
  • 有什么可靠网站做建材代理的吗企业网站优化解决方案