cgi bash脚本不等待命令的所有输出

时间:2013-02-03 03:07:14

标签: apache bash cgi

我有一个cgi脚本正在运行,但是我遇到了cgi脚本的问题,没有等待命令的所有输出。

这是cgi脚本:

#!/bin/bash
echo Content-type: text/plain
echo ""

case "$QUERY_STRING" in
  start)
    service servicename start
    ;;
  stop)
    service servicename stop
    ;;
  restart)
    service servicename restart
    ;;
  backup)
    service servicename backup
    ;;
  checkisup)
    service servicenamet checkisup
    ;;
  status)
    service servicename status
    ;;
  *)
  echo "Usage: $0 {checkisup|start|stop|restart|backup|status|restart}"
  exit 1
  ;;
esac

exit 0

当我使用script.cgi?status

调用状态时

它执行我的服务的状态功能

  if pgrep -u $USERNAME -f $SERVICE > /dev/null
  then
    pre_log_len=`wc -l "$PATH/server.log" | awk '{print $1}'`
    echo "$SERVICE is running... executing command"
    as_user "screen -p 0 -S screenname -X eval 'stuff \"$command\"\015'"
    sleep .1
    tail -n $[`wc -l "$PATH/server.log" | awk '{print $1}'`-$pre_log_len] "$PATH/server.log"
  fi

我遇到问题的部分是当函数到达sleep .1时,cgi脚本将继续而不等待高输出。

有什么想法吗?

1 个答案:

答案 0 :(得分:1)

您可能看不到tail的任何输出,因为-n参数的算术结果可能为0:

anew@Wintermute:work$ wc -l dev-configuration.json 
     105 dev-configuration.json
anew@Wintermute:work$ tail -n 0 dev-configuration.json 
anew@Wintermute:work$