馬哥教育21期網絡班—第9周課程+練習—-成長進行時–不退步

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

#!/bin/bash 
declare -i other=0
declare -i nologin=0
    for i in $(cut -d: -f7 /etc/passwd);do
        if [ $i == /sbin/nologin ];then
            let nologin++
                else
            let other++
       fi
    done
echo "other user total:$other"echo "nologin user total:$nologin"
  • 2、寫一個腳本

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

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

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

#!/bin/bash 
hostname=$(hostname)
if [ $hostname=='localhost' ];then
    hostname www.magedu.com   
    echo "hostnamme change : 'www.magedu.com'"
else
    echo 'hostname is: $hostname'
fi
  • 3、寫一個腳本,完成如下功能

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

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

#!/bin/bash 
read -p "Enter dev and file:" dev
if [ -e $dev ];then
    fdisk -l $dev
else
    echo "This devfile is not exist"
fi
  • 4、寫一個腳本,完成如下功能

  • 腳本能夠接受一個參數;

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

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

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

#!/bin/bash
if [ $# -eq 0 ];then
    echo “Enter one option”
else
case $1
inquit)echo “exit nomal”
;;
yes)echo “go on”
;;
*)echo “exit unomal”
;;
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  [ ! -e /backups ];then
mkdir /backups
fi
    read -p "please choose the Compression tool(gzip|bzip2|xz) " i
case $i 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 "please choose the correct tools"
        exit 1
;;
esac
  • 6、寫一個腳本,接受一個路徑參數:

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

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

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

  • (4) 其它為無法判斷;

#!/bin/bash
read -p "please input something " n
if [ -f $n ];then
   echo "$n can be access"
elif [ -d $n ];then
   echo "$n can be use "cd" command"
elif [ -L $n ];then
   echo "this is a access path"
else
   echo "$n can't be judge" 
fi
  • 7、寫一個腳本,取得當前主機的主機名,判斷

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

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

#!/bin/bash
host=`hostname`
if [ “$host”=”localhost” -o -z “$host” –o “$host”=”none” ];then
hostnamemail.magedu.com
else
echo “this machine hostname exists, it is $host”
fi
  • 8、寫一腳本,接受一個用戶名為參數;

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

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

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

#!/bin/bash        
        read -p "input a user name:" username
        uid=$(grep "^$username" /etc/passwd |cut -d: -f3)
        if [ $uid -eq 0 ];then
        echo "this is root."
        elif [ $uid -gt 0 -a $uid -le 500 ];then
        echo "this is a system user."
        else 
        echo "this is a common user."
        fi
  • 10、寫一個腳本,傳遞一個用戶名參數給腳本;

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

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

 #!/bin/bash
if [ $# -eq 1 ] && id $1>/dev/null;then
uid=`grep "$1" /etc/passwd | cut -d: -f3`
 if [ $uid -eq 0 ];then
  echo "this is root"
 elif [ $uid -gt 0 ]&&[ $uid -lt 500 ];then
  echo "this is system user"
 elif [ $uid -gt 500 ];then
  echo "this is normal user"
 fi
 else
  echo "please input the exist username"
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_ Dominic,如若轉載,請注明出處:http://www.www58058.com/43125

(0)
N21_ DominicN21_ Dominic
上一篇 2016-09-05 08:50
下一篇 2016-09-05 08:52

相關推薦

  • linux系統基礎目錄結構及功能說明

    linux系統基礎目錄結構及功能說明 [root@localhost /]# ls bin boot dev etc home host lib lib64 media mnt opt proc root run sbin srv sys tmp usr var /bin:所有用戶可用的基本命令程序文件;/sbin:供系統管理使用的工具程序;/boot:引導…

    Linux干貨 2018-03-04
  • shell中的引號用法

        SHELL引號  在shell里可以通過使用單引號,雙引號,反引號(TAB鍵上方的按鍵),反斜線來轉換某些shell元字符的含義。比如說,我們希望echo命令顯示出$本身字符的意義,而不是變量,我們需要使用某些功能來屏蔽$符號本身賦予的特殊含義,使其還原本身字面的意思。 主要講述四個比較特殊常用的符號。 1.反…

    2017-06-11
  • PHP安全模式詳解(PHP5.4安全模式將消失)

    1. 安全模式      一直沒有用過php的safe_mode安全模式,以此說明作為日后參考。      PHP 的安全模式是為了試圖解決共享服務器(shared-server)安全問題而設立的。在結構上,試圖在 PHP 層上解決這個問題是不合理的,但修改 web 服務器層和操作系統層顯得非常不現…

    Linux干貨 2015-06-02
  • 配置正、反向解析域,主從配置,子域授權

    配置解析一個正向區域:     1、定義區域        在主配置文件中(/etc/named.conf)或主配置文件輔助配置文件(/etc/named.rfc1912.conf)中實現:     (1) 在/etc/…

    Linux干貨 2017-05-31
  • Linux之SELinux

      Linux之SELinux     本文包括以下內容SELinux概念啟用SELinux管理文件安全標簽管理端口標簽管理SELinux布爾值開關管理日志查看SELinux幫助   SELinux介紹SELinux: Secure Enhanced Linux,是美國國家安全局(NSA=The National Se…

    Linux干貨 2016-09-21
  • OpenSSL:實現創建私有CA、簽署證書請求詳解

    一、OpenSSL:CA默認配置信息     1.證書簽發機構CA:公共信任CA、私有CA                建立私有CA方式如下: 小范圍測試使用openssl、 大…

    Linux干貨 2016-04-30

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-09-07 18:39

    腳本寫得非常的漂亮,思路清晰,腳本的縮進注意一下哈,7題的if 判斷 字符串之間的相等判斷使用的是”==“

欧美性久久久久