我有这个要比较cpuload
的脚本大于 limit 10
。
#!/bin/bash
cpuload=$(uptime | cut -d' ' -f 13 | sed '$ s/.$//')
limit=10
echo
echo "cpuload = $cpuload, limit = $limit"
echo
[[ $cpuload > $limit ]] && echo | mail -s "cpuload $cpuload is higher than $limit!" EMAIL
现在,即使 value 低于 limit ,我也会收到电子邮件(3 > 10)
。
问题出在哪里?
我尝试了条件语法的组合,但有时它可以工作,有时不能......我有点困惑。
谢谢。
更新
cpu_load=$(uptime | cut -d' ' -f 13 | sed '$ s/.$//')
limit=1
send_email(){
echo | mail -s "makroczsk, cpuload $cpu_load is higher than limit $limit!" $email_to
}
echo "cpuload = $cpu_load (${cpu_load%%.*}), limit = $limit"
[[ (( ${cpu_load%%.*} > $limit )) ]] && send_email
[[ ${cpu_load%%.*} -gt $limit ]] && send_email
cpuload = 3.10, limit = 10
./check-cpuload.sh: line 9: [[: 3.10: syntax error: invalid arithmetic operator (error token is ".10")
在第一种情况下,电子邮件仍在发送。
更新 2
这行得通。但我不确定为什么。:/
cpu_load=$(uptime | cut -d' ' -f 13 | sed '$ s/.$//')
limit=1
send_email(){
echo | mail -s "makroczsk, cpuload $cpu_load is higher than limit $limit!" $email_to
}
echo "cpuload = $cpu_load (${cpu_load%%.*}), limit = $limit"
#[[ (( ${cpu_load%%.*} > $limit )) ]] && send_email
[[ ${cpu_load%%.*} -gt $limit ]] && send_email
出于多种原因,您在这里的做法注定要失败。
首先,即使您得到正确的算术比较语法,即:
(POSIX shell 兼容)或
(bash / ksh 扩展测试)或
bash shell 仅支持整数运算,因此您需要首先修剪掉任何尾随小数,注意您的语言环境的数字表示,如 HuHa 所述。
请注意,当您在 bash 中使用
[[ $cpuload > $limit ]]
这是一个语法上有效的比较时,它会“奇怪地”工作,因为它按字典顺序逐个字符地比较 RHS 和 LHS。尤其是,因为 character
3
在字典上大于 character1
;然而因为 character
0
在字典上小于 character1
。底线是,如果您想在 bash 脚本中进行浮点运算,您将需要一个外部程序,例如bc
orawk
或perl
。1其次,
uptime
输出是为了人类可读性,而不是机器解析。特别是,时间格式取决于实际的正常运行时间,例如:(重启前)
(重启后)
尝试用它来标记它
cut -d' '
特别脆弱,因为它依赖于每个字段的左填充量:例如,如果天数/小时/分钟/用户数从一位数翻转到两位数,它将失败。相反,我建议直接从那里读取平均负载
/proc/loadavg
——无论如何,这是从哪里uptime
得到它的,你可以用以下方式确认strace
:格式是简单的空格分隔字段,您可以轻松解析和测试,
awk
例如:笔记:
ksh
orzsh
。