今天编写一个AIX上的KSH脚本,功能是定期收集VMSTAT信息并且放入ORACLE数据库,以供查询分析,脚本如下:

#!/usr/bin/ksh
 
export ORACLE_HOME=/home/oracle/database
export PATH=$ORACLE_HOME/bin:$PATH
SERVER_NAME=`uname -a|awk '{print $2}'`
typeset -u SERVER_NAME
export SERVER_NAME
 
SAMPLE_TIME=300
 
while true
do
        vmstat ${SAMPLE_TIME} 2 > /tmp/msg$$
        cat /tmp/msg$$|sed 1,3d| awk '{ printf("%s %s %s %s %s %s %s\n", $1, $6, $7, $14 ,$15, $16, $17) }' 
        while read RUNQUE PAGE_IN PAGE_OUT USER_CPU SYSTEM_CPU IDLE_CPU WAIT_CPU
        do
              $ORACLE_HOME/bin/sqlplus -s test/test@sid<<EOF
                insert into test.test$vmstat values (
                        sysdate,
                        $SAMPLE_TIME,
                        '$SERVER_NAME',
                        $RUNQUE,
                        $PAGE_IN,
                        $PAGE_OUT,
                        $USER_CPU,
                        $SYSTEM_CPU,
                        $IDLE_CPU,
                        0
                        );
                EXIT
                EOF
        done
done
rm /tmp/msg$$

结果悲剧就发生在上面最后一个“EOF”上,为了代码格式,我把EOF前面也加了TAB,但是这却是EOF所不允许的,出现了如下错误:
./get_vmstat.sh[13]: 0403-057 Syntax error at line 20 : `<' is not matched
EOF是代表Here Documents的结束。注意此处不能像写C程序一样,为了美观而把EOF向右缩进,因为SHELL规定EOF必须是该行唯一出现的内容,连空格都不能有。因此,这个EOF就暂时突出在这一行了。(通过将输入操作符改为“<<-”可以解决这个问题,但是这里也无伤大雅)。