shell脚本编程之选择控制结构

#!/bin/bash#this shell test mysql user exist system.if id mysql ;thenecho “mysql exist.”fi

fi

这种双分支的语句,等条件满足的时候就会运行then后面的语句,条件不满足的时候就运行else后面的语句。

eg1:如果指定的用户存,先说明其已经存在,美国服务器,并显示其ID号和SHELL;否则,就添加用户,并显示其ID号;

#!/bin/bashUsername=mysqlif id $Username &>/dev/null;thenId=`grep “^$Username\&;” /etc/passwd | cut -d: -f3`Shell=`grep “^$Username\&;” /etc/passwd | cut -d: -f7`echo “$Username exist,ID is $Id,shell is $Shell.”elseuseradd $UsernameId=`grep “^$Username\&;” /etc/passwd | cut -d: -f3`echo “$Username ID is $Id.”fi

eg2:判断用户是否存在,存在则显示ID和SHELL,不存在就添加用户,并显示其ID。

分析:这题与上一个列子不一样的地方是这个用户没有指定,既然没有指定,就需要自己手动去shell一个参数,而脚本怎么去引用参数。这里就用到了bash变量中的位置变量

位置变量:$1,$2…..$9($1就是脚本传递的第一个参数…)

$0:脚本自身名称

$@:所有位置参数的列表

$*:所有位置参数

$#:位置参数的个数

#!/bin/bashif id $1 &>/dev/null;thenId=`grep “^$1\&;” /etc/passwd | cut -d: -f3`Shell=`grep “^$1\&;” /etc/passwd | cut -d: -f7`echo “$1 exist,ID is $Id,shell is $Shell.”elseuseradd $1Id=`grep “^$1\&;” /etc/passwd | cut -d: -f3`echo “$1 ID is $Id.”fi

运行脚本 bash eg2.sh mysql (eg.sh是脚本的名称,mysql是传递给脚本的第一个参数)

eg3:通过参数传递一系列用户名给脚本,让脚本添加这些用户;但要先判断用户是否存在,不存在而后再添加;添加完成后,香港空间,显示一共添加了几个用户;当然,不能包括因为事先存在而没有添加的;

分析:这个脚本不明确的是不知道要传递几个参数,所以用位置变量有点不符合要求,所以引用了$@这个特殊的变量,然后这些用户,你得一个一个的去取这些用户,然后进行判断是否存在,用循环控制了如何一个一个的取这些用户,然后用户不能重复的一个一个的取,所以用户得取一个T掉$@列表中的用户,用了shift命令,shift命令就是轮流的T除用户。

#!/bin/bashcount=0for user in $@;do if id $1 &>/dev/null;thenecho “user $1 exsit.”shift elseuseradd $1count=$[$count+1]echo “add $1.”shift fidoneecho “total users:$count”

eg4:判断一个用户,如果存在则判断是否是普通用户,还是系统用户,还是admin用户。不存在则显示该用户不存在。

分析:首先判断用户是否存在,存在则比较用户的ID是否为大于等于500,大于等于500则表示为普通用户,是否1-499,是则表示为系统用户,是否为0,是则为admin用户。

本例子还用到了数值的比较,然后还用到了条件的组合

linux test命令支持数值比较、字符串比较、文件比较 详情请man test

数值比较

num1 -eq num2 检查num1是否等于num2

num1 -ge num2 检查num1是否>或等于num2

num1 -gt num2 检查num1是否大于num2

num1 -le num2 检查num1是否<等于num2

num1 -lt num2 检查num1是否<num2

num1 -ne num2 检查num1是否不等于num2

组合条件测试

-a:与 [ $Uid -ge 1 -a $Uid -le 499 ]

-o:或 [ $Uid -eq 0 -a $Uid -ge 500 ]

!:非,单目操作符 [ ! $Uid -eq 0 ]

#!/bin/bashif id $1 &> /dev/null;thenId=`grep “^$1\&;” /etc/passwd | cut -d: -f3`if [ $Id -ge 500 ];thenecho “$1 is common user.”elif [ $Id -lt 500 -a $Id -ge 1 ];thenecho “$1 is system user.”elseecho “$1 is admin user.”fielseecho “$1 Not exist.”fi

脚本执行结果

eg5:判定用户的shell是否为登录shell;

分析:首先判断用户的shell是否存在,redhat中有一个用户的shell就为空,如果shell存在则判断shell是否为bash,如果是则表示为登录用户,如果不是则表示为不能登录用户。在redhat 5.x的版本上。

字符串比较

str1 = str2 检查str1与str2是否相同

str1 != str2 检查str1与str2是否不同

str1 < str2 检查str1是否小于str2

str1 > str2 检查str1是否大于str2

-n str1 检查str1的长度是否大于0

-z str1 检查str1的长度是否为0

=~:判断左边的字符串是否能够被右边的模式所匹配,通常用于[[]]; [[ "$opt1" =~ pattern ]],

一般锚定行首和行尾

#!/bin/bashShell=`grep “^$1:” /etc/passwd | cut -d: -f7`if [ -z $Shell ];thenecho “$1 user no shell”elseif [ “$Shell” == “/bin/bash” ]; thenecho “$1 user shell is login shell.”elseecho “$1 user shell is nologin shell.”fifi

运行结果

eg6:判断当前主机的CPU生产商,其信息在/proc/cpuinfo文件中vendor id一行中。如果其生产商为GenuineIntel,就显示其为Intel公司;否则,就显示其为AMD公司;

#!/bin/bashVendor=`grep “vendor_id” /proc/cpuinfo | uniq | cut -d: -f2`if [[ “$Vendor” =~ [[:space:]]*GenuineIntel$ ]]; then echo “Intel”else echo “AMD”fi

运行结果

[root@Redhat5 test]# bash eg6.sh

Intel

eg7:

写一个脚本:可以接受一个参数,其使用形式如下:

script.sh {start|stop|restart|status}

如果参数为start,创建空文件/var/lock/subsys/script,并显示“Starting script successfully.”;

如果参数为stop,则删除文件/var/lock/subsys/script,并显示“Stop script finished.”;

如果参数为restart,则删除文件/var/lock/subsys/script后重新创建,并显示“Restarting script successfully.”;

如果参数为status,那么:

如果/var/lock/subsys/script文件存在,则显示为“script is running.”

否则,则显示为“script is stopped.”

其它任何参数:则显示“script.sh {start|stop|restart|status}”

文件比较

-b file 检查文件是否存在且是一个块特殊文件

-c file 检查文件是否存在且是一个字符文件

-d file 检查file是否存在并且是一个目录

-e file 检查文件是否存在

-f file 检查文件是否存在并且是一个文件

-h file 检查文件存在且为一个符合链接

-r file 检查文件是否存在并且可读

-s file 检查文件是否存在且不为空

-w file 检查文件是否存在且可写

-x file 检查文件是否存在且可执行

-O file 检查文件是否存在且别当前用户拥有

-G file 检查是否存在并且默认组是否为当前用户组

就是去做你害怕的事,直到你获得成功的经验。

shell脚本编程之选择控制结构

相关文章:

你感兴趣的文章:

标签云: