(CMD1;CMD2;...)和 { CMD1;CMD2;...; } 都可以将多个命令组合在一起,批量执行
区别是??() 会建立一个子 shell? ?不会改变当前环境
? ? ? ? ? ? ? ?{}?在当前?shell? ?(注意要加结尾符; )
{?}? 里的name?会改变原来的name
test 测试文件的表达式 是否成立
格式1:test ?条件表达式
格式2:[ ?条件表达式 ?]
注意[]空格,否则会失败
测试 是否成功使用 $? ?返回值
-d:测试是否为目录(Directory)
-e:测试目录或文件是否存在(Exist)
-a:测试目录或文件是否存在(Exist) ??
-f:测试是否为文件(File)
-r:测试当前用户是否有权限读取(Read)
-w:测试当前用户是否有权限写入(Write)
-x:测试当前用户是否有权限执行(eXcute)
-L: 测试是否为软连接文件
看? ?/etc/passwd? 文件是否存在? ? (推荐使用-e? ?-a有bug)
看? ? ?当前用户(root)??是否有权限读? ? ? /etc/passwd文件
看? ? ?当前用户(root)??是否有权限执行? ? ? /etc/passwd文件
注意:?此处以实际情况为准,文件属性上所有人都没权利读,root超级管理员,可读
但是,执行权限比较特殊, 大家都没有 root 也没有。只要有一个人有,root 就有
[ 整数1 -操作符 整数2 ] 公式
-eq:第一个数等于(Equal)第二个数
-ne:第一个数不等于(Not Equal)第二个数
-gt:第一个数大于(Greater Than)第二个数
-lt:第一个数小于(Lesser Than)第二个数
-le:第一个数小于或等于(Lesser or Equal)第二个数
-ge:第一个数大于或等于(Greater or Equal)第二个数
111? 大于1110
错误
如看磁盘占有率
把磁盘使用量作为一个变量
变量值? 去和80比较
超过80报警
=:字符串内容相同
!=:字符串内容不同,! 号表示相反的意思
-z:字符串内容为空
-n: 字符是否存在
[ 字符串1 = 字符串2 ] 是否相同
[ 字符串1 != 字符串2 ] 是否不相同
[ -z 字符串 ] 是否为空
[ -n 字符串 ] 字符是否存在
注意空格
注意空格? ? !取反要靠着等号
-a或&&:逻辑与,“而且”的意思全真才为真
-o或||:逻辑或,“或者”的意思一真即为真
!:逻辑否
&& 且 全真才真 一假即假
cmd1$$cmd2? ? ? ? ? ? cmd1 成立 cmd2 成立最后结果才为真
cmd1如果为假 就不会执行cmd2 因为一假为假
ll 一真就真 全假才假
cmd1llcmd2 一个真最后结果就是真
cmd1如果为真?就不会执行cmd2 因为一真为真
cmd1 && cmd2||cmd3
如果cmd1 成功 执行cmd2 如果 cmd1不成功 就执行cmd3
cmd1 如果为真 才会执行 cmd2, 整个式子一定为真,就不需要执行cmd3
cmd1为假 不会执行cmd2 整个式子为假( cmd1 && cmd2),然后需要执行 cmd3 来判断
[[ expression ]] 用法
== 左侧字符串是否和右侧的PATTERN相同
?注意:此表达式用于[[ ]]中,PATTERN为通配符? ?= 开启通配符
=~ 左侧字符串是否能够被右侧的正则表达式的PATTERN所匹配
?注意: 此表达式用于[[ ?]]中;扩展的正则表达式? ?~?开启正则表达式
?以log?结尾的文件
if 是关键字 不是命令 test 是命令
单分支
if 判断条件;
then ? 条件为真的分支代码
fi
if 判断条件; then
?条件为真的分支代码else
?条件为假的分支代码fi
if 判断条件1
then
?条件1为真的分支代码elif 判断条件2
then
?条件2为真的分支代码elif 判断条件3;then
?条件3为真的分支代码...
else
?以上条件都为假的分支代码 ?托底fi
?先看一下,这个程序,没启动
运行脚本,输出?服务正常启动
为了看的更清楚,先卸载httpd
运行脚本并查看,安装成功
?
当你输入有误时,重新运行该脚本,exit?退出
case语句可以使脚本程序的结构更加清晰、层次分明,常用于服务的启动、重启、停止的脚本,有的服务不提供这种控制脚本,需要用case?语句编写
case语句主要适用于以下情况:
某个变量存在多种取值,需要对其中的每一种取值分别执行不同的命令序列。这种情况与多分支的? if语句非常相似,只不过 i f 语句需要判断多个 不同的条件,而 case 语句只是判断一个变量的不同取值
$i? 是变量值,如果变量值等于 PAT1 执行分支1 ;;代表结束
注意PAT1? 后面有半个括号
最后写* 有个拖底
注意最后还有个esac
case $i in
PAT1)
?分支1
?;;
PAT2)
?分支2
?;;
...
*)
?默认分支
?;;esac
?
?
注意:中文双引号? 和英文双引号