摘要: 在过去我们实现多线程同步的代码中,往往使用join()、wait()、notiyAll()等线程间通信的方式,随着JUC包的不断的完善,java为我们提供了丰富同步工具类,官方也鼓励我们使用工具类来实现多线程的同步,今天我们就对其中CountDownLatch类的使用与底层实现进行分析与总结。 一、 阅读全文
posted @ 2019-06-28 20:56 DaFanJoy 阅读(706) 评论(0) 推荐(0) 编辑
摘要: 前面两篇文章Netty源码分析之NioEventLoop(一)—NioEventLoop的创建与Netty源码分析之NioEventLoop(二)—NioEventLoop的启动中我们对NioEventLoop的创建与启动做了具体的分析,本篇文章中我们会对NioEventLoop的具体执行内容进行分 阅读全文
posted @ 2019-06-11 22:04 DaFanJoy 阅读(963) 评论(0) 推荐(2) 编辑
摘要: 前面我们在java线程池ThreadPoolExecutor类使用详解中对ThreadPoolExector线程池类的使用进行了详细阐述,这篇文章我们对其具体的源码进行一下分析和总结; 首先我们看下ThreadPoolExecutor用来表示线程池状态的核心变量 ThreadPoolExecutor 阅读全文
posted @ 2019-05-29 21:34 DaFanJoy 阅读(573) 评论(0) 推荐(0) 编辑
摘要: 在SpringBoot框架中,注解做为一种隐式配置,极大的简化了之前xml文件的配置方式。SpringBoot中包含许多种类的注解,这里对在SpingBoot项目中经常使用到的一些注解的进行大致的归纳总结; 一、启动相关 1、@SpringBootApplication 在SpirngBoot启动类 阅读全文
posted @ 2019-05-16 18:52 DaFanJoy 阅读(604) 评论(0) 推荐(0) 编辑
摘要: 上篇文章中我们对Netty中NioEventLoop创建流程与源码进行了跟踪分析。本篇文章中我们接着分析NioEventLoop的启动流程; Netty中会在服务端启动和新连接接入时通过chooser选择器,分别为NioServerSocketChannel与NioSocketChannel选择绑定 阅读全文
posted @ 2019-03-23 15:13 DaFanJoy 阅读(1020) 评论(0) 推荐(2) 编辑
摘要: 一、NioEventLoop的概述 NioEventLoop做为Netty线程模型的核心部分,从本质上讲是一个事件循环执行器,每个NioEventLoop都会绑定一个对应的线程通过一个for(;;)循环来处理与 Channel 相关的 IO 操作, 包括 调用 select 等待就绪的 IO 事件、 阅读全文
posted @ 2019-03-10 22:44 DaFanJoy 阅读(3269) 评论(0) 推荐(1) 编辑
摘要: 一、基本介绍 ArrayBlcokingQueue,LinkedBlockingQueue是jdk中内置的阻塞队列,网上对它们的分析已经很多,主要有以下几点: 1、底层实现机制不同,ArrayBlcokingQueue是基于数组的,LinkedBlockingQueue是基于链表的; 2、初始化方式 阅读全文
posted @ 2019-02-03 19:00 DaFanJoy 阅读(3099) 评论(1) 推荐(0) 编辑
摘要: 最近开发网关服务的过程当中,需要用到kafka转发消息与保存日志,在进行压测的过程中由于是多线程并发操作kafka producer 进行异步send,发现send耗时有时会达到几十毫秒的阻塞,很大程度上上影响了并发的性能,而在后续的测试中发现单线程发送反而比多线程发送效率高出几倍。所以就对kafk 阅读全文
posted @ 2019-01-20 00:16 DaFanJoy 阅读(15888) 评论(3) 推荐(5) 编辑
摘要: 工作中许多地方需要涉及到多线程的设计与开发,java多线程开发当中我们为了线程安全所做的任何操作其实都是围绕多线程的三个特性:原子性、可见性、有序性展开的。针对这三个特性的资料网上已经很多了,在这里我希望在站在便于理解的角度,用相对直观的方式阐述这三大特性,以及为什么要实现和满足三大特性。 一、原子 阅读全文
posted @ 2018-11-29 18:35 DaFanJoy 阅读(6335) 评论(1) 推荐(1) 编辑
摘要: ServerBootstrap与Bootstrap分别是netty中服务端与客户端的引导类,主要负责服务端与客户端初始化、配置及启动引导等工作,接下来我们就通过netty源码中的示例对ServerBootstrap与Bootstrap的源码进行一个简单的分析。首先我们知道这两个类都继承自Abstra 阅读全文
posted @ 2018-11-03 17:47 DaFanJoy 阅读(1427) 评论(0) 推荐(1) 编辑