馬哥教育網絡班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
下一篇 2016-09-07

相關推薦

  • 倒排索引-搜索引擎的基石

    1.概述       在關系數據庫系統里,索引是檢索數據最有效率的方式,。但對于搜索引起,他它并不能滿足其特殊要求:       1)海量數據:搜索引擎面對的是海量數據,像Google,百度這樣大型的商業搜索引擎索引都是億級甚至幾千的網頁數量 ,面對…

    Linux干貨 2015-12-10
  • yum詳解及源碼包的編譯安裝

    yum的功能:     在我們使用rpm包安裝程序時,各個程序包之間可能存在非常嚴重的依賴關系,這就導致我們在安裝一個包的同時還需要安裝其他存在依賴關系的包,因此我們可以使用rpm包的前端管理工具yum,可通過yum所支持的文件共享機制來解決各個rpm包之間的依賴關系。 yum倉庫的配置文件:   …

    Linux干貨 2016-08-25
  • PPTPD搭建

    1、檢查服務器是否支持PPTP服務[root@centos1 ~]# modprobe ppp-compress-18 && echo okok以上命令執行出來顯示是“OK”的話,繼續往下進行![root@centos1 ~]# cat /dev/net/tuncat: /dev/net/tun: 文件描述符處于錯誤狀態以上命令執行出來顯示報…

    Linux干貨 2017-06-09
  • yum詳解

    yum YUM: Yellowdog Update Modifier,rpm的前端程序,用來解決軟件包相關依賴性,可以在多個庫之間定位軟件包,up2date的替代工具 yum repository: yum repo,存儲了眾多rpm包,以及包的相關的元數據文件(放置于特定目錄repodata下) yum對軟件包的管理機制 —–引用了…

    Linux干貨 2016-08-25
  • LVS四種模式

    馬哥教育網絡班18期 第17周課程練習1 LVS工作模式圖解 LVS-NAT模式 TCP請求報文的目的IP地址被Director調度服務器重寫為RIP后發送給RS,RS的默認網關配置為Director的DIP,Director接受到RS響應報文后修改源IP地址發送給用戶IP RS網關指向DIP,RIP,DIP和RIP必須在同一網段內 Director轉發請求…

    Linux干貨 2016-06-23
  • CentOS 7上的性能監控工具

    Linux中基于命令行的性能監控工具:dstat、top、netstat、vmstat、htop、ss、glances 1、dstat – 多類型資源統計工具(需配置epel源)   該命令整合了vmstat,iostat和ifstat三種命令。同時增加了新的特性和功能可以讓你能及時看到各種的資源使用情況,從而能夠使你對比和整…

    Linux干貨 2016-09-07

評論列表(1條)

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

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

欧美性久久久久