从Linux小白到大牛——与狼共舞的日子9

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

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


[root@localhost ~]# cat shell.sh 
#!/bin/bash
#
declare -i loginuser=0
declare -i nologinuser=0
while read line;do
    if [ `echo $line | cut -d: -f7`  ==  '/sbin/nologin' ];then
        let nologinuser++
    else
        let loginuser++
    fi

done < /etc/passwd
echo "nologin:$nologinuser"
echo "login:$loginuser"

2、写一个脚本

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

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

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


[root@localhost ~]# cat hostname.sh 
#!/bin/bash
#
hostname=$(hostname)
[[ $hostname = 'localhost' ]] && hostname www.magedu.com || echo "hostname:$(hostname)"

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

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

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


[root@localhost ~]# cat device.sh 
#!/bin/bash
#
[ $# -ne 1 ] && echo "Usage:$0 /PATH/TO/DEVICE" && exit 1 
[ -b $1 ] && echo "$1 is device." && lsblk $1 || echo "$1 no device."

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

  • 脚本能够接受一个参数;

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

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

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


[root@localhost ~]# cat quit.sh 
#!/bin/bash
#
read -p "Enter a choice:(quit|yes)" ans
case $ans in
quit)
    echo "quit...."
    exit 0;;
yes)
    echo "continue....";;
*)
    echo "error!!!"
    exit 1;;
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) 其它任意值,则显示错误压缩工具,并执行非正常退出;


[root@localhost ~]# mkdir /backups
[root@localhost ~]# cat tar.sh 
#!/bin/bash
#
[ $# -lt 0 ] && echo "Usage:$0 gzip|bzip2|xz" && exit 1
case $1 in
gzip)
    tar czf /backups/etc-20160613.tar.gz /etc &>/dev/null;; 
bzip2)
    tar cjf /backups/etc-20160613.tar.bz2 /etc &>/dev/null;;
xz)
    tar cJf /backups/etc-20160613.tar.xz /etc &>/dev/null;;
*)
    echo "Usage:$0 gzip|bzip2|xz"
    exit 2;;
esac

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

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

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

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

  • (4) 其它为无法判断;


[root@localhost ~]# cat type.sh 
#!/bin/bash
#
[ $# -lt 1 ] && echo "Usage:$0 /PATH/TO/FILE" && exit 1
[ -L $1 ] && echo "$0 is Link" && exit 0
[ -f $1 ] && echo "$0 can access." && exit 0
[ -d $1 ] && echo "$0 can use cd." && exit 0
echo "No file | No directory | No syblink."

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

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

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


[root@localhost ~]# cat hostname1.sh 
#!/bin/bash
#
name=$(hostname)
[[ -z $name || $name = "localhost" || $name = "(none)" ]]
[ $? -eq 0 ] && hostname mail.magedu.com || echo "hostname:$name"

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

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

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

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


[root@localhost ~]# cat user.sh 
#!/bin/bash
#
[ $# -lt 1 ] && echo "Usage:$0 username" && exit 1
! id $1 &>/dev/null && echo "No such user." && exit 0 || userid=`id -u $1`
[ $userid -eq 0 ] && echo $1:adminuser. && exit 0
[[ $userid -gt 0 && $userid -lt 500 ]] && echo $1:systemsuer. && exit 0
[ $userid -ge 500 ] && echo $1:commonuser. && exit 0

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

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

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


[root@localhost ~]# cat userbash.sh 
#!/bin/bash
#
[ $# -lt 1 ] && echo "Usage:$0 username" && exit 1
! id $1 &>/dev/null && echo "No such user." && exit 1 || userid=`id -u $1`
if grep sh$ /etc/passwd | grep ^$1 &>/dev/null;then
    [ $userid -ge 500 ] && echo "a user can log system." || echo "Can not log."
else
    echo "Can not log."
fi

11、写一个脚本,完成如下任务 :

  • (1) 按顺序分别复制/var/log目录下的每个直接文件或子目录至/tmp/test1-testn目录中;

  • (2) 复制目录时,才使用cp -r命令;

  • (3) 复制文件时使用cp命令;

  • (4) 复制链接文件时使用cp -d命令;

  • (5) 余下的所有类型,使用cp -a命令;


[root@localhost ~]# cat cptmp.sh 
#!/bin/bash
#
declare -i num=1
for i in /var/log/*;do
    [ -L $i ] && cp -d $i /tmp/test$num && let num++ && continue
    [ -d $i ] && mkdir /tmp/test$num && cp -r $i /tmp/test$num && let num++ && continue
    [ -f $i ] && cp $i /tmp/test$num && let num++  && continue
    cp -a /tmp/test$num && let num++ && continue
done

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

(0)
N21_孤狼N21_孤狼
上一篇 2016-12-05 17:05
下一篇 2016-12-05 17:05

相关推荐

  • ☞卸载kernel玩一玩

    卸载kernel玩一玩 废话不多说,下面开始卸载内核这一惊险之旅,特别提醒在开始之前做好虚拟机的快照,也许会造成系统无法启动,也许会出现各种错误,也许会笑着删数据库跑路,也许会从入门到放弃,,请系好安全带。  练习 冒泡排序法 #!/bin/bash##Author:jasonmc#Date:2016-08-24#Description:buble…

    Linux干货 2016-08-26
  • ansible基础应用

    Ansible基础 ansible是一款自动化运维工具,基于Python开发,实现了批量系统配置、批量程序部署、批量运行命令等功能。ansible是基于模块工作的,本身没有批量部署的能力。真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架。 Ansible架构简介 ansible的核心就是ansible平台,ansible是高度模…

    Linux干货 2016-08-22
  • 基于heartbeat v2 crm实现基于nfs的mysql高可用集群

    前言 因heartbeat v1内置的资源管理器haresource功能比较简单,且不支持图形化管理,所以heartbeat v2不再支持haresource,转而使用更加强大的资源管理器crm进行集群管理。本文将讲解如何基于heartbeat v2 crm实现基于nfs的mysql高可用集群。 高可用实现 实验拓扑 实验环境 node1:172.16.10…

    Linux干货 2015-06-11
  • Keepalive高可用Nginx服务测试

    环境   系统版本:CentOS 7.2  节点1地址:10.1.8.81  节点2地址:10.1.8.83  虚拟IP地址:10.1.8.248 安装软件     yum -y install nginx     yum -y …

    Linux干货 2017-02-16
  • N22-第三周博客作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 2、取出最后登录到当前系统的用户的相关信息。 3、取出当前系统上被用户当作其默认shell的最多的那个shell。 4、将/etc/passwd中的第三个字段数值最大的后10个用户的信息全部改为大写后保存至/tmp/maxusers.txt文件中。 5、取出当前主机的…

    Linux干货 2016-08-29
  • ftp的用户权限配置

    文件服务: 应用层:ftp; 内核级网络文件系统:nfs POSIX(可移植操作系统接口 Portable Operating System Interface of UNIX,缩写为 POSIX ) API(应用程序编程接口) 跨平台的网络文件系统:cifs (samba)   网络存储: NAS:NetworkAttached Stoage,文…

    Linux干货 2017-05-02

评论列表(1条)

  • Jeanne
    Jeanne 2017-04-24 03:59

    good point simon. i’ve recently been to the future and couldn’t find a planner anywhere.these days you have to go with flow (of change). planners should be more soc/ttaliculeural synthesizers. that would be useful vs. restating the bleeding obvious and pretending it’s an “insight”.the drumming gorilla simply rocks. that’s all you can ask of a chocolate bar commercial.