在执行 Shell 脚本时,如果需要将 所有输出(包括标准输出 stdout 和错误输出 stderr 重定向到日志文件,可以使用以下方法:


方法 1:直接重定向(推荐)

/appdata/mysql_backup_dump.sh > /var/log/mysql_backup.log 2>&1
  • >:将标准输出(stdout)重定向到 /var/log/mysql_backup.log
  • 2>&1:将错误输出(stderr)合并到标准输出(即也写入日志文件)。
  • 效果:所有输出(包括 echomysqldump 正常信息、错误信息)都会写入日志文件。

方法 2:追加模式(不覆盖旧日志)

/appdata/mysql_backup_dump.sh >> /var/log/mysql_backup.log 2>&1
  • >>:追加到日志文件(而不是覆盖),适合长期运行的备份任务。

方法 3:使用 tee 命令(同时输出到屏幕和文件)

/appdata/mysql_backup_dump.sh 2>&1 | tee -a /var/log/mysql_backup.log
  • tee -a:将输出 同时显示在终端追加到日志文件-a 表示追加)。
  • 适用场景:调试时想实时查看输出,同时保留日志。

方法 4:在脚本内部重定向

如果脚本是自己编写的,可以在脚本开头指定日志文件:

#!/bin/bash
exec > /var/log/mysql_backup.log 2>&1  # 所有后续输出都重定向到日志
echo "Backup started at $(date)"
# 备份命令(如 mysqldump)
  • exec:重定向整个脚本的输出,包括后续所有命令。

方法 5:使用 logger 写入系统日志

如果希望日志进入系统日志(如 /var/log/syslog/var/log/messages):

/appdata/mysql_backup_dump.sh > /tmp/backup.log 2>&1
logger -t "MySQL_BACKUP" -f /tmp/backup.log  # 写入系统日志
rm -f /tmp/backup.log  # 可选:删除临时日志文件
  • logger -t "TAG":给日志添加标签(方便过滤)。
  • -f:指定日志文件路径。

最佳实践

  1. 推荐方法 1 或 2(简单可靠)。
  2. 日志轮转:使用 logrotate 管理日志文件,避免日志过大:
    # /etc/logrotate.d/mysql_backup
    /var/log/mysql_backup.log {dailyrotate 7compressmissingoknotifempty
    }
    
  3. 在 cron 中记录日志
    0 2 * * * /appdata/mysql_backup_dump.sh > /var/log/mysql_backup.log 2>&1
    

验证日志是否生效

tail -f /var/log/mysql_backup.log  # 实时查看日志

或手动运行脚本并检查日志:

/appdata/mysql_backup_dump.sh > /var/log/mysql_backup.log 2>&1
cat /var/log/mysql_backup.log

总结

方法命令特点
覆盖日志> log 2>&1每次运行覆盖旧日志
追加日志>> log 2>&1保留历史日志
屏幕+文件2>&1 | tee -a log调试时使用
脚本内重定向exec > log 2>&1整个脚本生效
系统日志logger -t TAG -f log集成到系统日志

选择最适合你的方式即可!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/89195.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/89195.shtml
英文地址,请注明出处:http://en.pswp.cn/pingmian/89195.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Postman接口测试实现UI自动化测试

Selenium底层原理 3天精通Postman接口测试,全套项目实战教程!!运行代码,启动浏览器后,webdriver会将浏览器绑定到特定的端口,作为webdriver的remote server(远程服务端),…

CSS动画与变换全解析:从原理到性能优化的深度指南

引言:现代Web动画的技术革命 在当今的Web体验中,流畅的动画效果已成为用户交互的核心要素。根据Google的研究,60fps的动画可以使用户参与度提升53%,而卡顿的界面会导致跳出率增加40%。本文将深入剖析CSS动画(animation…

NPM组件 @ivy-shared-components/iconslibrary 等窃取主机敏感信息

【高危】NPM组件 ivy-shared-components/iconslibrary 等窃取主机敏感信息 漏洞描述 当用户安装受影响版本的 ivy-shared-components/iconslibrary 等NPM组件包时会窃取用户的主机名、用户名、工作目录、IP地址等信息并发送到攻击者可控的服务器地址。 MPS编号MPS-zh19-e78w…

Fail2ban防止暴力破解工具使用教程

Fail2ban防止暴力破解工具使用教程场景Fail2ban安装和配置安装配置原理遇到的问题以及解决办法问题1:设置的策略是10分钟内ssh连接失败2次的ip进行封禁,日志中实际却出现4次连接。问题2:策略设置为1分钟内失败两次,封禁ip。但通过…

亚远景科技助力长城汽车,开启智能研发新征程

亚远景科技助力长城汽车,开启智能研发新征程在汽车智能化飞速发展的当下,软件研发管理成为车企决胜未来的关键。近日,亚远景科技胡浩老师应邀为长城汽车开展了一场主题深刻且极具实用价值的培训。本次培训聚焦软件研发管理导论 - 建立机器学习…

图算法在前端的复杂交互

引言 图算法是处理复杂关系和交互的强大工具,在前端开发中有着广泛应用。从社交网络的推荐系统到流程图编辑器的路径优化,再到权限依赖的拓扑排序,图算法能够高效解决数据之间的复杂关联问题。随着 Web 应用交互复杂度的增加,如实…

Prometheus Operator:Kubernetes 监控自动化实践

在云原生时代,Kubernetes 已成为容器编排的事实标准。然而,在高度动态的 Kubernetes 环境中,传统的监控工具往往难以跟上服务的快速变化。Prometheus Operator 应运而生,它将 Prometheus 及其生态系统与 Kubernetes 深度融合&…

一种融合人工智能与图像处理的发票OCR技术,将人力从繁琐的票据处理中解放

在数字化浪潮席卷全球的今天,发票OCR技术正悄然改变着企业财务流程的运作模式。这项融合了人工智能与图像处理的前沿技术,已成为财务自动化不可或缺的核心引擎。核心技术:OCR驱动的智能识别引擎发票OCR技术的核心在于光学字符识别&#xff08…

时空大数据:数字时代的“时空罗盘“

引言:为何需要“时空大数据”?“大数据”早已成为热词,但“时空大数据”的提出却暗含深刻逻辑。中国工程院王家耀院士指出,早期社会存在三大认知局限:过度关注商业大数据而忽视科学决策需求;忽视数据的时空…

PySide笔记之信号连接信号

PySide笔记之信号连接信号code review! 在 PySide6(以及 Qt 的其他绑定,如 PyQt)中,信号可以连接到信号。也就是说,可以把一个信号的发射,作为另一个信号的触发条件。这样做的效果是:当第一个信…

Linux操作系统之线程:线程概念

目录 前言: 一、进程与线程 二、线程初体验 三、分页式存储管理初谈 总结: 前言: 大家好啊,今天我们就要开始翻阅我们linux操作系统的另外一座大山:线程了。 对于线程,大体结构上我们是划分为两部分…

windows利用wsl安装qemu

首先需要安装wsl,然后在swl中启动一个子系统。这里我启动一个ubuntu22.04。 接下来的操作全部为在子系统中的操作。 检查虚拟化 在开始安装之前,让我们检查一下你的机器是否支持虚拟化。 要做到这一点,请使用以下命令: sean@DESKTOP-PPNPJJ3:~$ LC_ALL=C lscpu | grep …

如何使用 OpenCV 打开指定摄像头

在计算机视觉应用中,经常需要从特定的摄像头设备获取视频流。例如,在多摄像头环境中,当使用 OpenCV 的 cv::VideoCapture 类打开摄像头时,如果不指定摄像头的 ID,可能会随机打开系统中的某个摄像头,或者按照…

JAVA面试宝典 -《分布式ID生成器:Snowflake优化变种》

🚀 分布式ID生成器:Snowflake优化变种 一场订单高峰,一次链路追踪,一条消息投递…你是否想过,它们背后都依赖着一个“低调却关键”的存在——唯一ID。本文将带你深入理解分布式ID生成器的核心原理与工程实践&#xff0…

苹果的机器学习框架将支持英伟达的CUDA平台

苹果专为Apple Silicon设计的MLX机器学习框架即将迎来CUDA后端支持,这意义重大。原因如下。 这项开发工作由GitHub开发者zcbenz主导(据AppleInsider报道),他于数月前开始构建CUDA支持的原型。此后他将项目拆分为多个模块&#xff…

golang语法-----变量、常量

变量1、声明与初始化(1)标准声明 (先声明,后赋值)var age int // 声明一个 int 类型的变量 age,此时 age 的值是 0 fmt.Println(age) // 输出: 0age 30 // 给 age 赋值 fmt.Println(age) // 输出: 30//int 的零…

Jenkins+Docker(docker-compose、Dockerfile)+Gitee实现自动化部署

项目目录结构 project-root/ ├── pom.xml ├── docker │ ├── copy.sh │ ├── file │ │ ├── jar │ │ │ └── 存放执行copy.sh以后jar包的位置 │ │ └── Dockerfile │ └── docker-compose.yml ├── docker-only-test │ ├─…

TASK01【datawhale组队学习】地瓜机器人具身智能概述

https://github.com/datawhalechina/ai-hardware-robotics 参考资料地址 具身智能(Embodied AI) 具身智能 智能的大脑 行动的身体。 比例(Proportional)、积分(Integral)、微分(Derivative&a…

uni-app 配置华为离线推送流程

1、首先需要创建一个华为开发者账号,我这个是个人开发账号 申请开发者账号 2、去AppGallery Connect登陆我们刚刚创建好的账号,点击页面的APP进入到如下3 AppGallery Connect ‎‎‎‎‎ ‎3、在AppGallery Connect 网站中创建一个 Android应用、点击…

当下主流摄像头及其核心参数详解

📖 推荐阅读:《Yocto项目实战教程:高效定制嵌入式Linux系统》 🎥 更多学习视频请关注 B 站:嵌入式Jerry 当下主流摄像头及其核心参数详解 一、摄像头发展概述 摄像头作为现代智能设备(如手机、安防、车载、工业等&am…