馬哥教育網絡班21期+第9周課程練習

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

#!/bin/bash 
declare -i loginable=0
declare -i unloginable=0
    for i in $(cut -d: -f7 /etc/passwd);do
        if [ $i == /sbin/nologin ];then
            let unloginable++
        else
            let loginable++
        fi
    done
echo "loginable:$loginable"
echo "unloginable:$unloginable"

2、寫一個腳本

(1) 獲取當前主機的主機名,保存于hostname變量中;
(2) 判斷此變量的值是否為localhost,如果是,則將當前主機名修改為www.magedu.com;
(3) 否則,則顯示當前主機名;
#!/bin/bash 
hostname=$(hostname)
if [[ "$hostname" == *localhost ]];then
    hostname www.magedu.com   
    echo "hostname is: 'www.magedu.com'"
else
    echo "hostname is: $hostname"
fi

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

(1) 傳遞一個磁盤設備文件路徑給腳本,判斷此設備是否存在;
(2) 如果存在,則顯示此設備上的所有分區信息;
#!/bin/bash 
if [ $# -le 0 ];then
    echo "usage:bash 9.3.sh /dev/DEVICE_NAME"
    exit 1
else
    dev=$1
    if [ -e $dev ];then
        fdisk -l $dev
    else
        echo "This device don't exist"
    fi
fi

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

腳本能夠接受一個參數;
(1) 如果參數1為quit,則顯示退出腳本,并執行正常退出;
(2) 如果參數1為yes,則顯示繼續執行腳本;
(3) 否則,參數1為其它任意值,均執行非正常退出;

#!/bin/bash 
if [ $# -le 0 ];then
    echo "usage:bash 9.4.sh quit|yes|..."
    exit 1
else
    case $1 in 
    quit) 
    echo "quiting..."
    exit 0;;
    yes) 
    echo "countine...";;
    *) 
    echo "error..."
    exit 1;;
    esac
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) 其它任意值,則顯示錯誤壓縮工具,并執行非正常退出;

#!/bin/bash 
if [ $# -le 0 ];then
    echo "usage:bash 9.5.sh gzip|bzip2|xz|..."
    exit 1
else
    case $1 in 
    gzip) 
    tar czvf /backups/etc-20160613.tar.gz /etc;;
    bzip2) 
    tar cjvf /backups/etc-20160613.tar.bz2 /etc;;
    xz) 
    tar cJvf /backups/etc-20160613.tar.xz /etc;;
    *) 
    echo "error..."
    exit 1;;
    esac
fi

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

(1) 如果為普通文件,則說明其可被正常訪問;
(2) 如果是目錄文件,則說明可對其使用cd命令;
(3) 如果為符號鏈接文件,則說明是個訪問路徑;
(4) 其它為無法判斷;

#!/bin/bash
#
if [ $# -le 0 ];then
    echo "Usage:bash 9.6.sh /filepath/filename."
    exit 1
fi
if [ -f $1 ];then
    echo "This file can be access."
elif [ -d $1 ];then
    echo "command 'cd' can be use."
elif [ -L $1 ];then
    echo "this is accessable file."
else
    echo "filetype unkonw."
fi

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

(1) 如果主機名為空或為localhost,或為"(none)",則將其命名為mail.magedu.com
(2) 否則,顯示現有的主機名即可;

#!/bin/bash
hostname=$(hostname)
if [ -z "$HOSTNAME" -o "$HOSTNAME" = "(none)" -o "$HOSTNAME"==*localhost ];then
    hostname mail.magedu.com
    echo "hostname is: 'mail.magedu.com'"
else
    echo "hostname is: $hostname"
fi

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

(1) 如果用戶的id號為0,則顯示其為管理員;
(2) 如果用戶的id號大于0且小于500, 則顯示其為系統用戶;
(3) 否則,則顯示其為普通用戶;

#!/bin/bash
#
if [ $# -le 0 ];then
    echo "Usage:bash 9.8.sh username"
    exit 1
fi
if id $1 &> /dev/null;then
    userid=`grep ^$1 /etc/passwd | cut -d: -f3`
    if [ $userid -eq 0 ];then
        echo "$1 is Administrator."
    elif
       [ $userid -gt 0 -a $userid -lt 500 ];then
        echo "$1 is System User."
    else
        echo "$1 is Common User."
    fi
fi

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

(1) 如果用戶的id號大于等于500,且其默認shell為以sh結尾的字符串,則顯示“a user can log system.”類的字符串;
(2) 否則,則顯示無法登錄系統;

#!/bin/bash
#
if [ $# -lt 1 ];then
    echo "Usage:bash 9.10.sh username"
    exit 1
fi
if id $1 &> /dev/null;then
    userid=`grep ^$1 /etc/passwd | grep sh$ | cut -d: -f3`
    if [ $userid -gt 0 -a $userid -eq 500 ];then
        echo "a user can log system."
    else
        echo "a user can not log system."
    fi
fi

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

(1) 按順序分別復制/var/log目錄下的每個直接文件或子目錄至/tmp/test1-testn目錄中;
(2) 復制目錄時,才使用cp -r命令;
(3) 復制文件時使用cp命令;
(4) 復制鏈接文件時使用cp -d命令;
(5) 余下的所有類型,使用cp -a命令;

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

原創文章,作者:N21_郁藍,如若轉載,請注明出處:http://www.www58058.com/43884

(0)
N21_郁藍N21_郁藍
上一篇 2016-09-07 09:43
下一篇 2016-09-07 09:43

相關推薦

  • 馬哥教育網絡班22期+第四周課程練習

    1、復制/etc/skel目錄為/home/tuser1,要求/home/tuser1及其內部文件的屬組和其它用戶均沒有任何訪問權限 [root@localhost ~]# cp -rf /etc/skel/ /home/tuser1 &> /dev/null [root@localhost ~]# chmod -R go= /home/tus…

    Linux干貨 2016-09-07
  • 學習宣言

    此刻打盹,你將做夢,此刻學習,你將圓夢! 為了財富自由,前進!

    Linux干貨 2016-12-28
  • 創建CA

    創建CA和申請證書 創建私有CA: 首先在CA服務器端創建CA。 先去看openssl的配置文件: /etc/pki/tls/openssl.cnf 一般我們不會去更改這個配置文件,但是要去看一下。我們是根據這個文件創建的CA. 這個文件里是openssl的配置文件,我們打開后只觀察與CA有關的文件。   在文本中可以看出一個主機中可以有多個CA,…

    2017-07-28
  • 馬哥教育網絡班21期-第5周課程練習

    1、顯示/boot/grub/grub.conf中以至少一個空白字符開頭的行;       grep ‘^[[:space:]]\{1,\}’ /boot/grub/grub.conf 2、顯示/etc/rc.d/rc.sysinit文件中以#開頭,后面跟至少一個空白字符,而后又有至少一個非空白字符的行; &…

    Linux干貨 2016-12-18
  • MariaDB日志

    MariaDB日志 查詢日志:query log; 慢查詢日志:slow query log 查詢時長超出指定界限。 錯誤日志:error log 二進制日志:binary log;此中存儲要發生改變或潛在發生改變的語句。 中繼日志:reley log 事務日志:transaction log 1、查詢日志 記錄查詢語句,日志存儲位置:一般不開啟。 文件:f…

    Linux干貨 2016-11-20
  • ?文件服務器 – vsftpd

    文件服務器 – vsftpd 概述 FTP協議 vsftpd的配置文件 vsftpd + pam + file_db + virtual_vsftp_user vsftpd + pam + mysql + virtual_vsftp_user 登錄時錯誤類型 總結 文件服務器是一種專供其他電腦訪問文件和存儲的程序。文件服務器通常比一般的個人電腦擁…

    Linux干貨 2016-10-15

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-09-07 22:53

    腳本寫得非常的漂亮,思路清晰,需要注意一下腳本的縮進,加油!

欧美性久久久久