马哥教育网络班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

相关推荐

  • HTTPD-相关的配置

    一次完整的HTTP请求处理过程: 1、建立连接:接收或拒绝链接请求 2、接受请求:接收客户端请求报文中对某资源的一次请求的过程 Web访问响应模型(Web I/O) 单进程I/O模型:启动一个进程处理用户请求,而且一次只处理一个,多个请 求被串行响应; 多进程I/O模型:并行启动多个进程,每个进程响应一个链接请求; 复用I/O结构:启动一个进程,同时响应N个…

    2017-08-29
  • inotify介绍及rsync + inotify 实时同步备份

    1、前言 rsync (remote sync)是一款非常好的数据同步工具,能够通过对比同步双方的数据变动,实现增量同步,还可以通过LAN/WAN实现远程多台主机间文件的同步,还能结合crond任务计划来执行自动备份,又可以结合ssh实现远程数据备份的安全,种种特性使他看起来相当优秀。但如果需备份数据十分庞大时,它的不足之处就显现出来了,比如每次执…

    Linux干货 2016-06-15
  • 磁盘管理

    1、创建一个10G分区,并格式为ext4文件系统。 (1)虚拟机添加21G硬盘 Disk /dev/sdb: 21.5 GB, 21474836480 bytes, 41943040 sectors Units = sectors of 1&nbsp…

    Linux干货 2016-12-18
  • 使用haproxy代理LAMP、LNMP 实现WordPress发布

    haproxy简介 HAProxy是专业的反向代理软件,它可以支持4层和7层代理服务。其配置包含一下几个配置段: global:全局设置,通常与操作系统有关 defaults:配置默认参数,可以被frontend、backend、listen组件利用 frontend:接收亲请求的前虚拟节点 backend:后端服务集群的配置,一个backend可以对应多个…

    2017-05-17
  • 磁盘管理(二)Raid与LVM逻辑卷

    概述:本章主要讲解raid和逻辑卷 什么是RAID RAID:Redundant Arrays of Inexpensive(Independent) Disks 1988年由加利福尼亚大学伯克利分校( University ofCalifornia-Berkeley) “ A Case for RedundantArrays of Inexpensive …

    Linux干货 2016-09-05
  • 如何实现在命令行输入pwd时显示出ifconfig的效果

    1、使用type ifconfig 查看   2、使用type pwd 查看 如果还没有使用过pwd则显示如下,表示pwd属于内部命令,然后输入enable -n pwd 禁用这个内部命令   如果已经使用过,就会显示hash,已经缓存过   此时就不仅需要禁用内部命令,还需要使用hash -d pwd 清除pwd的缓存,使其在…

    2017-07-13

评论列表(1条)

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

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