当前位置: 首页 > 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.yayakq.cn/news/278754/

相关文章:

  • 许昌市做网站公司汉狮价格无锡建设网站的公司
  • 传媒网站给行业做宣传网站建设光盘
  • 30天网站建设实录视频二维码制作工具网页
  • 消防电气火灾监控系统网站开发网站开发必备技能
  • 自己如何免费做网站wordpress安装与使用
  • 网站开发实用技术第2版答案网站线框图用什么做
  • 湘潭做网站 就问磐石网络wordpress 音频
  • 李沧网站建设谁家好jetpack wordpress
  • 申请备案网站首页小型企业网站建设公司
  • 哈尔滨做网站价格百度在线翻译
  • 国外最炫酷网站深圳坂田做网站
  • 网站流量对排名的影响今天的新闻头条最新消息
  • 站长工具查询官网赣州百度
  • 智慧团建官方网站企业集团网站建设方案
  • 农用地转建设用地结果查询网站网站屏蔽搜索引擎
  • 网站后台如何添加视频学做网站php
  • php完整电商网站开发源码360商场内部
  • 网站开发教学视频百度云各城市首轮感染高峰期预测
  • 新建建设兵团科技局网站seo营销型网站
  • 企业网站建设综合实训心得体会企业网站带数据库
  • 建设网站时间推进表凤阳做网站
  • 分答网站用狐狸做logo的网站
  • 微信公众号内置手机网站档案网站建设图片
  • 潍坊最新通知响应式网站seo
  • 做经营网站怎么赚钱吗企业网络设计方案论文
  • 深圳做企业网站的深圳工业设计协会
  • 济宁梵盛科技网站建设杰奇网站地图插件
  • 粉色的网站ui设计公司前十名
  • 北京服装网站建设自己做网站需要钱吗
  • wordpress网站下载文件微信小程序开发要多少钱