Vertx.vertx()初始框图和模块
Vertx.vertx()实例
一、构造方法
1. VertxImpl构造方法 选择 transports protocol , default select 模型
if (options.getPreferNativeTransport()) {
Transport nativeTransport = Transport.nativeTransport();
if (nativeTransport != null && nativeTransport.isAvailable()) {
transport = nativeTransport;// 使用netty-transport-native epoll-ET 或 Kqueue
} else {
transport = Transport.JDK;// java.nio (linux下 epoll-LT)
}
} else {
transport = Transport.JDK;// java.nio (linux下 epoll-LT)
}
native transports protocol
| transports | TCP | UDP | SCTP | UDT |
|---|---|---|---|---|
| jdk-NIO | X | X | X | X |
| netty-native-epoll | X | X | — | — |
| OIO | X | X | X | X |
PS : select 模型是线性扫描所有 FD , 时间复杂度O(n), 轮训机制.
epoll 模型基于callback机制 , k 活跃数 时间复杂度O(k).
试用场景: 大量FD 基本都是活跃状态,select 比 epoll 优秀,没有epollctl的回調开销,
反之有大量idle , dead状态 , epoll更优秀
2. BlockedThreadChecker线程,检查所有线程阻塞, 观察者模式
//默认Timer每 1 seconds检查一次 , 默认warn时间 5 seconds
checker = new BlockedThreadChecker(options.getBlockedThreadCheckInterval()
, options.getWarningExceptionTime()); //守护线程,监听所有阻塞线程,遍历扫描(container) WeakHashMap 弱引用,
//ContextImpl.runCloseHooks 执行结束置为null,使GC线程自动回收资源, 防止内存泄漏
timer = new Timer("vertx-blocked-thread-checker", true);
timer.schedule(...);
3. eventloop线程池
eventloop线程本质是对netty eventloop的封装.
eventLoopGroup = transport.eventLoopGroup(options.getEventLoopPoolSize()
,eventLoopThreadFactory, NETTY_IO_RATIO);
// 默认 2 * number of cores ,linux下依赖 /proc/self/status 做计算 acceptorEventLoopGroup = transport.eventLoopGroup(
, acceptorEventLoopThreadFactory, );
//负责客户端连接,线程1,单进程服务线程为1即可,否则造成资源浪费
note: eventloop线程checker默认最大阻塞时间 2 seconds,处理时间越长,eventloop事件堆积 就越多,影响服务正常响应,切不可阻塞,阻塞任务可换成worker线程池运行
4. worker线程池
worker线程池是J.U.C包下的FixedThreadPool,默认default 20
ExecutorService workerExec=Executors.newFixedThreadPool(
options.getWorkerPoolSize(),new VertxThreadFactory("vert.x-worker-thread-"
,checker, true, options.getMaxWorkerExecuteTime()));
note: worker主要用来处理耗时任务, 阻塞同步的调用而设计,checker默认超时时间 60 seconds, 执行行为两种, 串行(采用数据结构队列,FIFO) ; 并行 .
5.internal 线程池
internal线程池是J.U.C包下的FixedThreadPool,默认default 20
ExecutorService internalBlockingExec = Executors.newFixedThreadPool(
options.getInternalBlockingPoolSize()
,new VertxThreadFactory("vert.x-internal-blocking-"
,checker, true, options.getMaxWorkerExecuteTime()));
note: 内部使用的线程池,主要用来将阻塞代码异步化
5.初始化加载模块
//创建文件解析器,会创建一个 cache 目录,默认当前执行目录建立隐藏文件夹.vertx,
//使用 kill -15 <pid> 使进程触发ShutdownHook清理 cache目录文件和目录
fileResolver = new FileResolver(this, options.isFileResolverCachingEnabled()); /**
* 创建地址解析器,会读取/etc/resolv.conf DNS配置文件,
* resolv.conf手册地址:http://www.man7.org/linux/man-pages/man5/resolv.conf.5.html
*/
addressResolver = new AddressResolver(this, options.getAddressResolverOptions()); //创建部署Verticle管理器
deploymentManager = new DeploymentManager(this); //启用集群cluster,创建集群管理器
clusterManager = getClusterManager(options); //集群状态下创建HA管理器(高可用)
haManager = new HAManager(this, deploymentManager, clusterManager, options.getQuorumSize(), options.getHAGroup(), haEnabled); //创建并且启动事件总线,local和cluster模式实现不同
createAndStartEventBus(options, resultHandler); //创建sharedData实例,共享数据,local和cluster模式实现不同
sharedData = new SharedDataImpl(this, clusterManager); //创建抽象层的文件系统模块,AsyncFileImpl 依赖 java nio AsynchronousFileChannel
// private final FileSystem fileSystem = getFileSystem();
//不同操作系统call调用有兼容问题,最好开发环境和发布环境一致
Utils.isWindows() ? new WindowsFileSystem(this) : new FileSystemImpl(this) //初始化度量指标
metrics = initialiseMetrics(options);
5. static 块
static {
// 关闭netty的资源泄露器检查,有性能的一定开销
ResourceLeakDetector.setLevel(ResourceLeakDetector.Level.DISABLED);
// 默认使用 Jdk deflater/inflater
System.setProperty("io.netty.noJdkZlibDecoder", "false");
}
二、其它模块
//创建DNSclient
DnsResolverProvider provider = new
DnsResolverProvider(this,addressResolverOptions); //创建异步的httpClient,协议包括 HTTP_1_0 , HTTP_1_1 , HTTP_2 和 HTTPS
new HttpClientImpl(this, options); //创建httpServer, 默认协议协商版本 HTTP/2 , HTTP/1.1 , 支持 https
//(SNI:多证书单服务需要集成KeyCertOptions自己实现)
new HttpServerImpl(this, serverOptions); //创建tcp服务端,支持 tls
new NetServerImpl(this, options); //创建tcp客户端,支持 tls
new NetClientImpl(this, options); //创建udp服务
DatagramSocketImpl.create(this, options); //额外 CLI(command-line interface) , cli 模块
框图
REQUIRED MODEL
FREE MODEL
整体框图
Vertx.vertx()初始框图和模块的更多相关文章
- vertx实例的fileSystem文件系统模块
初始化 //根据OS区分实现 System.getProperty("os.name").toLowerCase(); Utils.isWindows() ? new Window ...
- vertx模块HAManager高可用
HAManager public HAManager(VertxInternal vertx, DeploymentManager deploymentManager, ClusterManager ...
- vertx模块DeploymentManager部署管理器
DeploymentManager public DeploymentManager(VertxInternal vertx) { this.vertx = vertx; loadVerticleFa ...
- vertx.io 与nodejs 一个简单的性能比较
vertx.io 与node 都是可以进行js运行的一个引擎,但是vertx 支持的语言相对于node 多,可以查看官网.今天下网上查询相关的信息 时来了解到vertx.io 性能比node 好,于是 ...
- vertx核心类之VertxImpl
在Vert.x中,Vertx接口是最为重要的一个接口,vertx-core的基础功能都在此接口中提供.这篇文章中我们就来分析一下Vertx接口体系的内部实现以及创建流程.本文对应Vert.x的版本为 ...
- vertx简单客户端创建
import java.util.HashMap;import java.util.Map; import com.yunva.vertx.test.vertproject.util.JsonUtil ...
- vertx简单服务创建
import java.util.HashMap;import java.util.Map; import org.slf4j.Logger;import org.slf4j.LoggerFactor ...
- Kotlin & Vertx 构建web服务
感想 Kotlin 是一门好语言,值得大家了解一下. Vertx 是一个好框架,也值得大家了解一下. Kotlin 写过js,也写过一点点go,主力一直是java.用了kotlin,貌似找到了常用语言 ...
- Kotlin Vertx
Kotlin & Vertx Kotlin 是一门好语言,值得大家了解一下. Vertx 是一个好框架,也值得大家了解一下. Kotlin 写过js,也写过一点点go,主力一直是java.用了 ...
随机推荐
- 控制结构(10): 指令序列(opcode)
// 上一篇:管道(pipeline) // 下一篇:Continuation-passing_style(CPS) 发现问题 在一个正式项目的开发周期中,除了源代码版本控制外,还存在着项目的配置/编 ...
- python 必学模块collections
包含的主要功能如下 查看collections 的源码我们可以看到其为我们封装了以下的数据结果供我们调用 __all__ = ['deque', 'defaultdict', 'namedtuple' ...
- BEX5下集成FullCalendar
实现版本 BEX5 3.6 集成前准备: 直接网上查找FullCalendar获得插件文件 fullcalendar.min.css fullcalendar.min.js fullcalendar. ...
- 四、Attribute
Attribute分两种 Attribute称为特性,语法:特性(Attribute)的名称和值是在方括号内规定的,放置在它所应用的元素之前. 1.ActionFilterAttribute(过滤器) ...
- jzoj6101. 【GDOI2019模拟2019.4.2】Path
题目链接:https://jzoj.net/senior/#main/show/6101 记\(f_i\)为从\(i\)号点走到\(n\)号点所花天数的期望 那么根据\(m\)条边等可能的出现一条和一 ...
- Win10修改编辑文件无法保存怎么办(没有权限)
Win10修改编辑hosts文件无法保存怎么办 修改一些系统文件无法保存说明这个账户没有“写”这个权限 这里以hosts文件为例,为账户增加读写权限: 首先进入Win10系统的hosts文件所在位置 ...
- 安利一个刚考过的信息安全认证Security+
在目前的信息安全大潮之下,人才是信息安全发展的关键.而目前国内的信息安全人才是非常匮乏的,拥有国际信息安全认证的人才,在未来职业发展.升职加薪的道路上必将优于普通的信息安全从业者. 果哥今天推荐201 ...
- idea中的一些快捷键,未完待续......
1.快速查看注释的渲染效果 在keymap中查找“Quick Documentation”并设置自己喜欢的快捷键即可 2.全局搜索 在keymap中查找“Replace in Path”并设置自己喜欢 ...
- Kafka实战分析(一)- 设计、部署规划及其调优
1. Kafka概要设计 kafka在设计之初就需要考虑以下4个方面的问题: 吞吐量/延时 消息持久化 负载均衡和故障转移 伸缩性 1.1 吞吐量/延时 对于任何一个消息引擎而言,吞吐量都是至关重要的 ...
- velocity 新手用小常识--开源,简单易上手
项目中经常用到的 .vm 后缀文件是什么? 基于 java 的 velocity 模版引擎的一种页面控制文件,是一些类似 html 语句和一种叫 VLT 的语句构成 velocity --美 [v ...