N22-妙手-第九周課程練習

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

#!/bin/bash
#

declare -i numberOfLoginUser=0
declare -i numberOfUnloginUser=0

while read lines; do

    shellType=${lines##*:}
    if [ "$shellType" == "/sbin/nologin" ]; then
        let numberOfUnloginUser++
    else
        let numberOfLoginUser++
    fi
done < /etc/passwd

echo "How many login shell: "$numberOfLoginUser"
echo "How many unlogin shell" $numberOfUnloginUser"

2、寫一個腳本

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

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

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

#!/bin/bash
#

hostname=$(hostname)
if [ "$hostname" == "www.magedu.com" ]; then
    hostnamectl set-hostname localhost.localdomain
    echo $(hostname)
else
    echo $hostname
fi

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

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

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

#!/bin/bash
#
if [ -b $1 ]; then
    fdisk -l $1
else
    echo "Please send the device file"
fi

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

腳本能夠接受一個參數;

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

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

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

#!/bin/bash

case $1 in
quit) 
    echo "Exit the shell script"
    exit 
    ;;
yes)
    echo "continue excute the shell script"
    ;;
*)
    echo "pleaes input quit or yes"
    exit 2
    ;;
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
#

format=$1

case $format in

gzip)
    tar -cf /backups/etc-20161013.tar.gz /etc/
    ;;
bzip2) 
    tar -jcf /backups/etc-21061013.tar.bz2 /etc/
    ;;
xz)    
    tar -Jcf /backups/etc-20161013.tar.xz /etc/
    ;;
*)
    echo "Please use the right compresss tool"
    exit 2
    ;;
esac

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

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

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

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

(4) 其它為無法判斷;

#!/bin/bash
#
para1=$1

if [ -f $para1 ]; then
    echo "This file can be accessed normally."
elif [ -d $para1 ]; then
    echo "This file is directory file and can use cd command to this directory"
elif [ -L $para1 ]; then
    echo "This is a symbol link file"
else 
    echo "The file can not be identified"
fi

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

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

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

#!/bin/bash
#

hostName=$(hostname)

if [ -z "$hostName" ] || [ "$hostName" == "localhost" ] || [ "$hostName" == "(none)" ]; then
    hostnamectl set-hostname mail.magedu.com
    echo $(hostname)
else
    echo $(hostname)
fi

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

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

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

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

#!/bin/bash
#
read -p "Please Enter username: " username

if id $name >& /dev/null; then
    userid=$(id -u $username)
    if [ $userid -eq 0 ]; then
        echo "Root user"
    elif [ $userid -gt 0 ] && [ $userid -le 500 ]; then
        echo "System user"
    else
        echo "Common user"
    fi

else
    echo "please input valid username"
    exit 2
fi

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

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

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

#!/bin/bash
#

if [ $# -lt 1 ]; then
    echo "Please send at lease 1 username"
    exit 1
fi

if id $1 >& /dev/null; then
    userid=$(id -u $1)
    userinfo=$(cat /etc/passwd | grep $1)
    if [ $userid -gt 500 ] && [ "${userinfo: -2}" == "sh" ];then
        echo "a user can log system"
    else    
        echo "this user can not log to system"
    fi
else
    echo "Please input a valid username"
fi

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

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

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

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

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

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

#!/bin/bash
#

dir=/test/test1-testn

if !(( -d $dir )); then
    mkdir -pv /test/test1-testn
fi

for i in /tmp/*; do
    if [ -d $i ]; then
        cp -r $i $dir
    elif [ -f $i ]; then
        cp $i $dir
    elif [ -L $i ]; then
        cp -d $i $dir
    else
        cp -a $i $dir
    fi
done

原創文章,作者:mxb93,如若轉載,請注明出處:http://www.www58058.com/52147

(0)
mxb93mxb93
上一篇 2016-10-19
下一篇 2016-10-19

相關推薦

  • 救援模式安裝RPM

    救援模式安裝RPM 步驟如下: (1)先讓RPM“自殺”掉,必須要使用忽略依賴選項—nodeps,否則卸載不了RPM程序。 (2)卸載完成后,將機器重啟,按F2鍵進入機器的BIOS模式,如下圖選擇CD-ROM啟動,最后按F10保存退出。 (3)機器將會從光驅上使用光盤文件做引導啟動,如下圖界面,相信大家都非常熟悉,該界面在我們安裝新系統的時候,也會見到。啰嗦…

    Linux干貨 2016-08-26
  • 操作系統文件管理

      在現代計算機系統中,要用到大量的程序和數據,因內存容量有限,且不能長期保存,故而平時總是把它們以文件的形式存放在外存中,需要時再隨時將它們調入內存。如果由用戶直接管理外存上的文件,不僅要求用戶熟悉外存特性,了解各種文件的屬性,以及它們在外存上的位置,而且在多用戶環境下,還必須能保持數據的安全性和一致性。顯然,這是用戶所不能勝任、也不愿…

    Linux干貨 2015-04-13
  • Linux Sysadmin–part4

    一、請詳細描述CentOS系統的啟動流程(詳細到每個過程系統做了哪些事情) A.POST加電自檢 主板在接通電源后,系統首先由POST程序來對內部各個設備進行檢查,自檢中如發現有錯誤,將按兩種情況處理:對于嚴重故障(致命性故障)則停機,此時由于各種初始化操作還沒完成,不能給出任何提示或信號;對于非嚴重故障則給出提示或聲音報警信號,等待用戶處理。 B.BIOS…

    2017-10-10
  • 用戶和組管理的命令

    用戶管理概念: 用戶類別:         管理員,普通用戶,(系統用戶和登錄用戶) 組類別:         管理組員,普通用戶組         基本組和附加組         私有組,公共組 數…

    Linux干貨 2016-12-21
  • 用vsftpd來搭建網絡yum源

    1、分別在CentOS6和CentOS7分別搭建網絡yum源 a、CentOS 7中 首先安裝并啟用vsftpd服務 [root@node1 ~]# mount /dev/cdrom /mnt/yum/ [root@node1 ~]# vim /etc/yum.repos.d/local.repo [local] name=local baseurl=fil…

    2015-10-03
  • ?iptables簡單介紹

    iptables簡單介紹 什么是防火墻? 防火墻是工作在主機或網絡邊緣,能夠對其所匹配到的報文根據事先定義好的規則作出相應處理的組件,可以是軟件,也可以是硬件,還能軟硬結合實現。 UNIX/Linux中對防火墻的實現 早期在openBSD中通過內核中的ipfw實現簡單的數據報過濾功能、后來在Linux 2.2內核中使用ipchains來取代,意為鏈、后來在L…

    Linux干貨 2016-03-31

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-10-25 13:28

    注意審題,不要理解反了,好好看看第二個問題的要求

欧美性久久久久