Loading

摘要: 之前推了一篇文章《十张图带大家看懂 ES 原理 !明白为什么说:ES 是准实时的!》,很多小伙伴都比较好奇在文章中的图是用的什么画图软件?看那么明显的手绘风格,当然是手画的啦!(开玩笑),其实我用的是 draw.io ,下面分享我的画图软件 —— draw.io 。 阅读全文
posted @ 2020-11-08 17:48 程序员小航 阅读(515) 评论(0) 推荐(0) 编辑
摘要: 说到 Elasticsearch ,其中最明显的一个特点就是 *near real-time* 准实时 —— 当文档存储在Elasticsearch中时,将在1秒内以几乎实时的方式对其进行索引和完全搜索。那为什么说 ES 是准实时的呢? 阅读全文
posted @ 2020-11-08 16:36 程序员小航 阅读(1270) 评论(0) 推荐(2) 编辑
摘要: ES 使用过程中常用的就是查询以及检索,那查询和检索的过程,什么样的呢? 阅读全文
posted @ 2020-11-07 10:54 程序员小航 阅读(499) 评论(0) 推荐(0) 编辑
摘要: 在前面已经介绍了 ES 中常用的一些名词,知道了数据是存储在 shard 中的,而 index 会映射一个或者多个 shard 。那这时候我要存储一条数据到某个索引下,这条数据是在哪个 index 下的呢? 阅读全文
posted @ 2020-11-07 10:53 程序员小航 阅读(240) 评论(0) 推荐(0) 编辑
摘要: 看完什么是 Elasticsearch 以及了解到了倒排索引的概念,下面就熟悉下 ES 中常用的一些名词。 阅读全文
posted @ 2020-11-07 10:49 程序员小航 阅读(171) 评论(0) 推荐(0) 编辑
摘要: 革命同志是块砖,哪里需要哪里搬!这不,老大发话,要我在组内做一个 Elasticsearch 技术分享。这不话题一转,开始看起来 ES 了。虽然很久之前用过 ELK 做过日志监控系统,但是毕竟时隔已久,还是得从头看起。当然手头的活也不能停,话不多说,开始分享。先看看什么是 ES? 阅读全文
posted @ 2020-11-07 10:48 程序员小航 阅读(111) 评论(0) 推荐(0) 编辑
摘要: 在了解完 ReentrantLock 和 ReentrantReadWriteLock 之后,惊奇的发现 JUC 下还有一个 StampedLock 。 查阅资料发现是 JDK8 新增的一个锁。现在已经 JDK15 了,原谅我的孤陋寡闻,实在是业务开发中用的太少。那行吧,赶紧来看一下 StampedLock 到底是什么?为什么有了 ReentrantLock 和 ReentrantReadWriteLock 之后还要设计一个 StampedLock ? 阅读全文
posted @ 2020-11-07 10:39 程序员小航 阅读(108) 评论(0) 推荐(0) 编辑
摘要: 在看完 IDEA 插件开发简易教程后,小伙伴们是否迫不及待的想自己上手整一个插件了?心里规划好了一二三,但是却不知道从哪里开始下手。下面我分享下自己整理的一些常用的 API。 阅读全文
posted @ 2020-11-07 10:34 程序员小航 阅读(659) 评论(0) 推荐(0) 编辑
摘要: 小伙伴你是否想亲手写一个插件,或者你是否有一些插件的想法,但是找不到插件。那就自己实现一个吧! 阅读全文
posted @ 2020-11-07 10:32 程序员小航 阅读(854) 评论(0) 推荐(0) 编辑
摘要: 在看完 ReentrantLock 之后,在高并发场景下 ReentrantLock 已经足够使用,但是因为 ReentrantLock 是独占锁,同时只有一个线程可以获取该锁,而很多应用场景都是读多写少,这时候使用 ReentrantLock 就不太合适了。读多写少的场景该如何使用?在 JUC 包下同样提供了读写锁 ReentrantReadWriteLock 来应对读多写少的场景。 阅读全文
posted @ 2020-11-07 10:28 程序员小航 阅读(280) 评论(0) 推荐(0) 编辑
摘要: 在阅读完 JUC 包下的 AQS 源码之后,其中有很多疑问,最大的疑问就是 state 究竟是什么含义?并且 AQS 主要定义了队列的出入,但是获取资源、释放资源都是交给子类实现的,那子类是怎么实现的呢?下面开始了解 ReentrantLock。 阅读全文
posted @ 2020-11-05 22:37 程序员小航 阅读(170) 评论(0) 推荐(0) 编辑
摘要: 又要开发新项目了,还是创建新项目,怎么办?老大说按照 xxx 项目的结构创建一个新项目就可以了。 阅读全文
posted @ 2020-11-05 22:29 程序员小航 阅读(203) 评论(0) 推荐(0) 编辑
摘要: AbstractQueuedSynchronizer 抽象队列同步器,简称 AQS 。是在 JUC 包下面一个非常重要的基础组件,JUC 包下面的并发锁 `ReentrantLock` `CountDownLatch` 等都是基于 AQS 实现的。所以想进一步研究锁的底层原理,非常有必要先了解 AQS 的原理。 阅读全文
posted @ 2020-11-05 22:24 程序员小航 阅读(167) 评论(0) 推荐(0) 编辑
摘要: LockSupport 是 JUC 中常用的一个工具类,主要作用是挂起和唤醒线程。在阅读 JUC 源码中经常看到,所以很有必要了解一下。 阅读全文
posted @ 2020-11-05 21:07 程序员小航 阅读(93) 评论(0) 推荐(0) 编辑
摘要: 在介绍 AtomicInteger 时,已经说明在高并发下大量线程去竞争更新同一个原子变量时,因为只有一个线程能够更新成功,其他的线程在竞争失败后,只能一直循环,不断的进行 CAS 尝试,从而浪费了 CPU 资源。而在 JDK 8 中新增了 LongAdder 用来解决高并发下变量的原子操作。下面同样通过阅读源码来了解 LongAdder 。 阅读全文
posted @ 2020-11-05 10:06 程序员小航 阅读(137) 评论(0) 推荐(0) 编辑
摘要: 业务开发中经常使用 ThreadLocal 来存储用户信息等线程私有对象... ThreadLocal 内部构造是什么样子的?为什么可以线程私有?常说的内存泄露又是怎么回事? 阅读全文
posted @ 2020-11-05 00:30 程序员小航 阅读(555) 评论(0) 推荐(0) 编辑
摘要: 关于红黑树,在HashMap中是怎么应用的? 前言 在阅读HashMap源码时,会发现在HashMap中使用了红黑树,所以需要先了解什么是红黑树,以及其原理。从而再进一步阅读HashMap中的链表到红黑树的转换,红黑树的增删节点等。 什么是红黑树? 在HashMap中是怎么应用的? 什么是红黑树? 阅读全文
posted @ 2020-11-03 21:08 程序员小航 阅读(151) 评论(0) 推荐(0) 编辑
摘要: HashMap的put kv,是如何扩容的? 描述下HashMap put(k,v)的流程? 它的扩容流程是怎么样的? HashMap put(k,v)流程 通过hash(key方法)获取到key的hash值 调用put方法, 将value存放到指定的位置 根据hash值确定当前key所在node数 阅读全文
posted @ 2020-11-03 21:05 程序员小航 阅读(119) 评论(0) 推荐(0) 编辑
摘要: HashMap的初始化,到底都做了什么? HashMap初始化参数都是什么?默认是多少? 为什么建议初始化设置容量? tableSizeFor方法是做什么的? 如何获取到一个key的hash值?及计算下标? HashMap初始化参数都是什么?默认是多少? HashMap初始化参数分别是初始容量和负载 阅读全文
posted @ 2020-11-03 20:59 程序员小航 阅读(267) 评论(0) 推荐(0) 编辑
摘要: JUC 下面还有一个系列的类,都是 CopyOnWriteXXX ,意思是写时复制,这个究竟是怎么回事?那就以 CopyOnWriteArrayList 为切入点,一起了解写时复制是怎么回事? 阅读全文
posted @ 2020-11-03 14:23 程序员小航 阅读(118) 评论(0) 推荐(0) 编辑