马哥教育网络班N22期+第9周课程练习

1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现;

#!/bin/bashnolo_user=0login_user=0while read user;do
   bash_type=$(echo $user | cut -d: -f7)   if [ "${bash_type##*/}" == nologin ];then
      let nolo_user+=1
   else
       let login_user+=1
   fidone</etc/passwdecho ${nolo_user}echo ${login_user}

2、写一个脚本

(1) 获取当前主机的主机名,保存于hostname变量中;

(2) 判断此变量的值是否为localhost,如果是,则将当前主机名修改为www.magedu.com;

(3) 否则,则显示当前主机名;

#!/bin/bash#hostname=$(hostname)if [ "$hostname" == localhost ];then
    hostname www.magedu.com && echo `hostname`else
     echo `hostname`fi

3、写一个脚本,完成如下功能

(1) 传递一个磁盘设备文件路径给脚本,判断此设备是否存在;

(2) 如果存在,则显示此设备上的所有分区信息;

#!/bin/bash#for i in $@ ;do
   if ! blkid | grep "$i";then
      echo "$i no exist" 
   fidone

4、写一个脚本,完成如下功能

脚本能够接受一个参数;

(1) 如果参数1为quit,则显示退出脚本,并执行正常退出;

(2) 如果参数1为yes,则显示继续执行脚本;

(3) 否则,参数1为其它任意值,均执行非正常退出;

#!/bin/bash#case $1 inyes|y)   echo "continue"
   ;;
quit|q)    echo "quit"
    exit 0
    ;;
*)    exit 12
    ;;esac
      I

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#case $1 in
gzip)
   tar -zcf /backups/etc-20160613.tar.gz /etc
   ;;
bzip2)
   tar -jcf /backups/etc-20160613.tar.bz2 /etc
    ;;
xz)
   tar -Jcf /backups/etc-20160613.tar.xz /etc
   ;;
*)
   echo "error"
   exit 1
   ;;
esac

6、写一个脚本,接受一个路径参数:

(1) 如果为普通文件,则说明其可被正常访问;

(2) 如果是目录文件,则说明可对其使用cd命令;

(3) 如果为符号链接文件,则说明是个访问路径;

(4) 其它为无法判断;

#!/bin/bash#for i in $@;do
  if [ -f $i ];then
     echo "NORMAL"
  elif [ -d $i ];then
      echo "use cd command"
  elif [ -L $i ];then
      echo "file path"
  else
       echo "can not judge"
   fidone

7、写一个脚本,取得当前主机的主机名,判断

(1) 如果主机名为空或为localhost,或为""(none)"",则将其命名为mail.magedu.com;

(2) 否则,显示现有的主机名即可;

   #!/bin/bash#if [ `hostname` == localhost ] || [ -z `hostname` ];then
   hostname mail.mageedu.comelse
  echo $(hostname)
fi

8、写一脚本,接受一个用户名为参数;

(1) 如果用户的id号为0,则显示其为管理员;

(2) 如果用户的id号大于0且小于500, 则显示其为系统用户;

(3) 否则,则显示其为普通用户;

#!/bin/bash#for i in $@;do
  if ! id $i &>/dev/null;then
     echo "$i no exsit "
     continue
  elif  [ `id -u $i` -eq 0 ] ;then
     echo "$i is admin"
  elif [ `id -u $i` -gt 0 -a `id -u $i` -lt 500 ];then
     echo "$i is system user"
  else
     echo "$i is normal user"
  fidone

10、写一个脚本,传递一个用户名参数给脚本;

(1) 如果用户的id号大于等于500,且其默认shell为以sh结尾的字符串,则显示“a user can log system.”类的字符串;

(2) 否则,则显示无法登录系统;

#!/bin/bash#for i in $@ ;do
   grep "^\<${i}\>.*sh$" /etc/passwd &>/dev/null
   value=$(echo $?)   if ! id $i;then
      echo "user no exsit"
   elif [ $(id -u $i) -ge 500 ] && [ ${value} -eq 0 ] ;then
      echo "a user can log system"
   else
      echo "cannot log system"
   fidone

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 ls -l /var/log/$i | grep "^d" &>/dev/null;then 
      cp -r /var/log/$i /tmp/test1-testn/ 
   elif ls -l /var/log/$i | grep "^[-]" &>/dev/null;then 
      cp  /var/log/$i /tmp/test1-testn/ 
   elif ls -l /var/log/$i | grep "^[l]" &>/dev/null;then 
      cp  -d /var/log/$i /tmp/test1-testn/ 
   else 
      cp  -a /var/log/$i /tmp/test1-testn/ 
   fi done

原创文章,作者:N22-武汉-enfp,如若转载,请注明出处:http://www.178linux.com/53345

(0)
N22-武汉-enfpN22-武汉-enfp
上一篇 2016-10-20
下一篇 2016-10-21

相关推荐

  • 企业实时同步方案—-Sersync介绍

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://nolinux.blog.51cto.com/4824967/1433109 Sersync 项目利用 Inotify 和 Rsync 技术实现对服务器数据实时同步的解决方案,其中 Inotify 用于监控 Sersync…

    Linux干货 2016-08-15
  • Mariadb数据库备份恢复系列(一):mysqldump逻辑备份工具实战

    实验一:利用mysqldump+二进制日志实现备份恢复数据库 1、查看原始数据 2、mysqldump执行备份 3、模拟在备份后修改数据,模拟利用二进制日志还原的场景 4、还原mysqldump备份的数据 5、导出二进制日志的事件 6、还原二进制日志事件   

    Linux干货 2016-11-24
  • linux 文件管理命令

    目录与路径    1.相对路径与绝对路径 因为我们在Linux系统中,常常要涉及到目录的切换,所以我们必须要了解 "路径" 以及 "相对路径" 与 "绝对路径" 的概念。在之前的学习中,就反复的强调了Linux的目录是 "树状目录" 。假设我们需要在任意一个目…

    Linux干货 2016-11-06
  • Linux程序包管理

      Linux的各个release版本开发商,在发布各种应用程序,以及一些团体发布应用程序时,通常会根据发布的程序所适应的开发语言,使用环境,预设参数等,事先编译完成一个可以在相应平台上安装的程序包供使用者直接使用,该程序包含有安装前(preinstall)操作系统环境检测的脚本,程序包中所有文件的相关信息,程序预定义的配置参数文件,程序…

    Linux干货 2016-11-30
  • 马哥教育网络班20期+第四周博客作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 # cp -R /etc/skel /home/tuser1 # chmod -R go-x /home/tuser1 2、编辑/etc/gro…

    Linux干货 2016-06-29
  • linux用户与组管理

    一、linux用户与组管理的基本介绍 1、任何一个用户想要使用Linux系统都要向管理员申请一个账号,对这些账号的管理即是对用户的管理,所谓组,就是多个账号的集合。用户和组管理可以提高用户的管理效率、工作效率以及系统的安全性,比如将同一个部门的成员放在一个组里并设置权限,这样可有效的对资源共享,同时可以避免其他部门的人恶意破坏。 2、用户和组的管理内容一般有…

    Linux干货 2016-08-02