N22-℡浮生.若夢 ╮第九周作业

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

#!/bin/bash
##
declare -i log_user
declare -i notlog_user
for i in $(cut -d: -f7 /etc/passwd);do
        if [[ "$i" == "/sbin/nologin" ]];then
                let notlog_user++
        else
                let log_user++
        fi
done

echo "登录用户有:$log_user个. 不可登录用户有:$notlog_user个."

2、写一个脚本
    (1) 获取当前主机的主机名,保存于hostname变量中;
    (2) 判断此变量的值是否为localhost,如果是,则将当前主机名修改为www.magedu.com;
    (3) 否则,则显示当前主机名;

#!/bin/bash
##
hostname=$(hostname)
[ "$hostname" == "localhost" ] && hostname www.magedu.com || echo "$hostname"

3、写一个脚本,完成如下功能
    (1) 传递一个磁盘设备文件路径给脚本,判断此设备是否存在;
    (2) 如果存在,则显示此设备上的所有分区信息;

#!/bin/bash
##
if [ -a $1 ];then
        fdisk -l $1
else
        echo "没有这个设备"
fi

4、写一个脚本,完成如下功能
   脚本能够接受一个参数;
   (1) 如果参数1为quit,则显示退出脚本,并执行正常退出;
   (2) 如果参数1为yes,则显示继续执行脚本;
   (3) 否则,参数1为其它任意值,均执行非正常退出;

#!/bin/bash
##
read -p "Enter a option:" option
if [ "$option" == "quit" ];then
        echo "Exit the script." 
        exit 0
elif [ "$option" == "yes" ];then
        echo "Continue to execute the script"
else
        exit 2
fi

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
##
cat << EOF
gzip : gzip格式压缩.
bzip2 : bzip2压缩格式.
xz : xz压缩格式.
EOF

read -p "请选择以上压缩格式:" option

if [ "$option" == "gzip" ];then
        tar -zcf /tmp/etc-20160613.tar.gz /etc &>/dev/null
elif [ "$option" == "bzip2" ];then
        tar -jcf /tmp/etc-20160613.tar.bz2 /etc &>/dev/null
elif [ "$option" == "xz" ];then
        tar -Jcf /tmp/etc-20160613.tar.xz /etc &>/dev/null
else
     echo "错误压缩工具"
     exit 3
fi

6、写一个脚本,接受一个路径参数:
   (1) 如果为普通文件,则说明其可被正常访问;
   (2) 如果是目录文件,则说明可对其使用cd命令;
   (3) 如果为符号链接文件,则说明是个访问路径;
   (4) 其它为无法判断;

#!/bin/bash
##
if [ -f $1 ];then
        echo "这是一个普通文件"
        cat $1
elif [ -d $1 ];then
        echo "这是个一个目录"
        cd $1
elif [ -L $1 ];then
        echo "这是个一符号链接文件"
else
        echo "无法判断"
fi

7、写一个脚本,取得当前主机的主机名,判断
   (1) 如果主机名为空或为localhost,或为"(none)",则将其命名为mail.magedu.com;
   (2) 否则,显示现有的主机名即可;

#!/bin/bash
##
hostname=$(hostname)
[ -z "$hostname" -o "$hostname" == "localhost" ] && hostname mail.magedu.com || hostname

8、写一脚本,接受一个用户名为参数;
   (1) 如果用户的id号为0,则显示其为管理员;
   (2) 如果用户的id号大于0且小于500, 则显示其为系统用户;
   (3) 否则,则显示其为普通用户;

#!/bin/bash
##
if [ $# -lt 1 ];then
        echo "请输入一个用户名"
        exit 2
fi
id=$(id -u $1)

if [ $id -eq 0 ]; then
        echo "此用户为管理员"
elif [ $id -lt 500 ];then
        echo "此用户为系统用户"
elif [ $id -ge 500 ];then
        echo "此用户为普通用户"
else
        echo "无此用户"
fi

10、写一个脚本,传递一个用户名参数给脚本;
   (1) 如果用户的id号大于等于500,且其默认shell为以sh结尾的字符串,则显示“a user can log system.”类的字符串;
   (2) 否则,则显示无法登录系统;

#!/bin/bash
##
if [ $# -lt 1 ];then
        echo "请输入一个用户名"
        exit 2
fi

if ! grep "^$1" /etc/passwd &> /dev/null;then
        echo "没有这个用户"
        exit 3
fi

id=$(id -u $1)
shell=$(grep "^$1.*sh$" /etc/passwd |grep -o sh)
if [ $id -ge 500 ] && [ $shell == sh ];then
        echo "a user can log system"
else
        echo "can not login"
fi

11、写一个脚本,完成如下任务 :
   (1) 按顺序分别复制/var/log目录下的每个直接文件或子目录至/tmp/test1-testn目录中;
   (2) 复制目录时,才使用cp -r命令;
   (3) 复制文件时使用cp命令;
   (4) 复制链接文件时使用cp -d命令;
   (5) 余下的所有类型,使用cp -a命令;

#!/bin/bash
##
file=/var/log/*

for i in $file;do
if [ -d $i ];then
        cp -r $i /tmp/test1-testn
elif [ -f $i ];then
        cp $i /tmp/test1-testn
elif [ -L $i ];then
        cp -d $i /tmp/test1-testn
else
        cp -a $i /tmp/test1-testn
fi
done

原创文章,作者:chenzhijie,如若转载,请注明出处:http://www.178linux.com/62936

(0)
chenzhijiechenzhijie
上一篇 2016-12-12 10:50
下一篇 2016-12-12 10:59

相关推荐

  • Linux基础知识之忘记root密码

    学习之后修改linux用户密码:(物理机端才能修改) ①在读秒时按下任意键一下即可;       ②在下面的界面,选择敲a键,进入命令行模式;       ③在下面的界面的末尾输入 1(表示进入单用户模式);      …

    Linux干货 2016-07-22
  • grub.config文件加密

    作用 在开机启动临时进入1模式的时候,系统先调用/etc/grub.conf。 /etc/grub.conf其实是/boot/grub/grub.conf的软连接。 加密改文件就有效的防止其他用户直接绕过口令登陆1模式,从而进入到root中做一些破坏。 我们可以看一下如何进入1模式。   我们可以看一下临时进入init1模式的窗口 这里的内容与gr…

    2017-07-22
  • Linux网络管理

                          Linux网络管理   本章内容: 网络概念 OSI七层模型 网络设备 TCP/IP IP地址 配置网络 实现网络组 测试网络 网络工具   网络用户应用程序: WEB浏览器(…

    系统运维 2016-09-12
  • LAMP (php-fpm模式)部署出现的奇葩问题

    1. 安装环境:(cent6.5) yum install -y php php-devel httpd  php-fpm mysql 2. 修改配置文件 vim /etc/httpd/conf/http.conf 注释掉DocumentRoot vim /etc/httpd/conf.d/vhost.conf <VirtualHost *:…

    2017-04-10
  • 2016/10/14日作业

    ##操作类: 1、设置自己的终端提示符,要求字符终端登录时: a> 需要带颜色 b> 需要显示当前执行到了第几条命令 c> 显示当前登录终端,主机名和当前时间 a>export  PS1='[\e[034m\u @\h \w \#]\$ \e[0m'  b>export PS1=&#039…

    Linux干货 2016-10-20
  • 马哥教育21期网络班—第六周课程+练习—-成长进行时

    请详细总结vim编辑器的使用并完成以下练习题 1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#; [root@localhost ~]# cp /etc/rc.d/rc.sysinit /tmp/rc.sysinit&nbs…

    Linux干货 2016-08-03

评论列表(1条)

  • 马哥教育
    马哥教育 2016-12-14 10:28

    博客完成的非常好,题目5中的备份文件命令应使用date来实现的,加油!