马哥教育网络第21期-第九周课程练习

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

#!/bin/bash
nologin=$( cut -d: -f7 /etc/passwd | grep 'nologin$' | wc -l)
login=$( cut -d: -f7 /etc/passwd | grep 'bash$' | wc -l)
echo "nologin:$nologin"
echo "login:$login"

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
if [ $# -eq 0 ];then
	echo "input arg"
	exit 1
else
	if [ -e $1 ];then
	 fdisk -l $1
	else
	echo "null"
	fi
fi

4、写一个脚本,完成如下功能
   脚本能够接受一个参数;
   (1) 如果参数1为quit,则显示退出脚本,并执行正常退出;
   (2) 如果参数1为yes,则显示继续执行脚本;
   (3) 否则,参数1为其它任意值,均执行非正常退出;
   
#!/bin/bash
if [ $# -eq 0 ];then
	echo "input argu"
	exit 1
fi
case $i in
	quit)
		exit
		echo "exit";;
	yes)
		echo "continue";;
	*)
		exit 2
		echo "exit";;
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
if [ $# -eq 0 ];then
	echo "input argu"
	exit 1
fi
case $1 in
	gzip)
	tar -zcvf /backups/etc-'date +%Y%m%d'.tar.gz /etc;;
	bzup2)
	tar -jvf /backups/etc-'date + %Y%m%d'.tar.bz2 /etc;;
	xz)
	tar -Jvf /backups/etc/-'date + %Y%m%d'.tar.xz /etc;;
	*)
	exit 1
esac
   
6、写一个脚本,接受一个路径参数:
   (1) 如果为普通文件,则说明其可被正常访问;
   (2) 如果是目录文件,则说明可对其使用cd命令;
   (3) 如果为符号链接文件,则说明是个访问路径;
   (4) 其它为无法判断;
   
#!/bin/bash
if [ $# -eq 0 ];then
	echo "input argu"
	exit 1
fi
		if [ -f $1 ];then
		echo "file"
		elif [ -d $1 ];then
		echo "directory"
		elif [ -L $1 ];then
		echo "path"
		else
		echo "unknow"
		fi
   
7、写一个脚本,取得当前主机的主机名,判断
   (1) 如果主机名为空或为localhost,或为"(none)",则将其命名为mail.magedu.com;
   (2) 否则,显示现有的主机名即可;
   
#!/bin/bash
hostname=$(hostname)
if [ -z "$hostname" -o "$hostname" == "localhost" -o  "$hostname" == "none" ];then
	hostname mail.magedu.com
else
	echo "$hostname"
fi

8、写一脚本,接受一个用户名为参数;
   (1) 如果用户的id号为0,则显示其为管理员;
   (2) 如果用户的id号大于0且小于500, 则显示其为系统用户;
   (3) 否则,则显示其为普通用户;
   
#!/bin/bash
if [ $# -eq 0 ];then
	echo "input argu"
	exit 1
fi
	userid=$(id -u)
if [ $userid -eq 0 ];then
	echo "admin"
elif [ $userid -gt 0 -a $userid -lt 500 ];then
	echo "system"
else
	echo "user"
fi

10、写一个脚本,传递一个用户名参数给脚本;
   (1) 如果用户的id号大于等于500,且其默认shell为以sh结尾的字符串,则显示“a user can log system.”类的字符串;
   (2) 否则,则显示无法登录系统;
   
#!/bin/bash
if [ $# -eq 0 ];then
	echo "input argu"
	exit 1
fi
	userid=grep ^$1 /etc/passwd | grep sh$ | cut -d: -f3
if [ $userid -ge 500 ];then
	echo " a user can log system"
else
	echo "nologin"
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 $i ];then
		cp -r /var/log/$i /tmp/test/test1-testn/$i
	elif [ -f $i ];then
		cp /var/log/$i /tmp/test/test1-testn/$i
	elif [ -L $i ];then
		cp -d /var/log/$i /tmp/test/test1-testn/$i
	else
		cp -a /var/log/$i /tpm/test/test1-testn/$i
	fi
done

以上

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

(0)
N21_619463772N21_619463772
上一篇 2016-11-14 08:28
下一篇 2016-11-14 08:28

相关推荐

  • HAProxy浅说

    HAProxy浅说:    HAProxy响应码:        200:请求正常,响应正常,也就是正常响应码     301:配置使用的重定向,以下都是有关于重定向的一些响应码,不做解释     302:    &nb…

    2017-05-18
  • Linux的用户组和权限(一)

    导读:本章主要内容如下       1.解释Linux的安全模型      2.解释用户账号和组群账号的目的      3.用户和组管理命令      4.理解并设置文件权限 &n…

    Linux干货 2016-08-04
  • PHP数组实际占用内存大小的分析

    我们在前面的php高效写法提到,尽量不要复制变量,特别是数组。一般来说,PHP数组的内存利用率只有 1/10, 也就是说,一个在C语言里面100M 内存的数组,在PHP里面就要1G。下面我们可以粗略的估算PHP数组占用内存的大小,首先我们测试1000个元素的整数占用的内存: <?php      &nb…

    系统运维 2015-05-28
  • Linux 第八天: 练习和作业

    Linux 第八天: (08月09日) 练习和作业       1删除/etc/grub2.cfg所有以空白开头的行行首空白字符 sed 's#^[[:space:]]\+##' /etc/grub2.cfgsed -r 's@^[[:space:]]+@@' /etc/grub2.cfg…

    Linux干货 2016-08-11
  • N23-第一周博客作业

    一、计算机组成 由五大基本部件【运算器 + 控制器 + 储存器 + 输入设备 + 输出设备】组成且遵循冯诺依曼体系,CPU包含运算器和控制器两大部件。 CPU: 核心部件:运算器、控制器 其他部件:寄存器、缓存、等等 存储器:内存,RAM(Random Access Memory)随机访问存储器。 Input(输入设备):下指令,提供数据等,如:硬盘、键盘、…

    Linux干货 2016-09-15
  • sed vim小练

     1 、删除/etc/grub2.conf 文件中所有以空白开头的行行首的空白字符  2 、删除/etc/fstab文件中所有以#开头,后面至少跟一个空 白字符的行的行首的#和空白字符 3 、在/root/install.log 每一行行首增加# [root@localhost ~]# sed -n&nbsp…

    Linux干货 2016-08-12

评论列表(1条)

  • 马哥教育
    马哥教育 2016-11-16 15:55

    写的很好,期待你的佳作