当前位置: 首页 > article >正文

Vert.x学习笔记-EventLoop与Context的关系


Vert.x学习笔记

      • 1. EventLoop 的核心作用
      • 2. Context 的核心作用
      • 3. EventLoop 与 Context 的关系
        • 1. 事件循环(EventLoop)的核心职责
        • 2. 上下文(Context)的核心职责
        • 3. 事件循环与上下文的关系
          • (1)一对一绑定
          • (2)任务调度协作
          • (3)线程安全保障
        • 4. 关键点总结
        • 5. 代码示例
        • 6. 总结
      • 4. 关键点总结
      • 5. 代码示例
        • 输出示例:
      • 6. 总结


在 Vert.x 中,EventLoop(事件循环)与 Context(上下文)是紧密关联的核心组件,它们共同协作以实现高效、非阻塞的异步编程模型。

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站


在这里插入图片描述


1. EventLoop 的核心作用

  • 事件驱动:EventLoop 是 Vert.x 中处理 I/O 事件的核心机制,负责监听网络事件(如套接字读写)、定时任务等,并将这些事件分发给对应的处理器(Handler)。
  • 线程绑定:每个 EventLoop 通常绑定到一个固定的线程(在 Vert.x 中称为 VertxThread),确保事件处理的线程亲和性,避免线程切换的开销。
  • 非阻塞设计:EventLoop 必须保持非阻塞状态。如果在 EventLoop 线程中执行阻塞操作(如同步 I/O、长时间计算),会导致整个 EventLoop 线程阻塞,从而影响其他事件的及时处理。

2. Context 的核心作用

  • 执行上下文:Context 是 Vert.x 中用于封装和调度异步任务的上下文环境。它负责将任务提交到正确的线程(EventLoop 或 Worker 线程)中执行。
  • 线程隔离:Context 确保同一 Verticle 的所有事件处理逻辑在同一个线程(EventLoop 线程)中执行,避免多线程竞争问题。
  • 任务调度:Context 提供了 runOnContextexecuteBlocking 等方法,用于将任务提交到当前 Context 关联的线程中执行。

3. EventLoop 与 Context 的关系

  • 一对一绑定
    每个 Verticle 实例在部署时会被分配到一个 EventLoop,并绑定到一个对应的 Context。这个 Context 封装了该 Verticle 的所有事件处理逻辑,并确保这些逻辑在同一个 EventLoop 线程中执行。

  • 任务调度
    当 Verticle 中触发一个事件(如 HTTP 请求到达)时,Vert.x 会将该事件的处理任务提交到对应的 Context 中。Context 会将任务调度到绑定的 EventLoop 线程中执行。

  • 避免阻塞
    如果 Verticle 中需要执行阻塞操作(如数据库查询),可以通过 Context 的 executeBlocking 方法将任务提交到 Worker 线程池中执行,避免阻塞 EventLoop 线程。


在 Vert.x 中,事件循环(EventLoop)上下文(Context) 是紧密协作的核心组件,它们共同构成了 Vert.x 异步编程模型的基础。以下是它们之间关系的详细解析:


1. 事件循环(EventLoop)的核心职责
  • 事件处理引擎:EventLoop 是 Vert.x 中负责监听和处理 I/O 事件(如网络请求、定时任务等)的核心机制。它基于非阻塞 I/O 模型,通过事件驱动的方式处理高并发请求。
  • 线程绑定:每个 EventLoop 通常绑定到一个固定的线程(VertxThread),确保事件处理的线程亲和性。这种设计避免了线程切换的开销,提高了性能。
  • 非阻塞要求:EventLoop 线程必须保持非阻塞状态。如果在 EventLoop 线程中执行阻塞操作(如同步 I/O、长时间计算),会导致整个 EventLoop 线程阻塞,从而影响其他事件的及时处理。

2. 上下文(Context)的核心职责
  • 执行环境封装:Context 是 Vert.x 中用于封装和调度异步任务的上下文环境。它负责将任务提交到正确的线程(EventLoop 线程或 Worker 线程)中执行。
  • 线程隔离与亲和性:Context 确保同一 Verticle 的所有事件处理逻辑在同一个线程(EventLoop 线程)中执行,避免多线程竞争问题。这种线程亲和性是 Vert.x 高性能的关键。
  • 任务调度:Context 提供了 runOnContextexecuteBlocking 等方法,用于将任务提交到当前 Context 关联的线程中执行。

3. 事件循环与上下文的关系
(1)一对一绑定
  • Verticle 与 Context 的绑定
    每个 Verticle 实例在部署时会被分配到一个 Context。这个 Context 封装了该 Verticle 的所有事件处理逻辑,并确保这些逻辑在同一个线程中执行。
  • Context 与 EventLoop 的绑定
    每个 Context 通常绑定到一个 EventLoop 线程(即 Context 的 owner() 方法返回的线程)。这意味着同一 Verticle 的所有事件处理逻辑都会在同一个 EventLoop 线程中执行。
(2)任务调度协作
  • 非阻塞任务
    当 Verticle 中触发一个事件(如 HTTP 请求到达)时,Vert.x 会将该事件的处理任务提交到对应的 Context 中。Context 会将任务调度到绑定的 EventLoop 线程中执行。
  • 阻塞任务
    如果 Verticle 中需要执行阻塞操作(如数据库查询),可以通过 Context 的 executeBlocking 方法将任务提交到 Worker 线程池中执行,避免阻塞 EventLoop 线程。
(3)线程安全保障
  • 线程亲和性
    由于 Context 确保同一 Verticle 的所有事件处理逻辑在同一个 EventLoop 线程中执行,因此无需显式使用同步机制(如锁)来保护共享数据,从而简化了编程模型。
  • 避免多线程竞争
    Context 将任务隔离到不同的线程中执行(EventLoop 线程或 Worker 线程),避免了多线程竞争问题,提高了程序的稳定性和性能。

4. 关键点总结
  • 线程绑定关系
    每个 Verticle 实例绑定到一个 Context,每个 Context 绑定到一个 EventLoop 线程。这种层级关系确保了线程亲和性和非阻塞设计。
  • 任务调度机制
    Context 负责将任务提交到正确的线程中执行。非阻塞任务在 EventLoop 线程中执行,阻塞任务在 Worker 线程中执行。
  • 性能与稳定性
    通过线程亲和性和任务隔离,Vert.x 实现了高并发、低延迟的异步编程模型,同时避免了多线程竞争问题。

5. 代码示例

以下是一个简单的 Vert.x 示例,展示了 EventLoop 和 Context 的协作:

import io.vertx.core.AbstractVerticle;
import io.vertx.core.Context;
import io.vertx.core.Vertx;
import io.vertx.core.eventloop.EventLoop;public class ExampleVerticle extends AbstractVerticle {@Overridepublic void start() {// 获取当前 Verticle 的 ContextContext context = vertx.getOrCreateContext();// 获取绑定的 EventLoopEventLoop eventLoop = context.owner();System.out.println("Current thread: " + Thread.currentThread().getName());System.out.println("Is EventLoop thread: " + context.isOnEventLoopThread());// 在 EventLoop 线程中执行任务context.runOnContext(v -> {System.out.println("Running on EventLoop thread: " + Thread.currentThread().getName());});// 执行阻塞操作(通过 Worker 线程)context.executeBlocking(promise -> {// 模拟阻塞操作try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}promise.complete("Blocking operation completed");}, res -> {System.out.println("Result: " + res.result());});}public static void main(String[] args) {Vertx vertx = Vertx.vertx();vertx.deployVerticle(new ExampleVerticle());}
}

6. 总结
  • 事件循环(EventLoop) 是 Vert.x 中处理 I/O 事件的核心线程,负责事件分发和非阻塞任务调度。
  • 上下文(Context) 是 Vert.x 中封装和调度异步任务的上下文环境,确保任务在正确的线程中执行。
  • 关系总结
    每个 Verticle 实例绑定到一个 Context,每个 Context 绑定到一个 EventLoop 线程。Context 负责将任务调度到绑定的 EventLoop 线程或 Worker 线程中执行,确保线程亲和性和非阻塞设计。

通过这种设计,Vert.x 实现了高并发、低延迟的异步编程模型,非常适合构建高性能的网络应用。


4. 关键点总结

  • 线程亲和性
    EventLoop 和 Context 共同确保同一 Verticle 的所有事件处理逻辑在同一个线程中执行,避免线程切换的开销和多线程竞争问题。

  • 非阻塞设计
    EventLoop 必须保持非阻塞状态,所有阻塞操作必须通过 Context 提交到 Worker 线程池中执行。

  • 任务隔离
    Context 将任务隔离到不同的线程中执行(EventLoop 线程或 Worker 线程),确保高并发场景下的性能和稳定性。


5. 代码示例

以下是一个简单的 Vert.x 示例,展示了 EventLoop 和 Context 的协作:

import io.vertx.core.AbstractVerticle;
import io.vertx.core.Context;
import io.vertx.core.Vertx;
import io.vertx.core.eventloop.EventLoop;public class ExampleVerticle extends AbstractVerticle {@Overridepublic void start() {// 获取当前 Verticle 的 ContextContext context = vertx.getOrCreateContext();// 获取绑定的 EventLoopEventLoop eventLoop = context.owner();System.out.println("Current thread: " + Thread.currentThread().getName());System.out.println("Is EventLoop thread: " + context.isOnEventLoopThread());// 在 EventLoop 线程中执行任务context.runOnContext(v -> {System.out.println("Running on EventLoop thread: " + Thread.currentThread().getName());});// 执行阻塞操作(通过 Worker 线程)context.executeBlocking(promise -> {// 模拟阻塞操作Thread.sleep(1000);promise.complete("Blocking operation completed");}, res -> {System.out.println("Result: " + res.result());});}public static void main(String[] args) {Vertx vertx = Vertx.vertx();vertx.deployVerticle(new ExampleVerticle());}
}
输出示例:
Current thread: vert.x-eventloop-thread-0
Is EventLoop thread: true
Running on EventLoop thread: vert.x-eventloop-thread-0
Result: Blocking operation completed
  • 解释
    • start() 方法在 EventLoop 线程中执行。
    • context.runOnContext 提交的任务也在同一个 EventLoop 线程中执行。
    • context.executeBlocking 提交的任务在 Worker 线程中执行(输出中未显示 Worker 线程名,但实际是异步的)。

6. 总结

  • EventLoop 是 Vert.x 中处理 I/O 事件的核心线程,负责事件分发和非阻塞任务调度。
  • Context 是 Vert.x 中封装和调度异步任务的上下文环境,确保任务在正确的线程中执行。
  • EventLoop 和 Context 的关系
    每个 Verticle 实例绑定到一个 EventLoop 和一个 Context,Context 负责将任务调度到绑定的 EventLoop 线程或 Worker 线程中执行,确保线程亲和性和非阻塞设计。

通过这种设计,Vert.x 实现了高并发、低延迟的异步编程模型,非常适合构建高性能的网络应用。


Vert.x学习笔记-什么是Handler

spring中的@EnableAutoConfiguration注解详解

Vert.x学习笔记-什么是EventLoop

相关文章:

Vert.x学习笔记-EventLoop与Context的关系

Vert.x学习笔记 1. EventLoop 的核心作用2. Context 的核心作用3. EventLoop 与 Context 的关系1. 事件循环(EventLoop)的核心职责2. 上下文(Context)的核心职责3. 事件循环与上下文的关系(1)一对一绑定&am…...

2025030给荣品PRO-RK3566开发板单独升级Android13的boot.img

./build.sh init ./build.sh -K ./build.sh kernel 【导入配置文件】 Z:\Android13.0\rockdev\Image-rk3566_t\config.cfg 【更新的内核】 Z:\Android13.0\rockdev\Image-rk3566_t\boot.img 【导入分区表,使用原始的config.cfg会出错的^_】 Z:\Android13.0\rockdev\…...

由enctype-引出post与get的关系,最后深究至请求/响应报文

本篇载自我的笔记,本次为第二次复习。我觉得我有能力理一下思路了。 --- 笔记截图。 enctype HTML 表单的 enctype(Encode Type,编码类型)属性用于控制表单数据在提交到服务器时的编码方式,不同取值的详细解析如下&a…...

排序算法衍生问题

排序算法衍生问题 引言 排序算法是计算机科学中基础且重要的算法之一,其应用广泛,如数据统计分析、数据库操作、网络排序等。随着计算机科学的发展,排序算法的研究不仅局限于传统的排序方法,还衍生出许多有趣且实用的衍生问题。…...

Mac电脑上本地安装 redis并配置开启自启完整流程

文章目录 一、安装 Redis方法 1:通过源码编译安装(推荐)方法 2:通过 Homebrew 安装(可选) 二、配置 Redis1. 创建配置文件和数据目录2. 修改配置文件 三、配置开机自启1、通过 launchd 系统服务&#xff08…...

STP(生成树协议)原理与配置

冗余链路与环路问题 冗余链路虽然提供网络可靠性,但会引发环路问题。广播风暴导致网络资源耗尽,MAC地址表频繁更新造成震荡,同一数据帧通过不同路径重复传输影响数据完整性。 STP工作机制 生成树协议通过选举机制消除环路,同时…...

搭建基于VsCode的ESP32的开发环境教程

一、VsCode搜索ESP-IDF插件 根据插件处搜索找到ESP-IDF并安装 安装完成 二、配置安装ESP-IDF 配置IDF 按照如下配置,点击安装 安装完成 三、使用案例程序 创建一个闪光灯的例子程序,演示程序编译下载。 选择blink例子,闪烁LED的程序 选…...

【MFC】初识MFC

目录 01 模态和非模态对话框 02 静态文本 static text 01 模态和非模态对话框 首先我们需要知道模态对话框和非模态对话框的区别: 模态对话框是一种阻塞时对话框,它会阻止用户与应用程序的其他部分进行交互,直到用户与该对话框进行交互并关…...

C++.二分法教程

二分法 1. 问题引入1.1 猜数字游戏2.1 二分法核心思想为什么需要二分法?二分法的基本步骤示例代码代码解析 2.2 二分法适用场景有序数组查找效率要求高示例场景示例代码代码解析 3.1 初始化左右边界示例代码代码解析 3.2 计算中间值示例代码代码解析 3.3 判断与更新…...

如何通过数据分析优化项目决策

通过数据分析优化项目决策需从明确数据分析目标、选择适当的数据分析工具、确保数据质量、建立数据驱动文化等方面入手,其中,明确数据分析目标是优化决策过程的基础,只有清晰明确的数据分析目标才能指导有效的数据采集与分析,避免…...

2024年数维杯国际大学生数学建模挑战赛B题空间变量协同估计方法研究解题全过程论文及程序

2024年数维杯国际大学生数学建模挑战赛 B题 空间变量协同估计方法研究 原题再现: 在数理统计学中,简单采样通常假设来自相同总体的采样点彼此独立。与数理统计相反,空间统计假设空间变量的采样点是相依的,并在其值中表现出某些趋…...

leetcode hot100刷题日记——34.将有序数组转换为二叉搜索树

First Blood:什么是平衡二叉搜索树? 二叉搜索树(BST)的性质 左小右大:每个节点的左子树中所有节点的值都小于该节点的值,右子树中所有节点的值都大于该节点的值。 子树也是BST:左子树和右子树也…...

thinkphp 5.1 部分知识记录<一>

1、配置基础 惯例配置->应用配置->模块配置->动态配置 惯例配置:核心框架内置的配置文件,无需更改。应用配置:每个应用的全局配置文件(框架安装后会生成初始的应用配置文件),有部分配置参数仅能在应用配置文件中设置。模块配置:每个模块的配置文件(相同的配置…...

RAG:面向知识密集型自然语言处理任务的检索增强生成

摘要 大型预训练语言模型已被证明能够在其参数中存储事实性知识,并在下游自然语言处理(NLP)任务的微调中取得了最先进的结果。然而,它们访问和精准操作知识的能力仍然有限,因此在知识密集型任务中,其表现落后于针对特定任务设计的架构。此外,如何为它们的决策提供出处(…...

MVVM、MVC的区别、什么是MVVM

一、什么是MVVM (一)定义 MVVM是Model - View - ViewModel的缩写,它是一种软件架构设计模式,主要用于构建用户界面。这种模式将应用程序分为三个主要部分: Model(模型层) 它是应用程序中负责…...

网页自动化部署(webhook方法)

实现步骤: 宝塔安装宝塔WebHook 2.5插件。 github 上配置网页仓库(或可在服务器的网页根目录clone)。 配置宝塔WebHook 2.5 添加hook脚本; 编辑添加syncJC脚本; #!/bin/bash # 定义网站根目录 WEBROOT"/www…...

线性代数入门:轻松理解二阶与三阶行列式的定义与理解

前言 行列式是线性代数中一个非常基础但又极其重要的概念。它不仅是解线性方程组的利器,还在矩阵理论、向量空间、特征值等问题中扮演着关键角色。今天,我将用最通俗易懂的方式,向高中生朋友们介绍二阶和三阶行列式的基本概念和计算方法。让…...

AU6825集成音频DSP的2x32W数字型ClaSSD音频功率放大器(替代TAS5825)

1.特性 ● 输出配置 - 立体声 2.0: 2 x 32W (8Ω,24V,THD N 10%) - 立体声 2.0: 2 x 26W (8Ω,21V,THD N 1%) ● 供电电压范围 - PVDD:4.5V -26.4V - DVDD: 1.8V 或者 3.3V ● 静态功耗 - 37mA at PVDD12V ● 音频性能指标 - THDN ≤ 0.02% at 1W,1kHz - SNR ≥ 107dB (A-wei…...

华为云Flexus+DeepSeek征文|DeepSeek-V3/R1商用服务体验全流程

华为云 Flexus 与 DeepSeek-V3/R1 的深度整合,构建了一套 “弹性算力 智能引擎” 的协同体系。 Flexus 系列云服务器基于柔性计算技术,通过动态资源调度(如 Flexus X 实例)实现 CPU / 内存的实时弹性分配,尤其适合大模…...

Go语言的原子操作

当我们想要对某个变量并发安全的修改,除了使用官方提供的mutex,还可以使用sync/atomic包的原子操作,它能够保证对变量的读取或修改期间不被其他的协程所影响。 Golang提供的原子操作都是非侵入式的,由标准库sync/atmoic包提供&am…...

Visual Studio 2022 插件推荐

Visual Studio 2022 插件推荐 Visual Studio 2022 (简称 VS2022) 是一款强大的 IDE,适合各类系统组件、框架和应用的开发。插件是接入 VS2022 最重要的扩展方式之一,它们可以大幅提升开发效率、优化代码质量,并提供强大的调试和分析功能。 …...

【深度学习-pytorch篇】3. 优化器实现:momentum,NAG,AdaGrad,RMSProp,Adam

Optimization Algorithms Explained 1. Beale Function 与导数函数讲解 Beale 函数是一个著名的用于测试优化算法性能的函数,其具有多个局部极值点,适合评估不同优化器的表现: def beale(x1, x2):"""Beale 函数定义&#x…...

C# NX二次开发-查找连续倒圆角面

在QQ群里有人问怎么通过一个选择一个倒圆角面来自动选中一组倒圆角面。 可以通过ufun函数 UF_MODL_ask_face_type 和 UF_MODL_ask_face_props 可判断处理选择相应的一组圆角面。 代码: Tag[] 查找连续倒圆角面(Tag faceTag) {theUf.Modl.AskFaceType(faceTag, out int typ…...

今天遇到的bug

先呈现一下BUG现象。 这主要是一个传参问题,参数一直传不过去。后来我才发现,问题所在。 我们这里用的RquestBody接收参数,所有请求的参数需要用在body体中接收,但是我们用postman,用的是字符串查询方式传参&#x…...

Go语言字符串类型详解

1. 定义字符串类型 package mainimport ("fmt");func main() {var str1 string "你好 GoLang 1"var str2 "你好 GoLang 2"str3 : "你好 GoLang 3"fmt.Printf("%v--%T\n", str1, str1)// 你好 GoLang 1--stringfmt.Printf…...

长安链智能合约命令解析(全集)

创建命令解析 ./cmc client contract user create \ --contract-namefact \ --runtime-typeWASMER \ --byte-code-path./testdata/claim-wasm-demo/rust-fact-2.0.0.wasm \ --version1.0 \ --sdk-conf-path./testdata/sdk_config.yml \ --admin-key-file-paths./testdata/cryp…...

一、OpenCV的基本操作

目录 1、OpenCV的模块 2、OpenCV的基础操作 2.1图像的IO操作 2.2绘制几何图形 2.3获取并修改图像中的像素点 2.4 获取图像的属性 2.5图像通道的拆分与合并 2.6色彩空间的改变 3、OpenCV的算数操作 3.1图像的加法 3.2图像的混合 3.3总结 1、OpenCV的模块 2、OpenCV的基…...

裂缝仪在线监测装置:工程安全领域的“实时守卫者”

在基础设施运维领域,裂缝扩展是威胁建筑结构安全的核心隐患之一。传统人工巡检方式存在效率低、时效性差、数据主观性强等局限,而裂缝仪在线监测装置通过技术迭代,实现了对结构裂缝的自动化、持续性追踪,为工程安全评估提供科学依…...

【论文精读】2024 ECCV--MGLD-VSR现实世界视频超分辨率(RealWorld VSR)

文章目录 一、摘要二、问题三、Method3.1 Latent Diffusion Model3.2 Motion-guided Diffusion Sampling3.3 Temporal-aware Decoder Fine-tuning 四、实验设置4.1 训练阶段4.2 训练数据 贡献总结 论文全称: Motion-Guided Latent Diffusion for Temporally Consis…...

SpringBoot简单体验

1 Helloworld 打开:https://start.spring.io/ 选择maven配置。增加SpringWeb的依赖。 Generate之后解压,代码大致如下: hpDESKTOP-430500P:~/springboot2/demo$ tree ├── HELP.md ├── mvnw ├── mvnw.cmd ├── pom.xml └── s…...