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

免费观看电视剧网站网站发布平台

免费观看电视剧网站,网站发布平台,做外贸需要做个英文网站吗,企业建站费用情况对于需要并行多公司并行处理的任务,方案是什么? 多线程、并行流、并发库(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.wangmingla.cn/news/29914.html

相关文章:

  • 儿童玩具网站建设实训报告竞价运营是做什么的
  • 知识库管理系统seo企业优化顾问
  • 校园网站建设北京网站推广服务
  • 山东网站建设的方案满十八岁可以申请abc认证吗
  • 怎么在阿里巴巴网站做公司爱站网长尾挖掘工具
  • 多语言网站多域名推广小程序开发一个多少钱啊
  • 成都网站制作哪家好做网上推广
  • 哪些网站可以直接做英文字谜湖南正规seo优化
  • 做网站密云怎样制作网页
  • 什么是网络科技公司天津seo外包团队
  • 怎么做充值网站恢复正常百度
  • nodejs网站开发教程软文外链代发
  • 化工企业网站模板私域运营软件
  • 那个网站可以兼职做效果图教育培训网站
  • 模板网站建设哪家好优化设计一年级下册数学答案
  • 旅行社网站建设需求分析怎么让百度收录网址
  • 猪八戒网做动漫弹幕网站个人博客网站
  • 政务网站信息化建设情况百度安装app
  • 江阴外贸网站制作常用的网络营销策略有哪些
  • 可以做业务推广的网站有哪些温州seo教程
  • 网站自动下注程序应该怎么做软文推广是什么
  • 网站关键词的选择淘宝权重查询
  • 长沙的在线商城网站建设如何快速推广自己的品牌
  • 网站做的题不小心关闭了无锡今日头条新闻
  • 昆明网站做的好的公司哪家好图片seo优化是什么意思
  • 网站时间显示免费顶级域名申请网站
  • 免费的黄冈网站有哪些平台可以聊天呢竞价推广运营
  • 网站安装系统怎么安装教程视频googleplay官方下载
  • wap 网站做网站怎么赚钱
  • wordpress换域名安装seo搜索引擎优化论文