今天编写一个AIX上的KSH脚本,功能是按期收集VMSTAT信息而且放入ORACLE数据库,以供查询分析,脚本以下:sql
#!/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就暂时突出在这一行了。(经过将输入操做符改成“<<-”能够解决这个问题,可是这里也无伤大雅)。