Linux之Bash基础特性条件测试&&自定义退出状态码(6)

简介:

条件测试

    判断某需求是否满足,需要由测试机制来实现。

    根据命令的执行状态结果,表达不同的测试条件


1、根据id命令的执行状态结果,判断用户是否存在

1
2
3
4
5
6
7
8
9
[root@izpo45bh60h6bsz ~] # id root
uid=0(root) gid=0(root)  groups =0(root)
[root@izpo45bh60h6bsz ~] # echo $?
0
 
[root@izpo45bh60h6bsz ~] # id help
id : help: no such user
[root@izpo45bh60h6bsz ~] # echo $?
1


2、根据在/etc/passwd文件中找到root开头的词的执行状态结果,判断用户是否存在

1
2
3
4
5
6
[root@izpo45bh60h6bsz ~] # grep -q '^root\b' /etc/passwd
[root@izpo45bh60h6bsz ~] # echo $?
0
[root@izpo45bh60h6bsz ~] # grep -q '^help\b' /etc/passwd
[root@izpo45bh60h6bsz ~] # echo $?
1


使用测试,在测试时,要使用特殊的测试符

    1)test 测试表达式

1
2
3
4
5
6
[root@izpo45bh60h6bsz ~] # test 1 > 3
[root@izpo45bh60h6bsz ~] # echo $?
0
[root@izpo45bh60h6bsz ~] # test 1 -gt 3 # 在数值测试时,用-gt表示 > 符号
[root@izpo45bh60h6bsz ~] # echo $?
1

    2)[ 测试表达式 ]

1
2
3
4
5
6
[root@izpo45bh60h6bsz ~] # [1 -lt 3]   # 测试表达示与中括号必须存在空格,否则就会报错。
- bash : [1:  command  not found
 
[root@izpo45bh60h6bsz ~] # [ 1 -lt 3 ]  # 在数值测试时,用-lt表示 < 符号
[root@izpo45bh60h6bsz ~] # echo $?
0

  3) [[  测试表达式 ]]

1
2
3
4
5
6
[root@izpo45bh60h6bsz ~] # [[1 -lt 3]]
- bash : [[1:  command  not found
 
[root@izpo45bh60h6bsz ~] # [[ 1 -eq 3 ]]  # 在数值测试时,用-eq 表示 = 符号
[root@izpo45bh60h6bsz ~] # echo $?
1


测试符分类

    数值测试

        -eq 左侧是否等于右侧

        -ne 是不等于

        -gt 是否大于

        -ge 是否大于等于

        -lt 是否小于

        -le 是否小于等于

    

1)A  -eq  B,  测试A所表示的数值是否等于B所表示的数值。等于为真

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
##测试方法一
# A=1
# B=10
# test $B -eq $A  # 测试变量B内存空间中存储的数据和变量A内存空间中存储的数据是否相等
# echo $?
1
 
##测试方法二
# [ $B -eq $A ]
# echo $?
1
 
##测试方法三
# [[ $B -eq $A ]]
# echo $?
1

2)A  -ne  B,  测试A所表示的数值是否不等于B所表示的数值。不等于为真

1
2
3
4
5
6
7
8
9
10
11
12
13
14
##测试方法一
# test $B -ne $A  # 测试变量B内存空间中存储的数据和变量A内存空间中存储的数据是否不相等
# echo $?
0
 
##测试方法二
# [ $B -ne $A ]
# echo $?
0
 
##测试方法三
# [[ $B -ne $A ]]
# echo $?
0

3) A  -gt  B , 测试A所表示的数值是否大于B所表示的数值。大于为真

1
2
3
4
5
6
7
8
9
10
11
12
13
14
##测试方法一
# test 10 -gt 3 # 测试10是否大于3
# echo $?
0
 
##测试方法二
# [ 10 -gt 3 ]
# echo $?
0
 
##测试方法三
# [[ 10 -gt 3 ]]
# echo $?
0

3) A  -ge  B , 测试A所表示的数值是否大于等于B所表示的数值。大于等于为真

1
2
3
4
5
6
7
8
9
10
11
12
13
14
##测试方法一
# test 10 -ge 3 # 测试10是否大于等于3
# echo $?
0
 
##测试方法二
# [ 10 -ge 3 ]
# echo $?
0
 
##测试方法三
# [[ 10 -ge 3 ]]
# echo $?
0

4)A -lt B , 测试A所表示的数值是否小于B所表示的数值。小于为真

1
2
3
4
5
6
7
8
9
10
11
12
13
14
##测试方法一
# let 1 -lt 3    # 测试 1 是否小于 3
# echo $?
0
 
##测试方法二
# [ 1 -lt 3 ]
# echo $?
0
 
##测试方法三
# [[ 1 -lt 3 ]]
# echo $?
0

5)A -le B , 测试A所表示的数值是否小于等于B所表示的数值。小于等于为真

1
2
3
4
5
6
7
8
9
10
11
12
13
14
##测试方法一
# let 1 -le 3    # 测试 1 是否小于 3
# echo $?
0
 
##测试方法二
# [ 1 -le 3 ]
# echo $?
0
 
##测试方法三
# [[ 1 -le 3 ]]
# echo $?
0

    

    字符测试 (所有的操作数,都应该使用引用)

== 等值测试

>  是否大于, ASCII码的比较

<  是否小于

!= 是否不等于

A =~ PATTERN 左侧字符串是否能够被右侧的(正则表达式)PATTERN所匹配到。一般用于 ` ` 中,PATTERN不能加引号

-z "STRING" 测试字串是否为空,空为真

-n "STRING" 是否不空

1) A == B ,A所表示的字符和B所表示的字符是否相等

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
##测试方法一
# test "obama" == "obama"  # 测试左侧字符串,是否与右侧字符串相等
# echo $?
0
 
# test "obama" == "Obama"   # 可见字符串,必须完成相等
# echo $?
1
 
# A=obama
# B=jerry
# test "$A" == "$B"     # 测试A变量内存空间存储的数据(字符型或数值型)是否与B变量中存储的数据相等
# echo $?
1
 
##测试方法二
# [ "obama" == "obama" ]
# echo $?
0
 
# A=obama
# B=jerry
# [ "$A" == "$B" ]
# echo $?
1
 
##测试方法三
# [[ "obama" == "obama" ]]
# echo $?
0
 
# [[ "$A" == "$B" ]]
# echo $?
1

2) A > B ,A所表示的字符是否大于B所表示的字符

3) A < B ,A所表示的字符是否小于B所表示的字符

4) A != B ,A所表示的字符和B所表示的字符是否不相等

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
##测试方法一
# test  "obama"  !=  "obama"   # 测试左侧字符串,是否与右侧字符串不相等
# echo $?
1
 
# test  "$B"  !=  "$A" 
# echo $?
0
 
##测试方法二
# [  "obama"  !=  "obama" 
# echo $?
1
 
# [  "$B"  !=  "$A" 
# echo $?
0
 
##测试方法三
# [[  "obama"  !=  "obama"  ]]
# echo $?
1
 
# A=obama
# B=jerry
# [[  "$A"  !=  "$B"  ]]
# echo $?
0

5) A =~ B ,A所表示的字符能否被B所表示的(正则表达式)模式所匹配。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# test "obama" =~ "^o.*"
- bash test : =~: binary operator expected
# test "obama" =~ ^o.*
- bash test : =~: binary operator expected
 
# [ "obama" =~ "^o.*" ]
- bash : [: =~: binary operator expected
# [ "obama" =~ ^o.* ]
- bash : [: =~: binary operator expected
 
# [[ "obama" =~ "^o.*" ]]
# echo $?
1
 
# [[ "obama" =~ ^o.* ]] #模式不能加引号
# echo $?
0

6)-z  "B",  测试B所表示的字符串是否为空,空为真

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
##测试方法一
# test -z "obama"
# echo $?
1
 
A=
# test -z "$A"  # A变量为空时,测试其结果
# echo $?
0
 
A=jerry
# test -z "$A"  # A变量不空时,测试其结果
# echo $?
1
 
##测试方法二
# [ -z "how are you?" ]
# echo $?
1
 
A=
# [ -z "$A" ]
# echo $?
0
 
##测试方法三
# [[ -z "how are you?" ]] # 测试字串是否为空
# echo $?
1
 
A=
# [[ -z "$A" ]]  # 测试变量中存储的字串,是否为空
# echo $?
0

7) -n "B",  测试B所表示的字符串是否为不空,不空为真

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
##测试方法一
# test -n "obama"
# echo $?
0
 
A=
# test -n "$A"  # A变量为空时,测试其结果
# echo $?
1
 
A=jerry
# test -n "$A"  # A变量不空时,测试其结果
# echo $?
0
 
##测试方法二
# [ -n "how are you?" ]
# echo $?
0
 
A=
# [ -n "$A" ]
# echo $?
1
 
##测试方法三
# [[ -n "how are you?" ]] # 测试字串是否为空
# echo $?
1
 
A=
# [[ -n "$A" ]]  # 测试变量中存储的字串,是否为空
# echo $?
1

    文件测试

-a 或 -e 测试文件是否存在,存在时状态返回值为0,否则为1-255

1
2
3
4
5
6
7
# [ -a /tmp/file.txt ] # 测试文件是否存在,存在执行状态结果为0,否则为1-255
# echo $?
0
 
# [ -e /tmp/file.txt ] # 测试文件是否存在,存在执行状态结果为0,否则为1-255
# echo $?
0

存在且文件为什么类别 (dbc lsp)

-b 是否存在且为 块设备文件,存在则为真

1
2
3
4
5
6
7
8
9
10
11
# [ -b /dev/sda ]  #不存在或不为块设备,结果为1.-255
# echo $?
1
# [ -b /dev/vda ]  #存在且为块设备,结果为0
# echo $?
0
 
# ls -l /dev/sda   #验证结果,不存在
ls : cannot access  /dev/sda : No such  file  or directory
# ls -l /dev/vda   #验证结果,存在
brw-rw---- 1 root disk 253, 0 Jul 31  2017  /dev/vda    ##由b可知为块设备

-c 是否存在 且为字符设备文件

1
2
3
4
5
6
7
8
9
10
crw-rw-rw- 1 root root      1,   5 Jul 31  2017 zero
crw-rw-rw- 1 root root      1,   3 Jul 31  2017 null
 
# [ -c /dev/null ] #存在且为字符设备
# echo $?
0
 
# [ -c /dev/zero ]
# echo $?
0

-d 是否存在 且为目录 文件

1
2
3
4
5
# ls -ld /etc
drwxr-xr-x. 111 root root 12288 Jun 11 16:38  /etc
# [ -d /etc ]
# echo $?
0

-f 是否存在 且为普通 文件

1
2
3
4
5
# ls -l /var/log/yum.log
-rw------- 1 root root 0 Jun 10 12:26  /var/log/yum .log
# [ -f /var/log/yum.log ]
# echo $?
0

-p 管道

1
2
3
# [ -p /var/log/yum.log ]
# echo $?
1

-h 或 -L 符号链接

1
2
3
4
5
6
7
8
# ls -l /etc/system-release
lrwxrwxrwx 1 root root 14 Jul 31  2017  /etc/system-release  -> centos-release
# [ -h /etc/system-release ]
# echo $?
0
# [ -L /etc/system-release ]
# echo $?
0

-S 套接字

1
2
3
4
5
6
# ls -l /dev/log
srw-rw-rw- 1 root root 0 Jul 31  2017  /dev/log
 
# [ -S /dev/log ]
# echo $?
0

存在且有特殊权限:(文件本身)

-g ,拥有sgid权限 

1
2
3
4
5
# ls -l /etc/passwd
-rw-r--r-- 1 root root 3673 Jun 10 13:22  /etc/passwd
# [ -g /etc/passwd ]
# echo $?
1

-u ,拥有suid权限

1
2
3
# [ -u /etc/passwd ]
# echo $?
1

-k , 拥有sticky权限

1
2
3
4
5
6
# [ -k /tmp ]
 
# echo $?
0
# ls -ld /tmp
drwxrwxrwt. 13 root root 4096 Jun 12 00:11  /tmp

文件权限: (跟用户相关) 

-r 文件存在且可读 cat

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
# ls -l /etc/shadow a.txt
-rw-r--r-- 1 root root  127 Jun 11 19:25 a.txt
---------- 1 root root 2843 Jun 10 13:24  /etc/shadow
 
# [ -r a.txt ]
# echo $?
0
# [ -r /etc/shadow ]  ##root用户能读
# echo $?
0
 
# su - myuser
Last login: Tue Aug  1 18:49:22 CST 2017 on pts /0
$ [ -r  /etc/shadow  ]   ##对于普通用户不能读
echo  $?
1

-w 文件存在且可写 修改

1
2
3
4
5
6
7
8
9
# ls -l /etc/shadow a.txt
-rw-r--r-- 1 root root  127 Jun 11 19:25 a.txt
---------- 1 root root 2843 Jun 10 13:24  /etc/shadow
# [ -w /etc/shadow ]
# echo $?
0
# [ -w a.txt ]
# echo $?
0

-x 文件存在且可执行 对于当前用户

1
2
3
4
5
# ls -l /bin/ls
-rwxr-xr-x 1 root root 117656 Nov  6  2016  /bin/ls
# [ -x /bin/ls ]
# echo $?
0

-s FILE 文件存在且非空

1
2
3
4
5
# touch b.txt 
# cat b.txt 
# [ -s b.txt ]
# echo $?
1

-t fd 文件描述符 fd是否打开,且与某个终端相关

运行命令

1、终端无关: 与随系统启动

2、终端相关: 手动运行,在交互式接口运行的命令。linux任何一个文件被打开都有一个文件描述符追踪文件


-N FILE 文件从上次打开后 是否被修改过? (重定向)

1
2
3
4
5
6
7
8
# [ -N a.txt ]
# echo $?
1
 
# echo "abc" >> a.txt
# [ -N a.txt ]
# echo $?
0

-O FILE 当前有效用户是否为文件的属主

1
2
3
4
5
# ls -l a.txt
-rw-r--r-- 1 root root 131 Jun 12 00:37 a.txt
# [ -O a.txt ]
# echo $?
0

-G FILE 当前有效用户是否为文件的属组

1
2
3
# [ -G a.txt ]
# echo $?
0


FILE1 -ef FILE2  refer to 指向    指向同一个设备上的相同inode

    FILE1和FILE2是否为互为硬链接

1
2
3
4
5
6
7
8
9
10
11
# [ a.txt -ef b.txt ]
# echo $?
1
 
# ln a.txt a.hl   ##创建硬链接
# ls -li a.txt a.hl
1558766 -rw-r--r-- 2 root root 131 Jun 12 00:37 a.hl    #inode 1558766
1558766 -rw-r--r-- 2 root root 131 Jun 12 00:37 a.txt   #inode 1558766
# [ a.txt -ef a.hl ]
# echo $?
0


FILE1 -nt FILE2   new than  最近一次修改的时间戳FILE1较FILE2更靠近现在

1
2
3
4
5
6
# ls -l /tmp/ntp.conf*
-rw-r--r-- 1 root root 2439 Jun 11 20:46  /tmp/ntp .conf
-rw-r--r-- 1 root root 2439 Jun 12 00:47  /tmp/ntp .conf.bak
# [ /tmp/ntp.conf -nt /tmp/ntp.conf.bak ]
# echo $? ###说明/tmp/ntp.conf.bak更新
1

FILE1 -ot FILE2   old than    最近一次修改的时间戳FILE1较FILE2更远离现在

1
2
3
# [ /tmp/ntp.conf -ot /tmp/ntp.conf.bak ]
# echo $?  ###说明/tmp/ntp.conf  更旧
0


组合测试条件

    逻辑运算:

        连接命令

            COMMAND1 && COMMAND2

            COMMAND1 || COMMAND2

            ! COMMAND


        连接条件

            [ EXPRESSION ] && [ EXPRESSION ] 相当于 [ EXPRESSION -a EXPRESSION ]

            [ EXPRESSION ]   ||   [ EXPRESSION ] 相当于 [ EXPRESSION -o EXPRESSION ]

            [ ! EXPRESSION ]

摩根定律

    非(P 且 Q) = (非 P) 或 (非 Q)

    非(P 或 Q) = (非 P) 且 (非 Q)

    

    例如:

    [ ! EXPRESSION ] &&  [ ! EXPRESSION ] 相当于 [   !   \(   EXPRESSION -o EXPRESSION  \)  ]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
install  -m 000  /etc/issue  /tmp
ls  -l  /tmp/issue 
---------- 1 myuser myuser 23 Jun 12 05:32  /tmp/issue
 
$ [ ! -r  /tmp/issue  ] && [ ! -w  /tmp/issue  ]
echo  $?
0
 
$ [ ! \( -r  /tmp/issue  -o -w  /tmp/issue  \) ]
echo  $?
0
 
$ [ ! \(-r  /tmp/issue  -o -w  /tmp/issue \) ]
- bash : [: too many arguments

2、bash中自定义退出状态码

    exit [#]  在bash脚本中,一旦遇到exit命令就会终止脚本,退出状态码为exit后的数值。

1、exit存在时

1
2
3
4
5
6
7
8
9
10
# nano helo.sh
#!/bin/bash
printf  "hello everyone\n" 
exit  1
 
## 判断脚本执行的状态结果
# bash helo.sh 
hello everyone
# echo $?
1

2、exit不存在时

1
2
3
4
5
6
7
8
9
10
11
# nano helo.sh
#!/bin/bash
printf  "hello everyone\n" 
 
## 判断脚本执行的状态结果
# bash helo.sh
#!/bin/bash
ls  /varr
printf  "hello everyone\n" 
# echo $?   ##返回值为最后一个命令的执行状态结果
0










本文转自 lccnx 51CTO博客,原文链接:http://blog.51cto.com/sonlich/1953085,如需转载请自行联系原作者
目录
相关文章
|
4月前
|
监控 安全 Shell
防止员工泄密的措施:在Linux环境下使用Bash脚本实现日志监控
在Linux环境下,为防止员工泄密,本文提出使用Bash脚本进行日志监控。脚本会定期检查系统日志文件,搜索敏感关键词(如&quot;password&quot;、&quot;confidential&quot;、&quot;secret&quot;),并将匹配项记录到临时日志文件。当检测到可疑活动时,脚本通过curl自动将数据POST到公司内部网站进行分析处理,增强信息安全防护。
163 0
|
2月前
|
存储 网络协议 Ubuntu
【Linux开发实战指南】基于UDP协议的即时聊天室:快速构建登陆、聊天与退出功能
UDP 是一种无连接的、不可靠的传输层协议,位于IP协议之上。它提供了最基本的数据传输服务,不保证数据包的顺序、可靠到达或无重复。与TCP(传输控制协议)相比,UDP具有较低的传输延迟,因为省去了建立连接和确认接收等过程,适用于对实时性要求较高、但能容忍一定数据丢失的场景,如在线视频、语音通话、DNS查询等。 链表 链表是一种动态数据结构,用于存储一系列元素(节点),每个节点包含数据字段和指向下一个节点的引用(指针)。链表分为单向链表、双向链表和循环链表等类型。与数组相比,链表在插入和删除操作上更为高效,因为它不需要移动元素,只需修改节点间的指针即可。但访问链表中的元素不如数组直接,通常需要从
169 2
|
4月前
|
存储 Shell Linux
Linux Bash 脚本中的 IFS 是什么?
【4月更文挑战第25天】
93 0
Linux Bash 脚本中的 IFS 是什么?
|
2月前
|
存储 Shell Linux
Linux|创建和使用 Bash 别名
Linux|创建和使用 Bash 别名
38 6
|
25天前
|
Kubernetes Linux API
在Linux中,LVS-DR模型的特性是什么?
在Linux中,LVS-DR模型的特性是什么?
|
25天前
|
负载均衡 算法 Linux
在Linux中,LVS-NAT模型的特性是什么?
在Linux中,LVS-NAT模型的特性是什么?
|
27天前
|
存储 固态存储 Linux
在Linux中,ext4文件系统有何特性?如何检查文件系统的完整性?
在Linux中,ext4文件系统有何特性?如何检查文件系统的完整性?
|
1月前
|
Ubuntu 搜索推荐 Shell
如何在 Linux VPS 上自定义你的 Bash 提示符
如何在 Linux VPS 上自定义你的 Bash 提示符
10 0
|
3月前
|
Linux API
Linux线程总结---线程的创建、退出、取消、回收、分离属性
Linux线程总结---线程的创建、退出、取消、回收、分离属性