今天编写一个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就暂时突出在这一行了。(通过将输入操作符改为“<<-”可以解决这个问题,但是这里也无伤大雅)。
本文转自zylhsy 51CTO博客,原文链接:http://blog.51cto.com/yunlongzheng/558798,如需转载请自行联系原作者