Rust Tracing 入门

Tracing 是一个强大的工具,开发人员可以使用它来了解代码的行为、识别性能瓶颈和调试问题。 Rust 是一种以其性能和安全保证而闻名的语言,在它的世界中,跟踪在确保应用程序平稳高效运行方面发挥着至关重要的作用。

在本文中探讨Tracing 的概念、它在 Rust 生态系统中的重要性,以及如何利用它来改进 Rust 应用程序。无论您是希望深入研究性能优化的经验丰富的 Rustace 爱好者,还是有兴趣了解更多调试工具的语言新手,本指南都旨在为您提供在 Rust 中有效使用Tracing 所需的知识。

理解Tracing

在我们深入研究 Rust 中的Tracing细节之前,了解什么是Tracing以及为什么它是开发人员的重要工具非常重要。

在软件开发的背景下,Tracing是一种用于监视程序执行的方法。它涉及记录有关程序执行的信息,例如函数调用、变量值,甚至整个调用堆栈。然后可以分析这些信息(通常称为“Trace data”),以深入了解程序的行为。

Tracing在调试和性能优化中起着关键作用。通过提供程序执行的详细视图,Tracing使开发人员能够识别瓶颈、发现低效率并了解错误的根本原因。这使其成为提高代码性能和可靠性的宝贵工具。


接下来将探讨如何在 Rust 应用程序中使用Tracing。


在 Rust 中,Tracing是通过一个名为 tracing的crate 强大库来实现的。该包提供了一个框架,用于检测 Rust 程序以收集结构化的、基于事件的诊断信息。与传统日志记录不同, Tracing旨在了解系统中一个事件或一系列事件的上下文,使其成为诊断复杂系统的强大工具。


要开始在 Rust 中使用Tracing,您首先需要将 tracing 箱添加到您的项目中。这可以通过将以下行添加到您的 Cargo.toml 文件中来完成:

[dependencies]
tracing = "0.1"


将 tracing 包添加到您的项目后,您可以通过将以下行添加到主 Rust 文件来开始使用它:

use tracing::{info, trace, warn, error};


tracing 包为不同级别的诊断信息提供了多个宏,包括 info! 、 trace! 、 warn! 和 error!


在 Rust 项目中实现Tracing

现在我们已经在项目中添加了 tracing ,让我们深入了解如何在 Rust 项目中实现Tracing。

use tracing::{info, trace, warn, error};

fn main() {
    tracing::subscriber::set_global_default(
        tracing_subscriber::FmtSubscriber::new()
    ).expect("setting default subscriber failed");

    let number = 5;
    info!("The number is {}", number);

    let result = compute(number);
    info!("The result is {}", result);
}

fn compute(n: i32) -> i32 {
    trace!("Computing the value...");
    if n > 10 {
        warn!("The number is greater than 10");
    } else if n < 1 {
        error!("The number is less than 1");
    }
    n * 2
}


在上面的代码中,我们首先为跟踪事件设置一个默认订阅者。然后,我们使用 info! 宏在信息级别记录事件。在 compute 函数中,我们使用 trace! 、 warn! 和 error! 宏根据 n 。


这是一个简单的示例,但它说明了 tracing 包的基本用法。您可以根据需要向代码中添加更复杂的跟踪逻辑。


在下一节中,我们将讨论如何分析程序生成的跟踪数据。

分析Trace数据


在 Rust 应用程序中实现Tracing并生成trace数据后,下一步就是分析这些数据以深入了解应用程序的行为。
分析trace数据涉及检查记录的事件并使用它们来了解程序的执行流程。这可以帮助您识别模式、发现异常并了解应用程序的性能特征。
有多种工具可用于分析 Rust 中的trace数据。最流行的之一是 tracing-subscriber ,它提供了用于实现和配置订阅者的实用程序。


以下是如何使用 tracing-subscriber 分析trace数据的基本示例:

use tracing_subscriber::FmtSubscriber;

fn main() {
    let subscriber = FmtSubscriber::builder()
        .with_max_level(tracing::Level::TRACE)
        .finish();

    tracing::subscriber::set_global_default(subscriber)
        .expect("setting default subscriber failed");

    // Your application code goes here...
}


在此示例中,我们创建一个 FmtSubscriber 并将其设置为全局默认值。 with_max_level 函数用于设置订阅者将记录的事件的最大级别。在本例中,我们将记录所有事件直至 TRACE 级别。


收集跟踪数据后,您可以使用各种工具对其进行可视化和解释。这可以帮助您了解应用程序的性能特征、识别瓶颈并发现潜在问题。


在下一节中,我们将探索 Rust 中的一些高级跟踪技术。


先进的trace技术

随着您对 Rust 中的基本跟踪越来越熟悉,您可能会发现自己需要更高级的技术来诊断复杂问题或优化性能。 Rust 生态系统提供了多种用于高级跟踪的强大工具和库。


其中一个工具是 tracing-futures ,它是 tracing 包的扩展,它为使用诊断信息检测 Future 提供支持。这在异步 Rust 程序中特别有用,其中理解 Future 的行为对于调试和性能优化至关重要。


另一个有用的工具是 tracing-serde ,它提供了 Serializer 实现来序列化 tracing 的 Id 、 Metadata 、 Event 、 Record 和 Span 类型作为 Serde Serializable 类型。当您需要序列化跟踪数据以进行分析或传输时,这非常有用。

以下是如何在 Rust 项目中使用 tracing-futures 和 tracing-serde 的示例:

use tracing::{info, Instrument};
use tracing_futures::WithSubscriber;
use tracing_serde::AsSerde;

#[tokio::main]
async fn main() {
    let subscriber = tracing_subscriber::fmt()
        .json() // Output events as JSON
        .with_env_filter("my_crate=info") // Set log filter
        .finish();

    let _guard = tracing::subscriber::set_default(subscriber);

    let future = async {
        info!("This is an async block");
        // Your async code here...
    };

    future
        .instrument(tracing::info_span!("my_span"))
        .with_subscriber(subscriber)
        .await;

    let span = tracing::info_span!("my_span");
    println!("{}", serde_json::to_string(&span.as_serde()).unwrap());
}


在此示例中,我们首先创建一个以 JSON 形式输出事件的 tracing 订阅者。然后,我们创建一个异步块,并使用 tracing-futures 中的 instrument 函数对其进行测试。 with_subscriber 函数用于将订阅者附加到未来。最后,我们使用 tracing-serde 将跨度序列化为 JSON。


以上只是 Rust 中可用的高级trace用法的几个示例。当您继续探索 Rust 生态系统时,您会发现更多旨在帮助您充分利用跟踪的工具和库。🦀

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/567177.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

数据结构之顺序表的实现(C语言版)

Hello, 大家好&#xff0c;我是一代&#xff0c;今天给大家带来有关顺序表的有关知识 所属专栏&#xff1a;数据结构 创作不易&#xff0c;望得到各位佬们的互三呦 一.前言 1.首先在讲顺序表之前我们先来了解什么是数据结构 数据结构是由“数据”和“结构”两词组合⽽来。 什…

安全特低电压 SELV(Safety Extra Low Voltage,缩写SELV) 是不接地系统的安全特低电压

SELV LED驱动器 市场上有很多LED灯是非隔离的&#xff0c;甚至还有灯条要100多伏特电压才能点亮的&#xff0c;安全吗&#xff1f; 国外多数LED驱动器标注了SELV&#xff0c;为什么&#xff1f; 安全特低电压 SELV(Safety Extra Low Voltage&#xff0c;缩写SELV) 是不接地系…

谈谈前端CSS盒模型

前言&#xff1a; 什么是CSS盒模型&#xff1f;盒模型的构造&#xff1f; 在前端开发中&#xff0c;CSS 盒模型是一种非常基础且核心的概念&#xff0c;它描述了文档中的每个元素被框架处理的方式。 ---- 打开浏览器开发者工具&#xff0c;查看Elements右侧下的Styles底部。 …

上手GitHub Copilot让AI写代码,效率飞起!

1 GitHub Copilot介绍 GitHub Copilot 由 GitHub 和 OpenAI 共同开发的人工智能代码辅助工具&#xff0c;可自动地生成高质量代码片段、上下文信息等。通过自然语言处理和机器学习技术&#xff0c;通过分析程序员编写的代码、注释和上下文信息&#xff0c;自动生成代码&#x…

【JAVA】UDP与TCP套接字编程

目录 一、UDP数据报套接字编程 1、DatagramSocket API 2、DatagramPacket API 3、InetSocketAddress API 4、示例一 5、示例二 二、TCP流套接字编程 1、ServerSocket API 2、Socket API 3、TCP中的长短连接 4、示例一 5、示例二 一、UDP数据报套接字编程 1、Datag…

山岭隧道及道路3D建模教程【Blender】

创建具有恒定坡度的山路、隧道的信息和技术似乎散布在互联网上。 在这篇文章中&#xff0c;我将它们全部收集在一起。 这篇文章的大纲如下&#xff1a; 创建一座山创建一条路挖一条隧道 道路的坡度将固定为常数&#xff0c;从而消除颠簸。 NSDT工具推荐&#xff1a; Three.j…

yolo-驾驶行为监测:驾驶分心检测-抽烟打电话检测

在现代交通环境中&#xff0c;随着汽车技术的不断进步和智能驾驶辅助系统的普及&#xff0c;驾驶安全成为了公众关注的焦点之一 。 分心驾驶&#xff0c;尤其是抽烟、打电话等行为&#xff0c;是导致交通事故频发的重要因素。为了解决这一问题&#xff0c;研究人员和工程师们…

Nginx目录浏览

类似 在nginx的配置文件中的server内配置&#xff0c;想给哪个网站开启&#xff0c;就在该网站的server中配置 server {listen 81;server_name localhost;autoindex on; # 开启目录浏览功能。autoindex_exact_size off; # 显示文件大小的时候带单位location / {root …

美国站群服务器的SEO优化策略助力提升网站流量?

美国站群服务器的SEO优化策略助力提升网站流量? 在当今数字化时代&#xff0c;网站的成功与否与其在搜索引擎结果页面上的排名密切相关。对于那些利用美国站群服务器运营多个网站的企业来说&#xff0c;通过SEO优化策略提升网站流量成为了至关重要的任务。然而&#xff0c;要…

最大层内元素和

题目链接 最大层内元素和 题目描述 注意点 返回层内元素之和 最大 的那几层&#xff08;可能只有一层&#xff09;的层号&#xff0c;并返回其中 最小 的那个树中的节点数在 [1, 10000]范围内-10^5 < Node.val < 10^5 解答思路 广度优先遍历树&#xff0c;使用队列存…

如何有效地进行汽车制造业文件共享,一文了解

随着数字化转变&#xff0c;企业的业务文件大多通过电子形式在内外部流转。这增加了外发文件数据泄露或被篡改的风险&#xff0c;如何保护外发文件安全已成为企业不容忽视的课题。其中汽车制造业是一个高度依赖文件共享与协作的行业&#xff0c;涉及设计图纸、技术文件、供应链…

TI API ,详情见ti.com

TI API &#xff0c;详情见ti.com TI API 接口开发&#xff0c;实现货品查询、查询订单、自动下单、抢购等功能。

Open Footprint®论坛数据模型Snapshot发布,与您全‘绿’以赴!

正值第55个“&#x1f30d;世界地球日”&#xff0c;The Open Group Open Footprint论坛很高兴地正式宣布《Open Footprint数据模型Snapshot》”的可用性。我们的期望是&#xff0c;一旦被广泛采用&#xff0c;数据模型将大大缓解内部以及范围3排放数据共享问题&#xff0c;有效…

IntelliJ IDEA2020下使用Maven构建Scala 项目

1.创建maven文件 2.进入pom.xml导入依赖 <!--添加spark的依赖--><dependency><groupId>org.apache.spark</groupId><artifactId>spark-core_2.12</artifactId><version>3.2.1</version></dependency><!--添加scala依…

羊大师解析,夏日消暑羊奶来帮忙

羊大师解析&#xff0c;夏日消暑羊奶来帮忙 炎炎夏日&#xff0c;烈日当空&#xff0c;人们总是寻找各种方式来消暑降温。除了常见的冷饮、空调等&#xff0c;其实还有一种天然、健康的饮品可以帮助我们度过酷暑——那就是羊奶。 羊奶作为一种营养丰富的天然饮品&#xff0c;不…

一文带你掌握yaml文件的使用

在自动化测试数据存储中&#xff0c;比较常见的有csv、json、excel文件等&#xff0c;可能大家忽略了另外一个非常简单、好用的&#xff0c;而且更简洁的文件&#xff0c;那就是咱们今天的主角yaml文件。 yaml文件是一种数据序列化语言&#xff0c;其良好的跨语言、跨平台、易…

CST电磁仿真软件的激励设置和使用场导入【基础教程】

设置平面波激励 确认平面波的特性&#xff01; Simulation > Sources and Loads > Plane Wave 通过Plane Wave在远离观测对象的位置接通场源(Field Source)&#xff0c;进行入射波的仿真分析该功能主要在RCS(Radar Cross Section)和EMS(Electromagnetic Susceptibilit…

vuex数据永久存续

第一步下载 vuex 并创建store下js文件 第二步 npm install vuex-persistedstate 第三步 引用 vuex-persistedstate 配置 plugins 项 import createPersistedState from vuex-persistedstateplugins:[createPersistedState({//存储方式&#xff1a;localStorage\sessionStor…

Linux - tar (tape archive)

tar 的全称是 Tape Archive。它最初是在 Unix 系统中用于将数据写入磁带的工具&#xff0c;但现在它通常用于创建、维护、修改和提取文件的归档文件。尽管 tar 可以用于压缩和解压缩文件&#xff0c;但它本身并不进行压缩&#xff0c;而是通常与 gzip 或 bzip2 等压缩工具一起使…

阿赵UE学习笔记——29、Niagara制作火焰效果

阿赵UE学习笔记目录 大家好&#xff0c;我是阿赵。   继续学习虚幻引擎&#xff0c;之前简单介绍了Niagara粒子系统&#xff0c;这次用Niagara系统做一个火焰的效果。 一、创建发射器 和之前介绍的一样&#xff0c;先创建一个空白的发射器&#xff1a; 我把这个发射器命名为…