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

Linux调试信息双输出:script与tee工具详解

1. Linux调试信息双输出方案概述在Linux系统开发过程中调试信息的输出管理是每个开发者都会遇到的常规需求。默认情况下使用printf等函数输出的调试信息会直接显示在终端标准输出stdout上。但在实际开发场景中我们常常需要同时满足两个看似矛盾的需求既要实时查看程序运行时的调试信息又要将这些信息完整保存到文件中供后续分析或与他人共享。这种需求在以下场景中尤为常见长时间运行的守护进程调试远程服务器问题诊断自动化测试日志收集嵌入式设备开发调试本文将详细介绍两种经典的解决方案script工具和tee工具。这两种方法各有特点适用于不同的使用场景我将结合自己多年的Linux开发经验详细解析它们的工作原理、使用技巧和实际应用中的注意事项。2. 使用script工具记录终端会话2.1 script工具的基本原理script是一个历史悠久的Unix工具它的核心功能是记录终端会话的所有输入输出。与简单的输出重定向不同script会忠实地记录终端上发生的一切包括命令输出命令输入时间戳信息控制字符和转义序列这种全量记录的特性使得script非常适合用于教学演示录制复杂调试过程记录审计和故障排查2.2 具体使用方法与参数解析基本使用语法非常简单script [options] [file]常用参数说明-a追加模式不覆盖已有文件-c直接执行指定命令而非交互式shell-f即时刷新输出适合监控-q安静模式不显示script自身的提示信息典型使用示例# 开始记录会话默认生成typescript文件 script # 指定输出文件名 script debug.log # 执行特定命令并记录 script -c make sudo make install build.log2.3 实际应用技巧与注意事项重要提示在嵌入式开发中目标系统可能没有预装script工具。这时可以考虑以下解决方案交叉编译busybox版本script工具使用nohup重定向组合方案通过ssh会话记录实现类似功能我在实际项目中总结的经验对于长时间运行的程序建议使用-f参数确保日志实时刷新结合tmux或screen使用可以避免会话中断导致记录终止记录完成后使用dos2unix处理日志文件避免Windows查看时的换行符问题可以通过SCRIPTTIMEFILE环境变量设置单独的时间记录文件3. 使用tee工具分流输出3.1 tee工具的工作机制tee是Linux管道系统中的重要工具其名称来源于T型管道分流器的形状隐喻。它的核心功能是将标准输入同时复制到标准输出屏幕一个或多个文件与script不同tee只处理数据流本身不记录终端控制字符和交互信息因此生成的日志更加干净。3.2 基础与进阶用法基本语法格式command | tee [options] file常用参数说明-a追加模式-i忽略中断信号-p诊断写入错误实际应用示例# 基本用法 ./my_program | tee output.log # 同时输出到多个文件 make 21 | tee build.log compile_warnings.log # 追加模式不覆盖原有内容 python test.py | tee -a test_results.log3.3 缓冲区机制与性能优化tee默认使用1024字节的缓冲区这意味着对于高频小数据量输出可能存在延迟可以通过stdbuf工具修改缓冲策略优化建议# 设置行缓冲立即输出每一行 stdbuf -oL ./program | tee output.log # 完全无缓冲性能影响较大 stdbuf -o0 ./program | tee output.log我在性能敏感场景下的经验对于实时性要求高的调试使用行缓冲模式生产环境建议保持默认缓冲以减少IO压力结合grep等工具可以实现日志过滤保存组合功能4. 方案对比与选型建议4.1 功能特性对比特性scripttee记录终端控制字符是否记录用户输入是否输出纯净度低含控制符高仅内容时间戳记录可选否资源占用较高较低嵌入式系统可用性常需自行移植通常已内置4.2 典型应用场景推荐选择script当需要完整复现终端会话场景调试交互式命令行程序进行教学演示录制系统默认没有重定向支持选择tee当只需要保存程序输出内容对日志文件大小敏感需要进一步管道处理输出在资源受限环境中使用4.3 混合使用高级技巧在一些复杂场景下可以组合使用这两个工具# 记录完整会话同时提取纯净输出 script -c ./run_tests.sh | tee test_output.log full_session.log这种组合既保留了完整的调试上下文又得到了便于分析的纯净日志。5. 常见问题与解决方案5.1 中文乱码问题现象日志文件中的中文显示为乱码解决方案确保终端、程序和日志文件的编码一致推荐UTF-8对于script记录可以设置LANGen_US.UTF-8 script log.txt对于tee需要保证源程序输出正确的编码5.2 日志文件过大处理优化策略使用logrotate工具定期轮转日志结合grep过滤关键信息./program | grep -E ERROR|WARN | tee filtered.log对于script可以使用-t参数添加时间戳便于后续分析5.3 权限问题处理典型错误Permission denied when writing log解决方法预先创建日志文件并设置适当权限使用tee的-a参数避免覆盖权限问题对于系统目录建议重定向到用户目录./daemon | tee ~/daemon.log5.4 实时监控技巧需要同时查看和记录实时日志时# 使用tail -f实时查看的同时记录 ./program | tee program.log tail -f program.log或者使用multitail工具./program | tee program.log | multitail - program.log6. 扩展应用与进阶技巧6.1 日志分级处理结合tee可以实现不同级别日志的分流./program 21 | tee (grep ERROR error.log) (grep DEBUG debug.log) all.log6.2 时间戳增强为tee的输出添加时间戳./program | while IFS read -r line; do echo $(date %T) $line; done | tee timed.log6.3 网络日志记录通过netcat将日志同时发送到远程服务器./program | tee (nc logs.example.com 1234) local.log6.4 嵌入式系统特别考虑对于资源受限的嵌入式环境使用busybox提供的轻量级tee考虑通过syslog机制转发日志对于没有tee的系统可以用shell替代./program | while read line; do echo $line; echo $line log.txt; done在实际嵌入式项目中我通常会采用以下策略开发阶段使用tee快速调试测试阶段结合script记录完整场景量产版本改为syslog或自定义日志模块关键日志通过LED或串口备用通道输出冗余备份

相关文章:

Linux调试信息双输出:script与tee工具详解

1. Linux调试信息双输出方案概述在Linux系统开发过程中,调试信息的输出管理是每个开发者都会遇到的常规需求。默认情况下,使用printf等函数输出的调试信息会直接显示在终端(标准输出stdout)上。但在实际开发场景中,我们…...

MATLAB实战:如何用三种噪声干扰模拟器提升脉冲雷达抗干扰能力

MATLAB实战:三种噪声干扰模拟器在脉冲雷达抗干扰测试中的应用 雷达系统在现代电子战中扮演着关键角色,而抗干扰能力是评估雷达性能的重要指标。本文将深入探讨如何利用MATLAB构建射频噪声、调幅噪声和调频噪声三种干扰模拟器,通过完整的代码实…...

从Prompt到Agent:收藏这份LLM应用落地演进指南,小白程序员必备!

本文介绍了LLM应用落地的演进过程,从最初的Prompt工程阶段,到Chain编排阶段,再到最新的Agent阶段。文章详细阐述了每个阶段的原理、优缺点及应用实例,并提供了基于Golang的Agent实现示例。通过学习本文,读者可以了解LL…...

鸿蒙3.1实测:UART调试日志去Root全流程(含init.cfg避坑指南)

鸿蒙3.1 UART调试权限管理实战:从Root到Shell的无缝切换 当你在深夜的实验室里盯着串口终端上刺眼的#符号时,是否曾思考过这个Root权限带来的安全隐患?鸿蒙系统作为新一代分布式操作系统,其权限管理机制与Android有着本质区别。本…...

胡桃工具箱:免费开源的原神桌面助手如何提升你的游戏体验

胡桃工具箱:免费开源的原神桌面助手如何提升你的游戏体验 【免费下载链接】Snap.Hutao 实用的开源多功能原神工具箱 🧰 / Multifunctional Open-Source Genshin Impact Toolkit 🧰 项目地址: https://gitcode.com/GitHub_Trending/sn/Snap.…...

别再傻傻分不清了!一文搞懂微信支付代金券和商家券的核心区别与适用场景

微信支付代金券VS商家券:技术选型与场景化应用指南 在数字化营销的浪潮中,优惠券作为连接商户与消费者的重要纽带,其技术实现方式直接影响营销效果与用户体验。微信支付提供的代金券与商家券看似功能相似,实则存在架构级差异。本文…...

如何选择ComfyUI-FramePackWrapper的模型加载方案?从技术选型到场景适配全解析

如何选择ComfyUI-FramePackWrapper的模型加载方案?从技术选型到场景适配全解析 【免费下载链接】ComfyUI-FramePackWrapper 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-FramePackWrapper 在AI视频生成工作流中,模型加载是影响效率与稳…...

Anubi基金会为何押注Cassava?深度解析Web3数据层+社交任务的黄金组合

Anubi基金会战略投资Cassava:Web3社交任务与数据层的价值重构 当Web3世界从DeFi的金融实验转向更广泛的社会化应用时,基础设施的演进正在经历一场静默的革命。Anubi基金会近期对Cassava Network的战略投资,揭示了两个关键趋势:社交…...

ISO/SAE 21434:2021(道路车辆 - 网络安全工程) 汇总

一、前言、引言(非正文章节)前言:标准制定背景、适用范围、与 ISO 26262(功能安全)的协同关系引言:网络安全对道路车辆 E/E 系统的必要性、全生命周期覆盖、风险导向原则二、正文核心章节(1–15…...

日期时间格式化中的字母代码解析与应用实例

1. 日期时间格式化字母代码入门指南 第一次接触日期时间格式化时,看到那些神秘的字母组合是不是一头雾水?yy、MM、dd这些看起来简单的代码,在实际使用中却藏着不少门道。作为处理时间数据的基础技能,掌握这些字母代码的含义和用法…...

优化算法避坑指南:为什么BFGS比DFP更常用?从数值稳定性到工程实践详解

优化算法避坑指南:为什么BFGS比DFP更常用?从数值稳定性到工程实践详解 在机器学习模型训练和工程优化问题中,我们常常需要求解无约束优化问题。当目标函数的海森矩阵难以计算或维度较高时,拟牛顿法因其出色的平衡性成为首选。但面…...

自适应滤波实战:如何用LMS算法在MATLAB/Simulink中快速搭建一个‘简易版’维纳滤波器?

自适应滤波实战:LMS算法在MATLAB/Simulink中的工程化实现 在信号处理领域,自适应滤波技术因其强大的环境适应能力而备受青睐。想象一下,你正在处理一段被噪声污染的语音信号,或是试图从复杂工业环境中提取有效振动特征——传统固定…...

SAP BAPI实战指南:核心模块高频接口速查与应用解析

1. SAP BAPI入门:为什么开发者需要这份速查手册 第一次接触SAP BAPI时,我盯着满屏的接口文档差点崩溃——光是FICO模块就有二十多个常用BAPI,每个接口的参数列表长得像毕业论文。后来在项目上踩过几次坑才明白,BAPI的难点不在于技…...

咱们今天聊点硬核但有趣的东西——用纳米级乐高积木(二氧化钛超表面)玩转光漩涡。想象一下,你手上有把能操控光波前形状的万能钥匙,这就是超表面的魅力所在

FDTD模型:基于超表面的完美涡旋光案例。 宽带任意阶 完美涡旋光束 介绍:全介质超表面实现完美矢量涡旋光束生成和完美庞加莱球生成,完美矢量涡旋光束不随拓扑荷的变化而变化,同时满足矢量光场的偏振变化,主要用于光学加密等领域&a…...

快速验证openclaw:用快马AI一键生成安装脚本与抓取原型

最近在做一个机器人抓取相关的项目,偶然发现了openclaw这个开源工具。作为一个Python实现的轻量级抓取框架,它很适合快速搭建原型。不过在实际使用过程中,我发现它的安装和配置过程有点繁琐,特别是对新手不太友好。于是尝试用InsC…...

新手零失败指南:利用快马ai轻松完成openclaw的ubuntu环境搭建

最近在学习机器人抓取相关的技术,发现OpenClaw是一个很不错的开源项目。但作为一个Ubuntu新手,在部署过程中遇到了不少坑。经过一番摸索,终于总结出了一套适合新手的零失败部署方案,今天就和大家分享一下。 准备工作 首先确保你的…...

从零开始用Typora写技术文档:完整配置指南与高效排版秘籍

从零开始用Typora打造专业技术文档:配置、排版与效率全攻略 在技术写作领域,文档的呈现质量往往直接影响知识传递的效果。Typora作为一款轻量级Markdown编辑器,凭借其即时渲染、简洁界面和强大的扩展功能,已成为众多开发者和技术作…...

ESP32嵌入式系统工具库:运行时监控、资源池与高精度时间管理

1. 项目概述sys_utils是一个面向 ESP32 平台、深度适配 ESP-IDF(Espressif IoT Development Framework)生态的系统级工具库。其定位并非通用 C 标准库的替代品,而是聚焦于嵌入式实时系统开发中高频、易错、跨模块复用的底层支撑需求——在裸机…...

AI数字人开源方案:Duix.Avatar本地化部署与应用指南

AI数字人开源方案:Duix.Avatar本地化部署与应用指南 【免费下载链接】Duix-Avatar 🚀 Truly open-source AI avatar(digital human) toolkit for offline video generation and digital human cloning. 项目地址: https://gitcode.com/GitHub_Trending…...

AMD Ryzen硬件调试指南:5分钟掌握SMUDebugTool核心功能

AMD Ryzen硬件调试指南:5分钟掌握SMUDebugTool核心功能 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: https://g…...

Phi-4-mini-reasoning作品集:自动将推理过程转化为教学级讲解语言

Phi-4-mini-reasoning作品集:自动将推理过程转化为教学级讲解语言 1. 模型简介 Phi-4-mini-reasoning是一个轻量级的开源文本生成模型,专注于将复杂推理过程转化为清晰易懂的教学语言。作为Phi-4模型家族的一员,它特别擅长处理需要逐步解释…...

别再只盯着细胞比例了!用Xenium数据做小鼠肺腺癌空间邻域分析,手把手教你找到真正的肿瘤边界

空间邻域分析:重新定义肿瘤微环境的生物学边界 在单细胞和空间组学研究中,我们常常陷入一个思维定式——过度关注细胞类型的比例变化,却忽略了细胞在三维空间中的精妙排布所蕴含的关键信息。这种比例优先的思维模式,就像试图通过统…...

Wan2.2-I2V-A14B部署教程:NVIDIA MPS多进程服务共享GPU资源方案

Wan2.2-I2V-A14B部署教程:NVIDIA MPS多进程服务共享GPU资源方案 1. 镜像概述与核心特性 Wan2.2-I2V-A14B是一款专为文本生成视频任务优化的私有部署镜像,特别针对RTX 4090D 24GB显存显卡进行了深度优化。这个镜像最大的特点是内置了完整的运行环境和模…...

Adafruit ST7735/ST7789 TFT驱动库详解:SPI接口与GFX分层架构

1. 项目概述 Adafruit ST7735 和 ST7789 库是一个面向嵌入式平台(尤其是 Arduino 生态)的轻量级图形驱动库,专为基于 Sitronix ST7735、ST7789 及 ST7796S 显示控制器的彩色 TFT 液晶模组设计。该库并非仅适配单一型号,而是通过统…...

万象视界灵坛基础教程:PyTorch+Transformers环境搭建与CLIP零样本推理入门

万象视界灵坛基础教程:PyTorchTransformers环境搭建与CLIP零样本推理入门 1. 环境准备与快速部署 1.1 系统要求 Python 3.8或更高版本支持CUDA的NVIDIA GPU(推荐)至少8GB显存(CLIP-ViT-L/14模型需求)10GB以上可用磁…...

从混乱到清晰:用QJsonObject重构你的Qt网络API数据解析层(避坑指南)

从混乱到清晰:用QJsonObject重构你的Qt网络API数据解析层(避坑指南) 在Qt开发中,与后端RESTful API交互是常见需求,但面对复杂、嵌套的JSON响应数据时,很多开发者容易陷入"面条代码"的泥潭。本文…...

3分钟掌握哔哩下载姬:零安装B站视频下载神器使用指南

3分钟掌握哔哩下载姬:零安装B站视频下载神器使用指南 【免费下载链接】downkyi 哔哩下载姬downkyi,哔哩哔哩网站视频下载工具,支持批量下载,支持8K、HDR、杜比视界,提供工具箱(音视频提取、去水印等&#x…...

避坑指南:Unreal导航网格NavMesh生成与Agent属性设置的5个常见误区

Unreal引擎导航系统避坑指南:NavMesh生成与Agent配置的5个关键误区 在Unreal引擎中构建可靠的AI寻路系统时,许多开发者常陷入相似的陷阱。当AI角色频繁卡在门槛边缘、拒绝攀爬斜坡或选择匪夷所思的绕路路线时,问题往往不在于代码逻辑&#xf…...

SerialLCD库深度解析:SerLCD v2.5串口LCD驱动实践

1. SerialLCD 库技术解析:面向嵌入式系统的 SparkFun SerLCD v2.5 串口 LCD 驱动深度实践 1.1 背景与工程定位 SerialLCD 是一个专为 SparkFun SerLCD v2.5 硬件模块设计的轻量级串口 LCD 控制库,其原始实现源自 Arduino.cc Playground 社区维护的 Ser…...

像素史诗智识终端效果展示:自动提取数据关键指标并生成结论段落

像素史诗智识终端效果展示:自动提取数据关键指标并生成结论段落 1. 产品概览:当科研遇上像素冒险 像素史诗智识终端(Pixel Epic Wisdom Terminal)是一款颠覆传统的研究报告辅助工具。它将枯燥的数据分析过程转化为一场充满像素美学的RPG冒险&#xff0…...