来自lastlog的错误(unix& bash)

时间:2012-04-29 22:04:47

标签: linux bash unix

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

到目前为止一切都很好,但现在尝试从我的脚本生成的列表中删除一些不需要的条目。我想在我的脚本中添加一个异常,以便在使用非使用参数调用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

1 个答案:

答案 0 :(得分:1)

你可以很简单地测试一下,但是在我方便的linux盒子lastlog确实为坏用户名设置了非零状态:

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

如果你在管道中运行它,问题是管道序列的“状态”是管道的 last 元素的状态:

$ progA | progB | progC
$ echo $?

打印progC的状态。

如果你使用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