Linux運維常用shell腳本實例


1、用shell腳本批量建立Linux用戶
實現要求:創建用戶student1到student50,指定組為student組!而且每個用戶需要設定一個不同的密碼!

腳本實現如下:

 

#!/bin/bash
for i in `seq 1 50`
do
    useradd -G student student$i ; 
    echo student$i | passwd student$i --stdin;
done
 
        

【說明:Linux下 Passwd有參數  --stdin  This option is used to indicate that passwd should read the new password from standard input, which can be a pipe.  所以linux下自動改變用戶密碼的辦法就是:  Echo 密碼 |passwd –stdin 用戶名】-------------------設置相同的密碼------------------------

#!/bin/bash
password="123456"
for USER in user1 user2 user3
do
     useradd -m $USER
     echo -e "${password}\n${password}" | passwd $USER
done

 【說明:
     echo -n 不換行輸出:
$echo -n "123"
$echo "456"
最終輸出 123456
而不是
123
456
    echo -e 處理特殊字符:
        \n 換行且光標移至行首 】 
ok,就這么一個簡單的腳本,就可以再系統里批量生成賬號了。而且密碼跟賬號的名字一樣。
這就是for do done語句用法。

2、 編寫shell腳本,將/usr/local/test目錄下大於100k的文件轉移到/tmp目錄下:

#!/bin/bash
for FILE in `ls /usr/local/test`
do
    if [ -f $FILE ] ; then
        if [ `ls -l  $FILE | awk `{print $5}` -gt 100000 ] ; then
            mv $FILE  /tmp/
        fi
    fi
done

================

#!/bin/bash
for FileName in `ls -l  /usr/local/test | awk '$5>102400' {print $9}`
do
        mv $FileName  /tmp/
done
ls -al  /tmp/
echo  "done!"


3、通過apache訪問日志access.log 統計IP和每個地址訪問的次數,按訪問量列出前10名。
     日志格式樣例如下:
     192.168.1.247  ---【02/jul/2010:23:44:59 + 8080 】 "GET /HTTP/1/1"   200 19
     答案:
         cat  access.log | awk '{print  $1}' |sort| uniq -c |sort -rn |head -10
 (uniq 參數說明:– c 顯示輸出中,在每行行首加上本行在文件中連續出現的次數。
     sort參數說明:sort默認的排序方式是升序,-r 參數就會改變成倒敘;你有沒有遇到過10比2小的情況。我反正遇到過。出現這種情況是由於排序程序將這些數字按字符來排序了,排序程序會先比較1和2,顯然1小,所以就將10放在2前面嘍。這也是sort的一貫作風。)

4、一台監控主機,一台被監控主機。被監控主機分區使用率大於80%,就發告警郵件。放到crontab里面,每10分鍾執行一次。
        a、 首先兩台機器要建立服務器間的信任關系。
        b、腳本:        

 
#!/bin/bash
FSMAX="80"
remote_user='root'
remote_ip=(IP地址列表)
 ip_num='0'
while [ "$ip_num" -le "$(expr ${#remote_ip[@]} -l)"]
do
  read_num='1'
  ssh "$remote_user"@"${remote_ip[$ip_num]}"  df -h > /tmp/diskcheck_tmp
  grep '^/dev/*'  /tmp/diskcheck_tmp | awk '{print $5}'|sed 's/\%//g'  > /tmp/diskcheck_num_tmp
    while [ "$read_num" -le $(wc -l < /tmp/diskcheck_num_tmp) ]
      do
	 size=$(sed -n "$read_num" 'p'  /tmp/diskcheck_num_tmp)
	 if [ "size" -gt "$FSMAX" ]
	   then
	     $(grep '^/dev/*'  /tmp/diskcheck_tmp |sed -n $read_num'p'  > /tmp/disk_check_mail)
	     $(echo ${remote_ip[$ip_num]}) >> /tmp/disk_check_mail)
	     $(mail  -s "diskcheck_alert"  admin  <  /tmp/disk_check_mail)
	 fi
	 read_num=$(expr  $read_num + 1)
	 done
  ip_num=$(expr  $ip_num + 1)
done

===================寫入crontab=====================
0/10 * * * *   /home/diskcheck.sh   2&>1


5、監控主機的磁盤空間,當使用空間超過90%就通過發mail來發警告

#!/bin/bash
#monitor available disk space
#提取本服務器的IP地址信息  
IP=`ifconfig eth0 | grep "inet addr" | cut -f 2 -d ":" | cut -f 1 -d " "`    
SPACE=` df -hP | awk '{print int($5)}'`
if [ $SPACE -ge 90 ]
then
  echo "$IP 服務器 磁盤空間 使用率已經超過90%,請及時處理。"|mail -s "$IP 服務器硬盤告警"   fty89@163.com
fi


6、自動ftp上傳     
   

#! /bin/bash
    ftp -n << END_FTP
    open 192.168.1.22
    user  test testing      //用戶名test  密碼:testing
    binary
    prompt  off    //關閉提示
    mput   files     //上傳files文件
    close
    bye
    END_FTP


7、編寫shell腳本,獲取本機的網絡地址。比如:本機的ip地址是:
192.168.100.5/255.255.255.0,
那么他的網絡地址是:
192.168.100.1/255.255.255.0
方法一:

#!/bin/bash
IP=ifconfig eth0|grep 'inet addr'|sed 's/^.*addr://g'|awk  '{print $1}'
 NETMASK=ifconfig eth0 |grep "inet addr"|sed 's/^.*Mask://g'
echo "$IP/&NETMASK"
exit

方法二:

#!/bin/bash
 #This script print ip and network
 file="/etc/sysconfig/network-scripts/ifcfg-eth0"
 if [ -f $file ] ;then
     IP=`grep "IPADDR" $file|awk -F"=" '{ print $2 }'`
     MASK=`grep "NETMASK" $file|awk -F"=" '{ print $2 }'`
 echo "$IP/$MASK"
 exit 1
 fi

IP地址也可這樣獲取:IP=`ifconfig eth0 | grep "inet addr" | cut -f 2 -d ":" | cut -f 1 -d " "
子網掩碼:NETMASK= `ifconfig eth0 | grep "inet addr"|cut -f 4 -d ":"

 8、某系統管理員需要每天做一定的重復工作,編制一個解決方案:
(1).從下午4:50 刪除/abc 目錄下的全部子目錄和全部文件;
(2).從早上8:00~下午6:00 每小時讀取/xyz 目錄下x1 文件中每行第一個域的全部數
據加入到/backup 目錄下的back01.txt 文件內;
(3).每逢周一下午5:50 將/data 目錄下的所有目錄和文件歸檔並壓縮為文件
backup.tar.gz;
(4).在下午5:55 將IDE 接口的CD-ROM 缷載(假設CD-ROM 的設備名為hdc);
(5).在早上8:00 前開機后啟動。
(a)用vi創建編輯一個名為prgx的crontab文件;
(b)prgx文件的內容:
            50 16 * * * rm -r /abc/*
            0 8-18/1 * * * cut -f1 /xyz/x1 >>  /backup/bak01.txt
            50 17 * * * tar zcvf backup.tar.gz /data
            55 17 * * * umount /dev/hdc
(c)由超級用戶登錄,用crontab執行 prgx文件中的內容:
            root@xxx:#crontab prgx;在每日早晨8:00之前開機后即可自動啟動crontab

9.設計一個shell程序,添加一個新組為class1,然后添加屬於這個組的30個用戶,用戶名的形式為stdxx,其中xx從01到30 
參考答案: 

#!/bin/sh 
i=1 
groupadd class1 
while [ $i -le 30 ] 
do 
if [ $i -le 9 ] ;then 
USERNAME=stu0${i} 
else
USERNAME=stu${i} 
fi 
useradd $USERNAME 
mkdir /home/$USERNAME 
chown -R $USERNAME /home/$USERNAME 
chgrp -R class1 /home/$USERNAME 
i=$(($i+1)) 
done


10.編寫shell程序,實現自動刪除50個賬號的功能。賬號名為stud1至stud50。 
參考程序: 

#!/bin/sh 
i=1 
while [ $i -le 50 ] 
do 
userdel -r stud${i} 
i=$(($i+1 )) 
done 

 

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

參考答案:
(1)編寫shell程序fileback: 

#!/bin/sh 
DIRNAME=`ls /root | grep bak` 
if [ -z "$DIRNAME" ] ; then 
mkdir /root/bak 
cd /root/bak 
fi
BACKETC=$(date +%Y%m%d)_etc.tar.gz 
tar zcvf  $BACKETC  /etc 
echo "fileback finished!" 

(2)編寫任務定時器: 
echo "0 0 1 * * /bin/sh /usr/bin/fileback" >; /root/etcbakcron 
crontab /root/etcbakcron 
或使用crontab -e 命令添加定時任務: 
0 1 * * * /bin/sh /usr/bin/fileback 

 

12.有一普通用戶想在每周日凌晨零點零分定期備份/user/backup到/tmp目錄下,該用戶應如何做? 

參考答案:
(1)第一種方法: 
用戶應使用crontab –e 命令創建crontab文件。格式如下: 
0 0 * * sun cp –r /user/backup /tmp 
(2)第二種方法: 
用戶先在自己目錄下新建文件file,文件內容如下: 
0 * * sun cp –r /user/backup /tmp 
然后執行 crontab file 使生效。 
13.設計一個Shell程序,在/userdata目錄下建立50個目錄,即user1~user50,並設置每個目錄的權限,其中其他用戶的權限為:讀;文件所有者的權限為:讀、寫、執行;文件所有者所在組的權限為:讀、執行。 
參考答案: 建立程序 Pro16如下: 

#!/bin/sh 
i=1 
while [ i -le 50 ] 
  do 
  if [ -d /userdata ];then 
    mkdir -p -m 754 /userdata/user$i   加上-m 754 就不用寫下面那一句了  -p 是遞歸建立目錄 
    #chmod 754 /userdata/user$i 
    echo "user$i" 
    let "i = i + 1" (或i=$(($i+1)) 
  else 
    mkdir /userdata 
    mkdir -p -m /userdata/user$i 
#chmod 754 /userdata/user$i 
    echo "user$i" 
    let "i = i + 1" (或i=$(($i+1)) 
  fi 
done


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM