流控制语句:
for…done语句
格式:for 变量 in 名字表
do
命令列表
done
例子:
#!/bin/sh for DAY in Sunday Monday Tuesday Wednesday Thursday Friday Saturday do echo "The day is : $DAY" done
select 变量 in 关键字
do
command 1
... ...
command n
done
select把关键字中的每一项做成类似表单,以交互的
方式执行do和done之间的命令。
case…esac语句,格式:
case 变量 in
字符串1) 命令列表1
;;
...
字符串n) 命令列表n
;;
esac
while语句,格式:
while 条件
do
命令
done
#! /bin/sh num=1 while [ $num -le 10 ] do SUM=`expr $num \* $num` echo $SUM num=`expr $num + 1` done
until语句,格式:
until 条件
do
命令
done
until类似while循环,不同的是until是条件返回值为假时才继续执行。
break:跳出整个循环
continue:跳过本次循环,进行下次循环
shift指令:参数左移,每执行一次,参数序列顺次左移一个位置,$#的值减1,用于分别处理每个参数,移出去的参数不再可用
#! /bin/sh if [ $# -le 0 ] then echo "Not enough parameters" exit 0 fi sum=0 while [ $# -gt 0 ] do sum=`expr $sum + $1` shift done echo $sum
函数的定义:
函数名 ()
{
命令序列
}
函数的调用:不带()
函数名 参数1 参数2 …
函数中的变量:
变量均为全局变量,没有局部变量
函数中的参数:调用函数时,可以传递参数,在函数中用$1、$2…来引用
sh -x script这将执行该脚本并显示所有变量的值。
sh -n script不执行脚本只是检查语法的模式,将返回所有语法错误。
awk命令应用:
awk -F 域分隔符 ‘命令’
示例:
1、检测系统中UID为0的用户:awk -F: '$3==0 {print $1}' /etc/passwd F后边的符号表示分割符,默认为空格
2、检测系统中密码为空的用户:awk -F: 'length($2)==0 {print $1}' /etc/shadow
输入文件名,然后进行压缩备份:
1 #!/bin/sh 2 #back files by date 3 4 DATE=`/bin/date +%Y%m%d` 5 /bin/tar -cf /backup/$1.$DATE.tar $1 > /dev/null 2>> /backup/$1.bak.log 6 /bin/gzip /backup/$1.$DATE.tar 7 8 if [ $? -eq 0 ] 9 then 10 echo "$1 $DATE backup successfully " 11 else 12 echo "ERROR failture $1 $DATE backup" 13 fi
查看apache 服务是否启动如果没有启动则启动,否则输出已启动
#!/bin/sh 2 3 echo "now .the web services of this Linux System will be fetect.." 4 echo 5 6 web=`/usr/bin/pgrep httpd` 7 if [ "$web" != "" ] 8 then 9 echo " the web services is running" 10 else 11 echo "the web services is not runing" 12 /etc/rc.d/init.d/httpd start 13 fi
查看任意输入用户的信息:
#!/bin/sh 2 3 echo "input your name" 4 read username 5 /bin/grep $username /etc/passwd > /dev/null 2> /dev/null #查看用户是否存在 6 7 if [ $? -eq 0 ] 8 then 9 echo "username is : $username" 10 else 11 echo "user does not exit" #不存在就退出结束程序 12 exit 1 13 fi 14 echo 15 16 userinfo=`/bin/grep ^$username:x /etc/passwd ` #得到用户的信息 17 userid=`/bin/echo $userinfo | /bin/awk -F: '{print $3}'` #取出uid 18 groupid=`/bin/echo $userinfo | /bin/awk -F: '{print $4}'` #取出gid 19 homedir=`/bin/echo $userinfo | /bin/awk -F: '{print $6}'` #取出宿主目录 20 shell=`/bin/echo $userinfo | /bin/awk -F: '{print $7}'` #取出执行脚本 21 22 echo "用户基本信息为:" 23 echo "userinfo $userinfo" 24 echo "userid $userid" 25 echo "groupid $groupid" 26 echo "homedir $homedir" 27 echo "shell $shell" 28 29 grouptmpname=`cat /etc/group | /bin/grep :x$groupid` #取得所在组的名字 30 groupname=`echo $grouptmpname | /bin/awk -F : '{print $1}'` 31 32 echo "用户所在组为 : $groupname" 33 echo 34 35 #get group info 36 groups=`/usr/bin/groups $username` 37 echo $groups 38 echo 39 40 #get login info 41 userlogin=`/usr/bin/who | /bin/grep $username` #判断用户是否登录 42 if [ "$userlogin" != "" ] then 45 echo "$username 没有登录" 46 else 47 echo "$username 以及登录" 48 fi 49
输入用户名,从登录列表中剔除
#!/bin/sh 2 3 #找出于该用户有关的服务 4 username=$1 5 /bin/ps aux | /bin/grep jack | awk '{print $2}' > /tmp/killuser.log 6 7 #关闭与该用户有关的服务 8 killids=`cat /tmp/killuser.log` 9 for pid in $killids 10 do 11 /bin/kill -9 $pid 12 done
批量添加用户:
1 #!/bin/sh 2 3 echo "input user name" 4 read name 5 echo "input adduse numbers" 6 read num 7 8 #循环控制添加用户 9 i=0 10 while [ $i -le $num ] 11 do 12 /usr/sbin/useradd $name$i 13 i=`expr $i + 1` 14 done 15 16 17 echo "input password " 18 read password 19 j=0; 20 while [ $j -le $num ] 21 do 22 echo $password | /usr/bin/passwd --stdin $name$j 23 j=`expr $j + 1` 24 done
批量删除用户:
1 #!/bin/sh 2 3 echo "input del username" 4 read name 5 echo "input del number" 6 read num 7 8 i=0 9 while [ $i -le $num ] 10 do 11 /usr/sbin/userdel -r $name$i 12 i=`expr $i + 1` 13 done