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

week9:
1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);
分别这两类用户的个数;通过字符串比较来实现;
	#!/bin/bash
	#
	SHELL1="/sbin/nologin"
	declare -i sum1=sum2=0

	for shell in `awk -F":" '{print $7}' /etc/passwd`;do
	    if [ $shell == $SHELL1 ];then
	        let sum1++
	    else
	        let sum2++
	    fi
	done

	echo "Login Users Counts: $sum2"
	echo "Forbidden Login Users Counts: $sum1"

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

	if [ $hostname == "localhost" ];then
	    hostname www.magedu.com
	    echo "hostname changed to $(hostname)"
	else
	    /bin/hostname
	fi

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

	read -p "Please input disk path: " diskpath

	if [ -b $diskpath ];then
	   /sbin/fdisk -l $diskpath
	else
	    echo "$diskpath Error !" 
	fi
   
4、写一个脚本,完成如下功能
   脚本能够接受一个参数;
   (1) 如果参数1为quit,则显示退出脚本,并执行正常退出;
   (2) 如果参数1为yes,则显示继续执行脚本;
   (3) 否则,参数1为其它任意值,均执行非正常退出;
	#!/bin/bash
	#

	if [ $# -eq 1 ];then 
	    case $1 in 
	        "quit")
	            echo "Stop script";;
	        "yes")
	            echo "Continue excuting script";;
	        "*")
	            exit 2;;
	    esac
	else
	    echo "Usage: $0 quit|yes|*"
	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) 其它任意值,则显示错误压缩工具,并执行非正常退出;
	if [ $# -eq 1 ];then
	    case $1 in 
	        "gzip")
	            tar -zcf /backup/etc-`date +%F`.tar.gz /etc/* ;;
	        "bzip2")
	            tar -jcf /backup/etc-`date +%F`.tar.gz /etc/* ;;
	        "xz")
	            tar -Jcf /backup/etc-`date +%F`.tar.gz /etc/* ;;
	        *)
	            echo -e "Error Pack Tool \nUsage: $0 gzip|bzip2|xz "
	            exit 1 ;;
	    esac
	else
	    echo -e "Parameter Error \nUsage: $0 gzip|bzip2|xz"
	fi

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

	if [ $# -eq 1 ];then
	    if [ -f $1 ];then
	        echo "You can access $1"
	    elif [ -d $1 ];then
	        echo "You can use command 'cd' to enter $1 directory "
	    elif [ -L $1 ];then
	        echo "$1 is a symlink file"
	    else
	        echo "Can't judge $1 type"
	    fi
	else
	    echo -e "Parameter Number Error \nUsage: $0 file_abs_path"
	fi

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

	if [ -z $HOSTNAME ] || [ $HOSTNAME == "localhost" ] || [ $HOSTNAME == "" ];then
	    /bin/hostname mail.magedu.com
	    sed -i -r 's/(HOSTNAME)=.*/\1=mail.magedu.com/g' /etc/sysconfig/network
	    echo "hostname has changed" 
	else
	    /bin/hostname
	fi

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

	if [ $# -eq 1 ] && id -u $1 &>/dev/null ;then
	    ID=`id -u $1`
	    if [ $ID -eq 0 ];then
	        echo "$1 is system Root"
	    elif [ $ID -gt 0 ] && [ $ID -lt 500 ];then
	        echo "$1 is system user"
	    else
	        echo "$1 is normal user"
	    fi
	else
	    echo -e "Error \nUsage: $0 USERNAME"
	fi

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

	if [ $# -eq 1 ] && id -u $1 &>/dev/null ;then
	    ID=`id -u $1`
	    SHELL1=$(awk -F":" -v user=$1 '{if(user==$1)print $7}' /etc/passwd)
	    SUB=${SHELL1:0-2:2}

	    if [ $ID -ge 500 ] && [ $SUB == "sh" ];then
	        echo "a user can login system"
	    else
	        echo "$1 can not login system"
	    fi
	else
	    echo -e "Error \nUsage: $0 USERNAME"
	fi

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

	Dir="/tmp/test1-testn"
	[ ! -d $Dir ] && mkdir $Dir

	for file in `ls /var/log`;do
	    if [ -d $file ];then
	        cp -r /var/log/$file $Dir/
	    elif [ -f $file ];then
	        cp /var/log/$file $Dir/
	    elif [ -L $file ];then
	        cp -d /var/log/$file $Dir/
	    else
	        cp -a /var/log/$file $Dir/
	    fi
	done
	echo "Finished copy task!"

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

(0)
devondevon
上一篇 2016-10-17 08:36
下一篇 2016-10-17 08:36

相关推荐

  • mysql 备份脚本的编写

        最近在为做一些边边角角的工作,现在有一个需求要每天把mysql的数据库dump出来到备份机器上面去. 看似简单的任务也潜在了很多的需求,整理如下:     自动运行-crontab      脚本的环境变量设置-由于通过crontab 启动执…

    Linux干货 2015-12-15
  • N25期—第五周作业

    1、 显示当前系统上root、fedora或user1用户的默认shell; grep -E "^(root|fedora|user1):" /etc/passwd | cut -d: -f7 2、找出/etc/rc.d/init.d/functions文件中某单词后面…

    Linux干货 2017-01-02
  • rpm软件包管理

    一:二进制应用程序组成部分 二进制文件(which command)、库文件(ldd `which command`)、配置文件(.conf)、帮助文件(.README)等 二:rpm包文件的组成 rpm文件、rpm元数据(如名称、依赖性关系等)、安装或卸载时运行的脚本 三:rpm包数据库: 1.组成部分(通过 ls /var/lib/rpm 来查…

    2017-08-13
  • TCP/IP五层模型

    1、简述osi七层模型和TCP/IP五层模型 网络的七层模型是由OSI和CITT一起制定的开放系统互连参考模型: TCP/IP 五层模型可以分为:应用层,传输层,网络层,数据链路层,物理层。 2、简述ip route家族命令 语法:ip [ OPTIONS ] OBJECT { COMMAND | help } OBJECT={link ,addr,rout…

    2018-01-05
  • 数据的游戏:冰与火

    我对数据挖掘和机器学习是新手,从去年7月份在Amazon才开始接触,而且还是因为工作需要被动接触的,以前都没有接触过,做的是需求预测机器学习相关的。后来,到了淘宝后,自己凭兴趣主动地做了几个月的和用户地址相关数据挖掘上的工作,有一些浅薄的心得。下面这篇文章主要是我做为一个新人仅从事数据方面技术不到10个月的一些心得,也许对你有用,也许很傻,不管怎么样,欢迎指…

    Linux干货 2016-08-15
  • N21天天第十三周课程练习

    1、建立samba共享,共享目录为/data,要求:(描述完整的过程)   1)共享名为shared,工作组为magedu;   2)添加组develop,添加用户gentoo,centos和ubuntu,其中gentoo和centos以develop为附加组,ubuntu不属于develop组;密码均为用户名;   3)添加s…

    Linux干货 2016-12-05

评论列表(1条)

  • 马哥教育
    马哥教育 2016-10-25 13:16

    脚本很清晰,下次如果你将问题与脚本分排版就更好了