1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现;
#!/bin/bash
#
#
#
NUM1=0
NUM2=0
for i in `cut -d: -f7 /etc/passwd` ;do
if [[ "$i" = '/bin/bash' ]];then
let NUM1+=1
else
let NUM2+=1
fi
done
echo " default shell is '/bin/bash' number is $NUM1"" default shell is not '/bin/bash' number is $NUM2"
2、写一个脚本
(1) 获取当前主机的主机名,保存于hostname变量中;
(2) 判断此变量的值是否为localhost,如果是,则将当前主机名修改为www.magedu.com;
(3) 否则,则显示当前主机名;
#!/bin/bash # # # hostname=$HOSTNAME [[ ! "$hostname" == 'localhost' ]] && echo $hostname || hostname www.magedu.com
3、写一个脚本,完成如下功能
(1) 传递一个磁盘设备文件路径给脚本,判断此设备是否存在;
(2) 如果存在,则显示此设备上的所有分区信息;
#!/bin/bash # # # [[ $# -ne 1 ]] && echo "use $0 arg" && exit [ -b $1 ]&& fdisk -l $1 || echo "$1 is not exist" ~
4、写一个脚本,完成如下功能
脚本能够接受一个参数;
(1) 如果参数1为quit,则显示退出脚本,并执行正常退出;
(2) 如果参数1为yes,则显示继续执行脚本;
(3) 否则,参数1为其它任意值,均执行非正常退出;
[[ $# -ne 1 ]] && echo "use $0 arg" && exit
case $1 in
quit)
exit 0
;;
yes)
echo "use $0 again"
break
;;
*)
exit 2
;;
esac
5、写一个脚本,完成如下功能
传递一个参数给脚本,此参数为gzip、bzip2或者xz三者之一;
(1) 如果参数1的值为gzip,则使用tar和gzip归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.gz;
(2) 如果参数1的值为bzip2,则使用tar和bzip2归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.bz2;
(3) 如果参数1的值为xz,则使用tar和xz归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.xz;
(4) 其它任意值,则显示错误压缩工具,并执行非正常退出;
#!/bin/bash
#
#
#
[[ $# -ne 1 ]] && echo "use $0 gzip or bzip2 or xz" && exit
case $1 in
gzip)
tar -Pczf /backups/etc-20160613.tar.gz /etc & >/dev/null
;;
bzip2)
tar -Pcjf /backups/etc-20160613.tar.bz2 /etc & >/dev/null
;;
xz)
tar -PcJf /backups/etc-20160613.tar.xz /etc & >/dev/null
;;
*)
echo "error"
exit 2
;;
esac
6、写一个脚本,接受一个路径参数:
(1) 如果为普通文件,则说明其可被正常访问;
(2) 如果是目录文件,则说明可对其使用cd命令;
(3) 如果为符号链接文件,则说明是个访问路径;
(4) 其它为无法判断;
#!/bin/bash
#
#
#
[[ $# -ne 1 ]] && echo "use $0 arg" && exit
if [ -d $1 ];then
echo "$1 is a directory "
elif [ -f $1 ];then
echo "$1 is a ordinary file"
elif [ -l $1 ];then
echo "$1 is a link file"
else
echo "unknown"
fi
7、写一个脚本,取得当前主机的主机名,判断
(1) 如果主机名为空或为localhost,或为”(none)”,则将其命名为mail.magedu.com;
(2) 否则,显示现有的主机名即可;
#!/bin/bash
#
#
#
hostname1=${HOSTNAME:-"mail.magedu.com"}
[[ $hostname1 = "mail.magedu.com" ]]&& echo $hostname1 && exit
if [[ $hostname1 = "localhost" ]] ;then
hostname "mail.magedulcom"
elif [[ $hostname1 = "(none)" ]];then
hostname "mail.magedu.com"
else
echo $hostname1
fi
8、写一脚本,接受一个用户名为参数;
(1) 如果用户的id号为0,则显示其为管理员;
(2) 如果用户的id号大于0且小于500, 则显示其为系统用户;
(3) 否则,则显示其为普通用户;
#!/bin/bash
#
#
#
[[ $# -ne 1 ]]&& echo "use $0 username" && exit
if ! id $1 &> /dev/null ;then
echo "$1 is not a username"
fi
NUM=`id -u $1`
if [[ $NUM -eq 0 ]];then
echo "$1 is a administrator"
elif [[ $NUM -gt 0 ]]&& [[ $NUM -le 500 ]]; then
echo "$1 is a system user"
else
echo "$1 is a ordinary user"
fi
10、写一个脚本,传递一个用户名参数给脚本;
(1) 如果用户的id号大于等于500,且其默认shell为以sh结尾的字符串,则显示“a user can log system.”类的字符串;
(2) 否则,则显示无法登录系统;
#!/bin/bash
#
#
#
[[ $# -ne 1 ]] && echo "use $1 username " && exit 2
if ! id $1 &> /dev/null ;then
echo "$1 is not a username"
fi
NUM=`id -u $1`
if [[ $NUM -ge 500 ]]&& grep "$1.*sh$" /etc/passwd ;then
echo "$1 can log system"
else
echo "$1 can not log system"
fi
11、写一个脚本,完成如下任务 :
(1) 按顺序分别复制/var/log目录下的每个直接文件或子目录至/tmp/test1-testn目录中;
(2) 复制目录时,才使用cp -r命令;
(3) 复制文件时使用cp命令;
(4) 复制链接文件时使用cp -d命令;
(5) 余下的所有类型,使用cp -a命令;
#!/bin/bash###for i in `ls /var/log/`;do if [[ -d /var/log/$i ]];then cp -r /var/log/$i /tmp/test1-testn elif [[ -f /var/log/$i ]];then cp /var/log/$i /tmp/test1-testn elif [[ -L /var/log/$i ]] ;then cp -d /var/log/$i /tmp/test1-testn else cp -a /var/log/$i /tmp/test1-testn fidone
原创文章,作者:胡安慧,如若转载,请注明出处:http://www.178linux.com/70808


评论列表(1条)
可以看出脚本运用的已经比较熟练了, 再接再励。