Jaeger是一个链路追踪系统,适合用于分布式的调用链路分析,服务依赖分析,性能和延迟优化。使用OpenTracing标准的语意和与其兼容的类库,使用灵活的抽样策略,支持多种后端存储(Cassandra, Elasticsearch, memory)
... ➦今天在v2ex看到一个问题,NIO 如下代码怎么绕过死锁?还是说我写的不对?如下代码,里面贴了代码。
简单说明:创建了两个selector A和B,线程1使用A来accept连接,并且register到B上。同时,线程2使用B来select,处理读写事件。
问题:select和register都要获取Selector publicKeys 的锁->虽然创建了线程1和2,但是还是要等待对方释放锁,所以这两个线程就没啥用,在以往的NIO实践中我也遇到过。解决这个问题很简单,生产者消费者模式就可以,线程1生产register请求,线程2消费register事件,真正执行在B上的register。反正一句话,同一个selector的register和select需要串行,并行不了(因为需要获取同一个锁)。
上面只是引子,我想看看netty是如何处理这个细节的。关于netty的架构和设计,什么EventLoopGroup、EventLoop、Pipepline、ChannelHandler网上说的很多了。今天要做的是看netty如何封装java NIO的accept、register,如何进行select,下面开始。
... ➦在Elasticsearch调研中,已经学习了es的similarity、plugin和在idea中debug启动。有了以上,就可以自己制作es评分插件。这篇博客说下如何自定义script_score实现自己的评分算法。
... ➦用一下acme.sh,实现自动签发野卡证书的需求。 acme.sh是一个开源的shell脚本,可以用来签发证书,支持很多dns服务商,支持自动续签。
... ➦目的:调研elasticsearch的启动、debug、评分、插件以实现自定义评分插件。
首先,关于es启动流程的大体介绍lanffy.github.io。在这片文章中,将会主要关注加载插件的部分。
... ➦