• 使用Linux输出重定向将debug信息和ERROR信息分离


    最近在安装Apache sentry,发现启动metastore和hiveserver2服务的时候会弹出大量的debug信息,有时候需要在一长串的信息中寻找ERROR信息,觉得挺花时间的,于是想到使用重定向将debug信息输出到指定的debug目录下,ERROR信息输出到ERROR目录下,这样能提高效率。


    1、下面先简要介绍一下Linux重定向


    0、1和2分别表示标准输入、标准输出和标准错误信息输出,可以用来指定需要重定向的标准输入或输出。 
    在一般使用时,默认的是标准输出,即1.当我们需要特殊用途时,可以使用其他标号。例如,将某个程序的错误信息输出到log文件中:

    ./program 2> log
    
    • 1
    • 2

    这样标准输出还是在屏幕上,但是错误信息会输出到log文件中。另外,也可以实现0,1,2之间的重定向。例如:

    2>&1
    • 1

    表示将错误信息重定向到标准输出。

    Linux下还有一个特殊的文件/dev/null,它就像一个无底洞,所有重定向到它的信息都会消失得无影无踪。这一点非常有用,当我们不需要回显程序的所有信息时,就可以将输出重定向到/dev/null。如果想要正常输出和错误信息都不显示,则要把标准输出和标准错误都重定向到/dev/null, 例如:

    ls 1> /dev/null 2> /dev/null
    • 1

    还有一种做法是将错误重定向到标准输出,然后再重定向到 /dev/null,例如:

    ls >/dev/null 2>&1
    • 1

    注意:此处的顺序不能更改,否则达不到想要的效果,此时先将标准输出重定向到 /dev/null,然后将标准错误重定向到标准输出,由于标准输出已经重定向到了/dev/null,因此标准错误也会重定向到/dev/null,于是一切静悄悄:-)


    2、后台运行指定程序,并将输出重定向


    为了让指定程序在后台运行,需要使用nohup命令,格式如下:

    nohup <程序名> &
    • 1

    但是,需要注意的是,使用nohup时,会自动将输出写入nohup.out文件中,且nohup.out文件保存在执行该命令的当前目录。为了将提示信息和错误信息分别存储在指定路径下,需要使用重定向。

    将提示信息存储在/usr/local/sentry/log/debug.out,将ERROR 信息存储在/usr/local/sentry/log/error.out下。

    nohup <程序名或服务> 1>> /usr/local/sentry/log/debug.out 2>> /usr/local/sentry/log/error.out &
  • 相关阅读:
    xpath获取a标签下文本
    Python学习笔记Day26
    DNS原理
    命令实战解析
    linux系统ext文件系统知识
    磁盘分区重点知识
    机械磁盘读写磁盘数据的原理
    linux用户管理
    linux命令讲解
    linux系统定时任务
  • 原文地址:https://www.cnblogs.com/fire909090/p/8134171.html
Copyright © 2020-2023  润新知