转载: 超越线程池:Java并发并没有你想的那么糟糕…
TPS00-J. 用线程池实现应用在流量暴涨时优雅降级 很多程序都要解决这样一个问题——处理一系列外来的请求.Thread- Per-Message这种设计模式是最简单的并发策略了,它为每一个请求创建一个线程.这种模式在耗时较长,受io约束,基于session或者,任务相互独立等场景下表现优于顺序处理. 但是,这种设计也有几个缺陷,包括线程创建和调用,任务处理,资源分配和释放,和频繁的上下文切换等带来的的开销.此外,攻击者可以通过一下子发起铺天盖地的请求造展开DoS攻击.系统不能优雅的降级,而是…
1.前言 第二篇设计模式的文章我们谈谈Visitor模式. 当然,不是简单的列个的demo,我们以电商网站中的购物车功能为背景,使用线程池实现并发的Visitor模式,并聊聊其中的几个关键点. 一,基于线程池的实现并发Visitor模式. 二,讨论下并发场景下的一些细节处理. 三,用模拟数据测试并做补充说明. 2.背景 当从网站的某个页面进入购物车时,服务端需要做各种数据处理,比如刷新商品价格,计算促销价.校验库存等等.这些操作会随着业务的增加不断扩展,那么Visitor模式就适合这种场景,这也…
java.util.concurrent 包是在 Java5 时加入的,与 concurrent 的相关的有 JMM及 AbstractQueuedSynchronizer (AQS),两者是实现 concurrent 的基础,下面我们来看一下 1 JMM JMM 是 Java Memory Model,围绕着并发过程中如何处理可见性.原子性.有序性这三个特征而建立的模型. 1.1 主内存和工作内存 JMM 中规定了所有变量都储存在主内存中,每条线程都有自己的工作内存(类似处理器的高速缓存),线…
好的软件设计不建议手动创建和销毁线程.线程的创建和销毁是非常耗 CPU 和内存的,因为这需要 JVM 和操作系统的参与.64位 JVM 默认线程栈是大小1 MB.这就是为什么说在请求频繁时为每个小的请求创建线程是一种资源的浪费.线程池可以根据创建时选择的策略自动处理线程的生命周期.重点在于:在资源(如内存.CPU)充足的情况下,线程池没有明显的优势,否则没有线程池将导致服务器崩溃.有很多的理由可以解释为什么没有更多的资源.例如,在拒绝服务(denial-of-service)攻击时会引起的许多线…
还记得我们在初始介绍线程池的时候提到了Executor框架的体系,到现在为止我们只有一个没有介绍,与ThreadPoolExecutor一样继承与AbstractExecutorService的ForkJoinPool.Fork/Join框架是Java7提供了的一个用于并行执行任务的框架, 是一个把大任务分割成若干个小任务,最终汇总每个小任务结果后得到大任务结果的框架. 我们通过表面的意思去理解ForkJoin框架:Fork即把一个大任务切割成若干部分并行执行,join即把这些被切分的任务的执行…
前面我们简单介绍了线程池的使用,但是对于其如何运行我们还不清楚,Executors为我们提供了简单的线程工厂类,但是我们知道ThreadPoolExecutor是线程池的具体实现类.我们先从他开始分析. 1. ThreadPoolExecutor初探 ThreadPoolExecutor一共有3个构造方法,我们来看一下其中看起来比较复杂的这个: public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAl…
上节我们简单介绍了线程池,这次我们就来使用一下.Executors提供四种线程池,分别是:newCachedThreadPool,newFixedThreadPool ,newScheduledThreadPool ,newSingleThreadExecutor .下面我们分别来使用下. 1. newSingleThreadExecutor 创建一个单线程的线程池.这个线程池只有一个线程在工作,也就是相当于单线程串行执行所有任务.如果这个唯一的线程因为异常结束,那么会有一个新的线程来替代它.此…
熟悉Java多线程编程的同学都知道,当我们线程创建过多时,容易引发内存溢出,因此我们就有必要使用线程池的技术了. 最近看了一些相关文章,并亲自研究了一下源码,发现有些文章还是有些问题的,所以我也总结了一下,在此奉献给大家. 1 线程池的优势 总体来说,线程池有如下的优势: (1)降低资源消耗.通过重复利用已创建的线程降低线程创建和销毁造成的消耗. (2)提高响应速度.当任务到达时,任务可以不需要等到线程创建就能立即执行. (3)提高线程的可管理性.线程是稀缺资源,如果无限制的创建,不仅会消耗系统…
介绍   在项目开发中,经常遇到定时任务,今天通过自定义多线程池总结一下SpringBoot默认实现的定时任务机制. 定时任务模板 pom依赖 <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <depend…