shell指令碼學習-2

來源:互聯網
上載者:User

 1.用Shell編程,判斷一檔案是不是塊或字元裝置檔案,如果是將其拷貝到 /dev 目錄下。

#!/bin/bash
#1.sh
#判斷一檔案是不是字元或塊裝置檔案,如果是將其拷貝到 /dev 目錄下
#file executable: chmod 755 1.sh
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
export PATH
echo -e "The program will Judge a file is or not a device file./n/n"
read -p "Input a filename : " filename
if [ -b "$filename" -o -c "$filename" ]
then
       echo "$filename is a device file" && cp $filename /dev/ &
else
       echo "$filename is not a device file" && exit 1
fi

 

1.5  用Shell編程,判斷目錄下所有檔案 是不是塊或字元裝置檔案,如果是將其拷貝到 /laji 目錄下。
for file in `ls -l /dev | awk '/^[bc]/ {print $10}'`
do
file="/dev/"$file
echo -e "$file is Block file or character file" &&cp $file /laji -Rf
done

或者

ls -l /dev | awk '/^[bc]/ {print "/dev/"$10}' |xargs -i cp {} laji -Rf

---------------------------------

2. 設計一個shell程式,添加一個新組為class1,然後添加屬於這個組的30個使用者,使用者名稱的形式為stdxx,其中xx從01到30。

#!/bin/bash
#2.sh
#設計一個shell程式,添加一個新組為class1,然後添加屬於這個組的30個使用者,使用者名稱的形式為stdxx,其中xx從01到30。
#file executable: chmod 755 2.sh
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
export PATH
groupadd class1
for i in {9901..9930}
do
       xx=`echo $i | sed 's/99//g'`
       useradd -g class1 std$xx
       echo std$xx | passwd std$xx --stdin
       echo -e "user std$xx password is std$xx" >> /root/newuser.txt
done

--------------------------------
3.編寫shell程式,實現自動刪除50個帳號的功能。帳號名為stud1至stud50。

#!/bin/bash
#4.sh
#編寫shell程式,實現自動刪除50個帳號的功能。帳號名為stud1至stud50。
#file executable: chmod 755 3.sh
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
export PATH
i=1
while [ i -le 50 ]
do
   let i++
       userdel -r stud$i
done

-------------------------------
4.某系統管理員需每天做一定的重複工作,請按照下列要求,編製一個解決方案:
(1)在下午4 :50刪除/abc目錄下的全部子目錄和全部檔案;
(2)從早8:00~下午6:00每小時讀取/xyz目錄下x1檔案中每行第一個域的全部資料加入到/backup目錄下的bak01.txt檔案內;
(3)每逢星期一下午5:50將/data目錄下的所有目錄和檔案歸檔並壓縮為檔案:backup.tar.gz;
(4)在下午5:55將IDE介面的CD-ROM卸載(假設:CD-ROM的裝置名稱為hdc);
(5)在早晨8:00前開機後啟動。

vim /etc/crontab 在裡面增加下面內容:

50 16 * * * root rm -rf /abc/* 2>&1 &
00 8-18 * * * root cat /xyz/x1|awk '{print $1}' >> /backup/bak01.txt 2>&1 &
50 17 * * 1 root cd /data;tar -zcvf backup.tar.gz * 2>&1 &
55 17 * * * root umount /hdc 2>&1 &

5)在早晨8:00前開機後啟動 --> 這個我不是很明白它的意思,不知道是不是8點前開機就啟動上面的設定,8點後才開機就不用啟動的意思。
姑且用下面這個命令吧
chkconfig --level 2345 crond on

----------------------------

5.設計一個shell程式,在每月第一天備份並壓縮/etc目錄的所有內容,存放在/root/bak目錄裡,且檔案名稱
為如下形式yymmdd_etc,yy為年,mm為月,dd為日。Shell程式fileback存放在/usr/bin目錄下。

vim /usr/bin/fileback.sh

#!/bin/bash
#fileback.sh
#file executable: chmod 755 fileback.sh
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
export PATH
filename=`date +%y%m%d`_etc.tar.gz
cd /etc/
tar -zcvf $filename *
mv $filename /root/bak/
------------------------------------------------------
vim /etc/crontab 加入
* * 1 * * root ./fileback.sh &

-----------------------------------
6.有一普通使用者想在每周日淩晨零點零分定期備份/user/backup到/tmp目錄下,該使用者應如何做?
可以用 contab -e 來做,和上面一題差不多。

7.設計一個Shell程式,在/userdata目錄下建立50個目錄,即user1~user50,並設定每個目錄的許可權,其
中其他使用者的許可權為:讀;檔案所有者的許可權為:讀、寫、執行;檔案所有者所在組的許可權為:讀、執行。

#!/bin/bash
#7.sh
#file executable: chmod 755 7.sh
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
export PATH
for ((i=1;i<=50;i++))
do
       mkdir -p /usrdata/user$i
       cd /usrdata
       chmod 754 user$i
done

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.