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、寫一個腳本
-
獲取當前主機的主機名,保存于hostname變量中;
-
判斷此變量的值是否為localhost,如果是,則將當前主機名修改為www.magedu.com;
-
否則,則顯示當前主機名;
#!/bin/bash # hostname=`hostname` if [ $hostname == "localhost" ]; then hostname "www.magedu.com" else echo "$hostname" fi
3、寫一個腳本,完成如下功能
-
傳遞一個磁盤設備文件路徑給腳本,判斷此設備是否存在;
-
如果存在,則顯示此設備上的所有分區信息;
#!/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為quit,則顯示退出腳本,并執行正常退出;
-
如果參數1為yes,則顯示繼續執行腳本;
-
否則,參數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的值為gzip,則使用tar和gzip歸檔壓縮/etc目錄至/backups目錄中,并命名為/backups/etc-20160613.tar.gz;
-
如果參數1的值為bzip2,則使用tar和bzip2歸檔壓縮/etc目錄至/backups目錄中,并命名為/backups/etc-20160613.tar.bz2;
-
如果參數1的值為xz,則使用tar和xz歸檔壓縮/etc目錄至/backups目錄中,并命名為/backups/etc-20160613.tar.xz;
-
其它任意值,則顯示錯誤壓縮工具,并執行非正常退出;
#!/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、寫一個腳本,接受一個路徑參數:
-
如果為普通文件,則說明其可被正常訪問;
-
如果是目錄文件,則說明可對其使用cd命令;
-
如果為符號鏈接文件,則說明是個訪問路徑;
-
其它為無法判斷;
#!/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、寫一個腳本,取得當前主機的主機名,判斷
-
如果主機名為空或為localhost,或為""(none)"",則將其命名為mail.magedu.com;
-
否則,顯示現有的主機名即可;
#!/bin/bash # hostname=`hostname` if [ $hostname == "localhost" -o $hostname == "" ]; then hostname "mail.magedu.com" else echo "$hostname" fi
8、寫一腳本,接受一個用戶名為參數;
-
如果用戶的id號為0,則顯示其為管理員;
-
如果用戶的id號大于0且小于500, 則顯示其為系統用戶;
-
否則,則顯示其為普通用戶;
#!/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、寫一個腳本,傳遞一個用戶名參數給腳本;
-
如果用戶的id號大于等于500,且其默認shell為以sh結尾的字符串,則顯示“a user can log system.”類的字符串;
-
否則,則顯示無法登錄系統;
#!/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、寫一個腳本,完成如下任務 :
-
按順序分別復制/var/log目錄下的每個直接文件或子目錄至/tmp/test1-testn目錄中;
-
復制目錄時,才使用cp -r命令;
-
復制文件時使用cp命令;
-
復制鏈接文件時使用cp -d命令;
-
余下的所有類型,使用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
寫的很好,排版也很棒,加油