馬哥教育網絡班20期-第九周課程作業

Table of Contents

1、寫一個腳本,判斷當前系統上所有用戶的shell是否為可登錄shell(即用戶的shell不是/sbin/nologin);分別這兩類用戶的個數;通過字符串比較來實現;

#!/bin/bash
#
for shell in `cut -d':' -f7 /etc/passwd`; do
    if [ $shell == "/sbin/nologin" ]; then
        let "NOLOGIN++"
    else
        let "LOGIN++"
    fi
done

echo "可登錄用戶數: $LOGIN"
echo "不可登錄用戶數: $NOLOGIN"

2、寫一個腳本

  1. 獲取當前主機的主機名,保存于hostname變量中;

  2. 判斷此變量的值是否為localhost,如果是,則將當前主機名修改為www.magedu.com;

  3. 否則,則顯示當前主機名;

#!/bin/bash
#
hostname=`hostname`
if [ $hostname == "localhost" ]; then
    hostname "www.magedu.com"
else
    echo "$hostname"
fi

3、寫一個腳本,完成如下功能

  1. 傳遞一個磁盤設備文件路徑給腳本,判斷此設備是否存在;

  2. 如果存在,則顯示此設備上的所有分區信息;

#!/bin/bash
#
ARG_WRONG=87

if [ $# -ne 1 ]; then
    echo "usage: $0 dev_name"
    exit $ARG_WRONG
fi

if [ -b $1 ]; then
    fdisk -l $1
else
    echo "$1不存在或格式錯誤"
fi

4、寫一個腳本,完成如下功能

腳本能夠接受一個參數;

  1. 如果參數1為quit,則顯示退出腳本,并執行正常退出;

  2. 如果參數1為yes,則顯示繼續執行腳本;

  3. 否則,參數1為其它任意值,均執行非正常退出;

#!/bin/bash
#
ARG_WRONG=87
if [ $# -ne 1 ]; then
    echo "usage: $0 {yes|quit}"
    exit $ARG_WRONG
fi

case $1 in
    'quit')
        echo "退出腳本"
        exit 0
        ;;
    'yes')
        echo "繼續執行腳本"
        ;;
    *)
        exit 1
        ;;
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
#
ARG_WRONG=87
if [ $# -ne 1 ]; then
    echo "usage: $0 {gzip|bzip2|xz}"
    exit $ARG_WRONG
fi

case $1 in
    gzip)
        tar -czf /backups/etc-`date %Y%m%d`.tar.gz /etc
        ;;
    bzip2)
        tar -cjf /backups/etc-`date %Y%m%d`.tar.gz /etc
        ;;
    xz)
        tar -cJf /backups/etc-`date %Y%m%d`.tar.gz /etc
        ;;
    *)
        echo "錯誤壓縮工具"
        exit 1
        ;;
esac

6、寫一個腳本,接受一個路徑參數:

  1. 如果為普通文件,則說明其可被正常訪問;

  2. 如果是目錄文件,則說明可對其使用cd命令;

  3. 如果為符號鏈接文件,則說明是個訪問路徑;

  4. 其它為無法判斷;

#!/bin/bash
#
ARG_WRONG=87
if [ $# -ne 1 ]; then
    echo "usage: $0 FILENAME"
    exit $ARG_WRONG
fi

if [ -f $1 ]; then
    echo '其可被正常訪問'
    exit 0
fi

if [ -d $1 ]; then
    echo '可對其使用cd命令'
    exit 0
fi

if [ -L $1 ]; then
    echo '是個訪問路徑'
    exit 0
fi

echo '無法判斷'
exit 1

7、寫一個腳本,取得當前主機的主機名,判斷

  1. 如果主機名為空或為localhost,或為""(none)"",則將其命名為mail.magedu.com;

  2. 否則,顯示現有的主機名即可;

#!/bin/bash
#
hostname=`hostname`
if [ $hostname == "localhost" -o $hostname == "" ]; then
    hostname "mail.magedu.com"
else
    echo "$hostname"
fi

8、寫一腳本,接受一個用戶名為參數;

  1. 如果用戶的id號為0,則顯示其為管理員;

  2. 如果用戶的id號大于0且小于500, 則顯示其為系統用戶;

  3. 否則,則顯示其為普通用戶;

#!/bin/bash
#
ARG_WRONG=87
if [ $# -ne 1 ]; then
    echo "usage: $0 USERNAME"
    exit $ARG_WRONG
fi

if id $1; then
    if [ `id -u $1` -eq 0 ]; then
        echo "該用戶是管理員"
    elif [ `id -u $1` -lt 500 ]; then
        echo "該用戶是系統用戶"
    else
        echo "該用戶是普通用戶"
    fi
else
    echo "不存在該用戶"
    exit 1
fi

10、寫一個腳本,傳遞一個用戶名參數給腳本;

  1. 如果用戶的id號大于等于500,且其默認shell為以sh結尾的字符串,則顯示“a user can log system.”類的字符串;

  2. 否則,則顯示無法登錄系統;

#!/bin/bash
#
ARG_WRONG=87
if [ $# -ne 1 ]; then
    echo "usage: $0 USERNAME"
    exit $ARG_WRONG
fi

if id $1; then
    if [ `id -u $1` -ge 500 -a grep -q "^\<$1\>.*sh$" /etc/passwd ]; then
        echo "a user can log system."
        exit 0
    fi
fi

echo "無法登錄系統"
exit 1

11、寫一個腳本,完成如下任務 :

  1. 按順序分別復制/var/log目錄下的每個直接文件或子目錄至/tmp/test1-testn目錄中;

  2. 復制目錄時,才使用cp -r命令;

  3. 復制文件時使用cp命令;

  4. 復制鏈接文件時使用cp -d命令;

  5. 余下的所有類型,使用cp -a命令;

#!/bin/bash
#
DESTINATION=/tmp/test1-testn
for file in `ls /var/log`; do
    if [ -d $file ]; then
        cp -r $file $DESTINATION
    elif [ -f $file ]; then
        cp $file $DESTINATION
    elif [ -L $file ]; then
        cp -d $file $DESTINATION
    else
        cp -a $file $DESTINATION
    fi
fi

原創文章,作者:Net20_木皮,如若轉載,請注明出處:http://www.www58058.com/28464

(0)
Net20_木皮Net20_木皮
上一篇 2016-08-05 16:16
下一篇 2016-08-05 16:16

相關推薦

  • 第五周博客作業

    1、顯示當前系統上root、fedora或user1用戶的默認shell; [root@localhost ~]# grep -E "^(root|fedora|user1)\>" /etc/passwd | cut -d: -f1,7 roo…

    Linux干貨 2017-01-07
  • IP地址之IPv4

    一、概述   IP地址有IPv4和IPv6兩個版本,目前我們通常所說的IP地址是指IPv4。   IP地址由32位的二進制數組合而成,為了方便人類記憶,將二進制轉換成4個十進制的數值。   在這32位數據中分為網絡號與主機號兩個部分。 二、IP的分級   IP網段分為五個等級,其定義如下:   A類:規定前面…

    Linux干貨 2016-02-14
  • Linux運維學習歷程-第六天-Linux用戶、組以及權限管理

    本章內容    Linux的安全模型    用戶和組    用戶和組管理命令    文件權限    默認權限    特殊權限    ACL訪問控制 一:3A認證       &nb…

    Linux干貨 2016-08-07
  • 安裝LNMP + 搭建WordPress個人博客

    安裝LNMP + 搭建Wordpress個人博客 前言 來到馬哥教育也有幾個月了,學了很多知識?,F在想要把這些知識能夠存儲在一個地方,隨時隨地的都能看到,于是乎我就想到了博客,以下我搭建Wordpress的過程。 安裝LNMP 一、關掉防火墻 # chkconfig iptables off 二、安裝開發包和庫文件 #&nbsp…

    Linux干貨 2016-05-31
  • Linux 文件系統權限

    一、簡述權限  文件系統的權限管理機制的建立,約束了用戶對數據的操作。 1、對系統安全而言  管理員的操作權限非常大,足以破壞系統,權限機制將管理員與普通用戶之間區分開,防止系統被隨意破壞。 2、對用戶而言  Linux是一個多用戶的操作系統,不同用戶間為了防止其他人破壞數據或訪問數據,文件系統的權限管理是非常必要的。 二、文件…

    Linux干貨 2016-08-04
  • find查找

    find查找是生產中最常見的日志查找工具 下面看看它的用法 基本用法: find    查找路徑    查找標準    查找到以后的處理動作 查找路徑:需要被查找的文件所在的路徑,一定是個目錄,默認情況下為當前的目錄 查找的標準:查找的時候用什么方式去查找 處理動作:文件查找完畢后,需要對查找出來的…

    Linux干貨 2017-05-08

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-08-05 17:05

    寫的很好,排版也很棒,加油

欧美性久久久久