从lastlog捕获错误(unix和bash)



我正在创建一个脚本来检测哪个用户有一段时间没有连接到服务器。

到目前为止,一切都很好,但现在试图从我的脚本生成的列表中删除一些不需要的条目。我想在我的脚本中添加一个例外,以便在使用未使用的参数调用 lastlog 时,输出不会打印到屏幕上。

我尝试过类似的东西:

if [ $? -gt 0 ]; then
    echo "ERROR!"
fi

问题是 lastog 在成功时返回 0,但只是:

lastlog: Unknown user or range: infolog

出错时。所以我无法抓住这个解释。

这是我的代码(非常简单)

#!/bin/bash
FILES=../*
for year in 2000 2001 2002 2003 2004 2005 2006 2007 2008 2009 2010 2011 2012
do
    for f in $FILES
    do
        tempUser=${f:3:20}
        userCommand=`lastlog -u $tempUser | grep $year`
        if [ ${#userCommand} != 0 ]   
        then
          echo "$userCommand"
        fi
    done
done

您可以非常简单地测试这一点,但是在我方便的 Linux 框中,lastlog确实为错误的用户名设置了非零状态:

$ if lastlog -u nosuchuser; then echo no error; else echo error; fi
lastlog: Unknown user or range: nosuchuser
error

如果在管道中运行它,则问题在于管道序列的"状态"是管道最后一个元素的状态:

$ progA | progB | progC
$ echo $?

打印程序 C 的状态。

如果你使用 bash,你可以通过 bash 的 PIPESTATUS 数组变量从所有内容中获取状态:

bash$ progA | progB | wc
bash: progB: command not found
bash: progA: command not found
      0       0       0
bash$ echo ${PIPESTATUS[@]}
127 127 0
bash$

这应该让你走完剩下的路。


编辑:你甚至可能不在乎,只是在寻找一种从lastlog扔掉stderr输出的方法,在这种情况下,请考虑:
$ lastlog 2>/dev/null | grep ...

最新更新