马哥教育网络班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)
上一篇 2016-10-17 08:36
下一篇 2016-10-17 08:36

相关推荐

  • DNS服务与bind配置

    DNS服务   DNS: Domain Name Service,协议   BIND:Bekerley Internat Name Domain, ISC (www.isc.org)   本地名称解析配置文件:hosts           linux:/et…

    Linux干货 2016-09-26
  • 文本处理工具sed

    处理文本的工具sed     stream EDitor,行编辑器     sed是一种流编辑器,他一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,成为“模式空间”(pattern space),接着用sed命令处理缓存区中的内容,处理完成后,把缓冲区的内容送往屏幕。…

    Linux干货 2016-08-10
  • 网络配置——IP划分网络基础

    Linux网络属性配置: 计算机网络: TCP/IP:协议栈         ISO,OSI:协议栈学习 MAC:Media Access Control          48bits: &nbsp…

    Linux干货 2016-09-07
  • 磁盘配额、阵列与逻辑卷

    一、磁盘配额 在内核中执行以文件系统为单位启用对不同组或者用户的策略不同 根据块或者节点进行限制执行软限制(soft limit)硬限制(hard limit) 步骤一:获得文件系统支持临时有效:mount -o remount,usrquota,grpquota {mount_point|device}永久有效:写入配置文件 /etc/fstab 中检查文…

    Linux干货 2016-08-29
  • Linux作业管理、网络客户端工具和bash循环

    Linux系统作业控制;                   job:         前台作业foregroud:通过终端启动,且启动后会一直占据终端;         后台作业…

    Linux干货 2017-01-05
  • history

    history命令详解

    Linux干货 2018-02-28

评论列表(1条)

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

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