news 2026/7/1 18:40:03

异步调用共享MDC信息(请求id,用户信息)用于日志跟踪(登录日志)、批量生成数据、异步存储设备登录数

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
异步调用共享MDC信息(请求id,用户信息)用于日志跟踪(登录日志)、批量生成数据、异步存储设备登录数

文章目录

  • I 开发设计
    • 性能优化
    • 异步调用共享MDC信息
    • MDC(Mapped Diagnostic Context)
  • II 案例
    • 存储设备登录数
    • 异步存储用户登录日志

I 开发设计

本文介绍了开发设计中的性能优化和MDC信息共享方案。
在性能优化方面

  • 建议数据库层面创建查询索引并避免循环操作
  • 代码层面采用异步处理非主流程逻辑。
  • 针对异步调用场景,强调通过指定线程池名称(normalThreadPool)来共享MDC信息。

MDC作为多线程日志上下文传递机制,使用put()/setContextMap()绑定线程数据,需注意清理防止内存泄漏。对于JDK21虚拟线程,推荐使用ScopedValue或自定义装饰器实现MDC传递。

性能优化

  1. 数据库层面: 查询字段创建索引,循环不执行数据库操作
  2. 代码层面: 非主流程的逻辑可以使用异步执行,比如日志操作,异步方法获取用户信息可以采取MDC实现

异步调用共享MDC信息

后续如果涉及异步调用的时候,异步方法需要获取用户信息的话,需要指定线程池名称为:normalThreadPool,尤其有多个线程池对象的时候,一定要指定。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/25 20:30:50

35、Solaris文件与文件I/O详解

Solaris文件与文件I/O详解 1. Solaris中的文件 1.1 文件的基本定义 从广义上讲,文件是一种以字节数组形式存储数据的实体,数据从第0字节开始,一直延伸到文件末尾。文件内容可以有多种形式,如简单的文本文件、二进制可执行文件、目录文件等。Solaris支持多种类型的文件,…

作者头像 李华
网站建设 2026/7/1 2:49:06

42、Unix文件系统UFS实现详解

Unix文件系统UFS实现详解 1. UFS概述 UFS(Unix文件系统)以可加载的文件系统模块形式实现,包含vfs和vnode对象的实例。其中,UFS的vnode接口实现文件操作,而UFS的vfs接口则负责文件系统的管理。 UFS文件系统的实现可分为以下五个主要组件: - vfs对象的实例,以及用于挂…

作者头像 李华
网站建设 2026/7/2 0:24:24

GitHub热门项目EmotiVoice为何成为开发者新宠?

EmotiVoice:让机器“说出情感”的开源语音合成新范式 在虚拟主播直播时突然哽咽落泪,游戏NPC因被击败而愤怒咆哮,有声书朗读中语调随情节起伏波动——这些曾依赖真人配音才能实现的情感表达,如今正被一个名为 EmotiVoice 的开源项…

作者头像 李华
网站建设 2026/6/30 20:25:06

PaddlePaddle模型转ONNX格式实操:依赖cuda安装正确版本

PaddlePaddle模型转ONNX格式实操:依赖CUDA安装正确版本 在AI工程化落地日益深入的今天,一个训练好的深度学习模型能否快速、稳定地部署到目标环境中,往往决定了整个项目的成败。尤其是在企业级场景中,训练可能使用PaddlePaddle这样…

作者头像 李华
网站建设 2026/6/30 2:19:40

影视配音新方式:GPT-SoVITS实现角色声音复刻

影像与声音的重构:用 GPT-SoVITS 实现角色语音的“数字永生” 在一部经典老片修复项目中,团队面临一个棘手问题:主角的关键对白因原始磁带损坏而缺失,而配音演员已年逾古稀、无法重新录制。传统补录方案几乎不可行——直到他们尝试…

作者头像 李华