Shell条件语句

本文详细介绍了Linux Shell中的条件测试,包括文件测试、整数值比较、字符串比较和逻辑测试,以及如何使用if和case语句来实现流程控制。通过示例展示了如何检查磁盘占用、CPU使用和内存使用等性能指标,并提到了数据监控和警报邮件的配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

test条件测试

测试表达式是否成立,若成立返回0,否则返回其他数值
格式1:test 条件表达式
格式2:[ 条件表达式 ]

文件测试

[ 操作符 文件或目录 ]

常用的测试操作符
-d:测试是否为目录(Directory)
-e:测试目录或文件是否存在(Exist)
-f:测试是否为文件(File)
-r:测试当前用户是否有权限读取(Read)
-w:测试当前用户是否有权限写入(Write)
-x:测试当前用户是否有权限执行(eXcute)

[root@server2 ~]# touch aa
[root@server2 ~]# ls -lh
[root@server2 ~]# test -f aa
[root@server2 ~]# echo $?
0                                  返回0表示条件成立
[root@server2 ~]# test -d aa
[root@server2 ~]# echo $?
1                                  返回1表示条件不成立
[root@server2 ~]# [ -f aa ]
[root@server2 ~]# echo $?
0
[root@server2 ~]# [ -d aa ]
[root@server2 ~]# echo $?
1

整数值比较

[ 整数1 操作符 整数2 ]

常用的测试操作符
-eq:等于(Equal)
-ne:不等于(Not Equal)
-gt:大于(Greater Than)
-lt:小于(Lesser Than)
-le:小于或等于(Lesser or Equal)
-ge:大于或等于(Greater or Equal)

[root@server2 ~]# who
[root@server2 ~]# who | wc -l    条件判断先取值
5
[root@server2 ~]# [ $(who | wc -l) -ge 4 ] && echo "too many."
too many.          用户数大于等于4               
[root@server2 ~]# [ $(who | wc -l) -lt 4 ] && echo "too many."

free -m:查看内存使用情况
grep Mem:检索Mem字段
awk ‘{print $7}’:输出第7字段
查看资源占用:内存、CPU、磁盘空间

字符串比较

3种格式:
[ 字符串1 = 字符串2]
[ 字符串1 != 字符串2]
[ -z 字符串 ]

常用的测试操作符:
=:字符串内容相同
!=:字符串内容不同,!号表示取反
-z:字符串内容为空(空格不为空)

[root@server2 ~]# [ 'b' = 'c' ]
[root@server2 ~]# echo $?
1
[root@server2 ~]# [ 'b' = 'c' ] && echo "b不等于c"
[root@server2 ~]# [ 'b' != 'c' ] && echo "b不等于c"
b不等于c
[root@server2 ~]# [ -z '' ] && echo "空的"
空的

逻辑测试

[ 表达式1 ] 操作符 [ 表达式2 ]
命令1 操作符 命令2

常用的测试操作符:
-a或&&:逻辑与,而且的意思(第一个不成立后面就不会再看了)
-o或||:逻辑或,或者的意思(第一个成立就直接成立)
!:逻辑否,取反 (和后面一个字符中间有空格)

if语句

  • 单分支结构
if 条件测试操作
   then 命令序列
fi
  • 双分支结构
if 条件测试操作
   then 命令序列1
   else 命令序列2
fi
  • 多分支结构
if 条件测试操作1
   then 命令序列1
elif 条件测试操作2
   then 命令序列2
   else
   命令序列3
fi

提取性能监控指标项目(磁盘占用,CPU使用,内存使用)

  • 磁盘占用情况
[root@server2 ~]# df -Th
[root@server2 ~]# df -Th | grep "/$"
[root@server2 ~]# df -Th | grep "/$" | awk '{print $6}'
[root@server2 ~]# df -Th | grep "/$" | awk '{print $6}' | awk -F% '{print $1}'
[root@server2 ~]# disk=$( df -Th | grep "/$" | awk '{print $6}' | awk -F% '{print $1}')
[root@server2 ~]# [ $disk -gt 10 ] && echo "too less."
[root@server2 ~]# [ $disk -lt 10 ] && echo "too less."
  • 内存占用情况
[root@server2 ~]# free
[root@server2 ~]# free | grep "Mem:" | awk '{print $3}'
[root@server2 ~]# free | grep "Mem:" | awk '{print $2}'
[root@server2 ~]# expr $(free | grep "Mem:" | awk '{print $3}') / $(free | grep "Mem:" | awk '{print $2}')
[root@server2 ~]# expr $(free | grep "Mem:" | awk '{print $3}') \* 100 / $(free | grep "Mem:" | awk '{print $2}')
[root@server2 ~]# echo $(expr $(free | grep "Mem:" | awk '{print $3}') \* 100 / $(free | grep "Mem:" | awk '{print $2}'))
[root@server2 ~]# mem=$(expr $(free | grep "Mem:" | awk '{print $3}') \* 100 / $(free | grep "Mem:" | awk '{print $2}'))
  • CPU占用率
[root@server2 ~]# mpstat
[root@server2 ~]# mpstat | tail -1 | awk '{print $12}'
[root@server2 ~]# mpstat | tail -1 | awk '{print $12}' | awk -F. '{print $1}'
[root@server2 ~]# expr 100 - $( mpstat | tail -1 | awk '{print $12}' | awk -F. '{print $1}')
  • 配置数据
disk=$( df -Th | grep "/$" | awk '{print $6}' | awk -F% '{print $1}')     
mem=$(expr $(free | grep "Mem:" | awk '{print $3}') \* 100 / $(free | grep "Mem:" | awk '{print $2}'))
cpu=$(expr 100 - $( mpstat | tail -1 | awk '{print $12}' | awk -F. '{print $1}'))
if [ $disk -ge 85 ] then echo "磁盘占有率超过85%"
if [ $mem -ge 90 ] then echo "内存占有率超过90%"
if [ $cpu -ge 90 ] then echo "cpu占有率超过90%"
  • 发送警报邮件
[root@server2 ~]# rpm -qa mailx   查看是否安装程序
[root@server2 ~]# vi /etc/mail.rc   配置文件
[root@server2 ~]# echo "123456" | mail -s "test" 123456789@qq.com
发送邮件,内容:123456
set from=123456789@qq.com  发送邮箱地址
set smtp=smtp.qq.com       邮箱使用的smtp服务器的域名
set smtp-auth-user=123456789@qq.com  smtp邮件发送时登录的账号
set smtp-auth-password=........    授权码
set smtp-auth=login           smtp的状态,登录状态

case语句结构(双分号)

case  变量值 in
模式1)
命令序列1
;;
模式2)
命令序列2
; ;
....
*)
默认命令序列
esac

示例

[root@server2 ~]# vi case.sh
[root@server2 ~]# chmod +x case.sh
[root@server2 ~]# ./case.sh

#!/bin/bash
# 判断输入的字符是哪种类型
read -p "请输入一个字符并按enter回车确认" key
case "$key" in
    [a-z]|[A-Z])                   匹配任意字母
         echo "您输入的是字母."    
      ;;
    [0-9])                            匹配任意数字
         echo "您输入的是数字."
      ;;     
     *)                                  匹配任意字符 
         echo "您输入的是空格,功能键,其它控制字符." 
exit 1
esac
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值