博客
关于我
20210204-深入理解nohup日志输出2_&1
阅读量:794 次
发布时间:2019-03-25

本文共 1023 字,大约阅读时间需要 3 分钟。

深入理解Nohup日志输出

在Linux系统操作中,Nohup命令是一个非常实用的工具,尤其是在长时间运行脚本或程序时。通过理解Nohup的工作原理和日志输出功能,开发者可以更高效地管理程序运行日志,避免因断机式中断带来的工作损失。本文将详细讲解Nohup日志输出的相关知识,并通过实例说明其实际应用场景。

Nohup启动日志输出

Nohup的全称是"no hang up",意为“无hang up”,它用于使程序继续运行,即使控制终端断开。与普通命令运行时的程序不同,Nohup允许程序在没有用户交互的情况下正常完成。例如,以下命令可以用来在后台运行一个Python脚本,并将标准输出和错误输出重定向到指定文件中:

nohup python3 produce_data_to_sqlite.py > run.log 2>&1

解释如下:- **Nohup**:表示不间断运行,即使控制终端被断开,此程序仍会继续运行。- **>run.log**:表示标准输出(标准输出)被重定向到run.log文件中。- **2>&1**:2表示标准错误(标准错误),>&表示标准错误被重定向到文件描述符1,默认为标准输出。因此,标准错误也被重定向到run.log文件中。- **1**:默认值,表示标准输出会被重定向到终端,但由于此时是追加操作,最终所有输出都会被写入run.log文件中。

标准错误示例

在编程中,有时候需要向程序输出错误信息。了解如何正确处理标准错误输出,可以帮助程序更好地报告异常情况。例如,在Java编程中,使用System.err.println来输出错误信息,如下所示:

System.err.println("error1");

参考文档

深入理解Linux shell中2>&1的含义可以从以下几个方面入手:1. **理解Linux标准输入/输出/错误(STDIN, STDOUT, STDERR)**:标准输入输出错误是将程序间通信的三个关键流。本文将重点讨论标准输出和错误输出。2. **掌握Nohup命令的使用场景**:Nohup在自动化脚本、长时间运行程序、防止进程因断机中断等场景中非常有用。3. **搭配Tee命令使用**:Nohup可以与Tee命令结合使用,实现将双向通信输出到同一文件中的功能。4. **理解日志管理基础**:熟悉如何将程序输出重定向到文件,如何管理程序日志,是系统管理员和开发人员的基础技能。

转载地址:http://izuyk.baihongyu.com/

你可能感兴趣的文章
php更新数据库失败,php – 无法更新MySQL数据库
查看>>
php机器人聊天对话框,基于AIML的PHP聊天机器人
查看>>
PHP查找数组中最大值与最小值
查看>>
php查最大值,在PHP数组中查找最大值
查看>>
php标签筛选,关于PHP CodeIgniter框架中通过<a>标签和url做多条件分类筛选
查看>>
php根据年月日计算年龄
查看>>
RabbitMQ - 单机部署(超详细)
查看>>
php检查注册,PHP检查注册的电子邮件地址是一个’school.edu’地址
查看>>
php模拟发送GET和POST请求
查看>>
RabbitMQ - 以 MQ 为例,手写一个 RPC 框架 demo
查看>>
php模板引擎smarty
查看>>
php正则表达式模式
查看>>
php正则表达式的特殊字符含义
查看>>
PHP正则表达式获取武汉市的实时pm2.5数据并邮件发送phpmailer
查看>>
RabbitMQ + JMeter组合,优化你的中间件处理方式!
查看>>
PHP水仙花问题解法之一
查看>>
php没有解析是怎么回事,linux下php文件没有被剖析怎么办?_后端开发
查看>>
php注册页面实现注册后跳转页面
查看>>
PHP消息队列的实现方式与详解,值得一看
查看>>
PHP混合Go协程并发
查看>>