马哥教育网络第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
下一篇 2016-11-14

相关推荐

  • 使用NFS和Samba文件服务搭建博客站点

    使用NFS和Samba文件服务搭建博客站点 实验目的:分别使用NFS和Smaba文件服务实现wordpress 实验要求: (1) server导出/data/application/web,在目录中提供wordpress; (2) client挂载nfs server导出的文件系统至/var/www/html;(3) 客户端1(lamp),部署w…

    2017-04-30
  • 计划任务

    Linux计划任务、周期性的执行任务

    2017-12-24
  • Linux任务计划

        任务计划分类:    一次性任务计划:只执行一次就结束                at batch    周期性任务计划:每隔一定的周期去…

    Linux干货 2017-05-08
  • iptables

    iptables 一、基础概念 1、防火墙概念 Firewall:隔离工具;Packets Filter Firewall;工作于主机或网络的边缘,对经由的报文根据预先定义的规则(匹配条件)进行检测,对于能够被规则匹配到的报文实行某预定义的处理机制的一套组件; 如果没有防火墙,你的本机的所有端口都会被别人访问到! 2、分类 硬件防火墙:在硬件级别实现部分功能…

    2016-10-26
  • linux防火墙介绍

    一、前言firewall(防火墙):工作在网络进入或者流包,进出的网络数据包进行一定的规则进行检查过滤系统。包括iptables和netfilter组件。iptables 是与 Linux 内核集成的 IP 信息包过滤系统。如果 Linux 系统连接到因特网或 LAN、服务器或连接 LAN 和因特网的代理服务器, 则该系统系统中更好地控制 IP 信息包过滤和…

    2017-04-30
  • ftp的用户权限配置

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

    Linux干货 2017-05-02

评论列表(1条)

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

    写的很好,期待你的佳作