久久国产成人av_抖音国产毛片_a片网站免费观看_A片无码播放手机在线观看,色五月在线观看,亚洲精品m在线观看,女人自慰的免费网址,悠悠在线观看精品视频,一级日本片免费的,亚洲精品久,国产精品成人久久久久久久

分享

Linux運(yùn)維常用shell腳本實例

 科技強(qiáng)我 2018-06-14

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

腳本實現(xiàn)如下:

  1. <span style="font-size:14px;">#!/bin/bash  
  2. for i in `seq 1 50`  
  3. do  
  4.     useradd -G student student$i ;   
  5.     echo student$i | passwd student$i --stdin;  
  6. done</span>  
【說明:Linux下 Passwd有參數(shù)  --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 用戶名】-------------------設(shè)置相同的密碼------------------------
  1. #!/bin/bash  
  2. password="123456"  
  3. for USER in user1 user2 user3  
  4. do  
  5.      useradd -m $USER  
  6.      echo -e "${password}\n${password}" | passwd $USER  
  7. done  
 【說明:
     echo -n 不換行輸出:
$echo -n "123"
$echo "456"
最終輸出 123456
而不是
123
456
    echo -e 處理特殊字符:
        \n 換行且光標(biāo)移至行首 】 
ok,就這么一個簡單的腳本,就可以再系統(tǒng)里批量生成賬號了,。而且密碼跟賬號的名字一樣,。
這就是for do done語句用法。

2,、 編寫shell腳本,,將/usr/local/test目錄下大于100k的文件轉(zhuǎn)移到/tmp目錄下:
  1. #!/bin/bash  
  2. for FILE in `ls /usr/local/test`  
  3. do  
  4.     if [ -f $FILE ] ; then  
  5.         if [ `ls -l  $FILE | awk `{print $5}` -gt 100000 ] ; then  
  6.             mv $FILE  /tmp/  
  7.         fi  
  8.     fi  
  9. done  
================
  1. #!/bin/bash  
  2. for FileName in `ls -l  /usr/local/test | awk '$5>102400' {print $9}`  
  3. do  
  4.         mv $FileName  /tmp/  
  5. done  
  6. ls -al  /tmp/  
  7. echo  "done!"  

3、通過apache訪問日志access.log 統(tǒng)計IP和每個地址訪問的次數(shù),,按訪問量列出前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 參數(shù)說明:– c 顯示輸出中,在每行行首加上本行在文件中連續(xù)出現(xiàn)的次數(shù),。
     sort參數(shù)說明:sort默認(rèn)的排序方式是升序,,-r 參數(shù)就會改變成倒敘;你有沒有遇到過10比2小的情況,。我反正遇到過,。出現(xiàn)這種情況是由于排序程序?qū)⑦@些數(shù)字按字符來排序了,排序程序會先比較1和2,,顯然1小,,所以就將10放在2前面嘍,。這也是sort的一貫作風(fēng)。)

4,、一臺監(jiān)控主機(jī),,一臺被監(jiān)控主機(jī)。被監(jiān)控主機(jī)分區(qū)使用率大于80%,,就發(fā)告警郵件,。放到crontab里面,每10分鐘執(zhí)行一次,。
        a,、 首先兩臺機(jī)器要建立服務(wù)器間的信任關(guān)系。
        b,、腳本:
             
  1. #,!/bin/bash  
  2.                FSMAX="80"  
  3.                remote_user='root'  
  4.                remote_ip=(IP地址列表)  
  5.                 ip_num='0'  
  6.                while [ "$ip_num" -le "$(expr ${#remote_ip[@]} -l)"]  
  7.                do  
  8.                        read_num='1'  
  9.                        ssh "$remote_user"@"${remote_ip[$ip_num]}"  df -h > /tmp/diskcheck_tmp  
  10.                        grep '^/dev/*'  /tmp/diskcheck_tmp | awk '{print $5}'|sed 's/\%//g'  > /tmp/diskcheck_num_tmp  
  11.                          while [ "$read_num" -le $(wc -l < /tmp/diskcheck_num_tmp) ]  
  12.                            do  
  13.                                    size=$(sed -n "$read_num" 'p'  /tmp/diskcheck_num_tmp)  
  14.                                            if [ "size" -gt "$FSMAX" ]  
  15.                                            then  
  16.                                                    $(grep '^/dev/*'  /tmp/diskcheck_tmp |sed -n $read_num'p'  > /tmp/disk_check_mail)  
  17.                                                    $(echo ${remote_ip[$ip_num]}) >> /tmp/disk_check_mail)  
  18.                                                    $(mail  -s "diskcheck_alert"  admin  <  /tmp/disk_check_mail)  
  19.                                            fi  
  20.                                    read_num=$(expr  $read_num + 1)  
  21.                            done  
  22.                        ip_num=$(expr  $ip_num + 1)  
  23.              done  

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


5、監(jiān)控主機(jī)的磁盤空間,當(dāng)使用空間超過90%就通過發(fā)mail來發(fā)警告
  1. #!/bin/bash  
  2. #monitor available disk space  
  3. #提取本服務(wù)器的IP地址信息    
  4. IP=`ifconfig eth0 | grep "inet addr" | cut -f 2 -d ":" | cut -f 1 -d " "`      
  5. SPACE=` df -hP | awk '{print int($5)}'`  
  6. if [ $SPACE -ge 90 ]  
  7. then  
  8.   echo "$IP 服務(wù)器 磁盤空間 使用率已經(jīng)超過90%,,請及時處理,。"|mail -s "$IP 服務(wù)器硬盤告警"   [email protected]  
  9. fi  

6、自動ftp上傳     
   
  1. #! /bin/bash  
  2.     ftp -n << END_FTP  
  3.     open 192.168.1.22  
  4.     user  test testing      //用戶名test  密碼:testing  
  5.     binary  
  6.     prompt  off    //關(guān)閉提示  
  7.     mput   files     //上傳files文件  
  8.     close  
  9.     bye  
  10.     END_FTP  

7,、編寫shell腳本,,獲取本機(jī)的網(wǎng)絡(luò)地址。比如:本機(jī)的ip地址是:
192.168.100.5/255.255.255.0,
那么他的網(wǎng)絡(luò)地址是:
192.168.100.1/255.255.255.0
方法一:
  1. #,!/bin/bash  
  2. IP=ifconfig eth0|grep 'inet addr'|sed 's/^.*addr://g'|awk  '{print $1}'  
  3.  NETMASK=ifconfig eth0 |grep "inet addr"|sed 's/^.*Mask://g'  
  4. echo "$IP/&NETMASK"  
  5. exit  
方法二:
  1. #!/bin/bash  
  2.  #This script print ip and network  
  3.  file="/etc/sysconfig/network-scripts/ifcfg-eth0"  
  4.  if [ -f $file ] ;then  
  5.      IP=`grep "IPADDR" $file|awk -F"=" '{ print $2 }'`  
  6.      MASK=`grep "NETMASK" $file|awk -F"=" '{ print $2 }'`  
  7.  echo "$IP/$MASK"  
  8.  exit 1  
  9.  fi  
IP地址也可這樣獲?。篒P=`ifconfig eth0 | grep "inet addr" | cut -f 2 -d ":" | cut -f 1 -d " "
子網(wǎng)掩碼:NETMASK= `ifconfig eth0 | grep "inet addr"|cut -f 4 -d ":"

 8、某系統(tǒng)管理員需要每天做一定的重復(fù)工作,,編制一個解決方案:
(1).從下午4:50 刪除/abc 目錄下的全部子目錄和全部文件,;
(2).從早上8:00~下午6:00 每小時讀取/xyz 目錄下x1 文件中每行第一個域的全部數(shù)
據(jù)加入到/backup 目錄下的back01.txt 文件內(nèi);
(3).每逢周一下午5:50 將/data 目錄下的所有目錄和文件歸檔并壓縮為文件
backup.tar.gz;
(4).在下午5:55 將IDE 接口的CD-ROM 缷載(假設(shè)CD-ROM 的設(shè)備名為hdc);
(5).在早上8:00 前開機(jī)后啟動,。
(a)用vi創(chuàng)建編輯一個名為prgx的crontab文件,;
(b)prgx文件的內(nèi)容:
            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執(zhí)行 prgx文件中的內(nèi)容:
            root@xxx:#crontab prgx,;在每日早晨8:00之前開機(jī)后即可自動啟動crontab

9.設(shè)計一個shell程序,,添加一個新組為class1,然后添加屬于這個組的30個用戶,,用戶名的形式為stdxx,,其中xx從01到30 
參考答案: 
  1. #!/bin/sh   
  2. i=1   
  3. groupadd class1   
  4. while [ $i -le 30 ]   
  5. do   
  6. if [ $i -le 9 ] ;then   
  7. USERNAME=stu0${i}   
  8. else  
  9. USERNAME=stu${i}   
  10. fi   
  11. useradd $USERNAME   
  12. mkdir /home/$USERNAME   
  13. chown -R $USERNAME /home/$USERNAME   
  14. chgrp -R class1 /home/$USERNAME   
  15. i=$(($i+1))   
  16. done  

10.編寫shell程序,實現(xiàn)自動刪除50個賬號的功能,。賬號名為stud1至stud50,。 
參考程序: 
  1. #!/bin/sh   
  2. i=1   
  3. while [ $i -le 50 ]   
  4. do   
  5. userdel -r stud${i}   
  6. i=$(($i+1 ))   
  7. done   


11.設(shè)計一個shell程序,在每月第一天備份并壓縮/etc目錄的所有內(nèi)容,存放在/root/bak目錄里,,且文件名為如下形式y(tǒng)ymmdd_etc,,yy為年,mm為月,,dd為日,。Shell程序fileback存放在/usr/bin目錄下。 

參考答案:
(1)編寫shell程序fileback: 
  1. #!/bin/sh   
  2. DIRNAME=`ls /root | grep bak`   
  3. if [ -z "$DIRNAME" ] ; then   
  4. mkdir /root/bak   
  5. cd /root/bak   
  6. fi  
  7. BACKETC=$(date +%Y%m%d)_etc.tar.gz   
  8. tar zcvf  $BACKETC  /etc   
  9. echo "fileback finished!"   
(2)編寫任務(wù)定時器: 
echo "0 0 1 * * /bin/sh /usr/bin/fileback" >; /root/etcbakcron 
crontab /root/etcbakcron 
或使用crontab -e 命令添加定時任務(wù): 
0 1 * * * /bin/sh /usr/bin/fileback 


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

參考答案:
(1)第一種方法: 
用戶應(yīng)使用crontab –e 命令創(chuàng)建crontab文件。格式如下: 
0 0 * * sun cp –r /user/backup /tmp 
(2)第二種方法: 
用戶先在自己目錄下新建文件file,,文件內(nèi)容如下: 
0 * * sun cp –r /user/backup /tmp 
然后執(zhí)行 crontab file 使生效,。 
13.設(shè)計一個Shell程序,在/userdata目錄下建立50個目錄,,即user1~user50,,并設(shè)置每個目錄的權(quán)限,其中其他用戶的權(quán)限為:讀,;文件所有者的權(quán)限為:讀,、寫、執(zhí)行,;文件所有者所在組的權(quán)限為:讀,、執(zhí)行。 
參考答案: 建立程序 Pro16如下: 
  1. #!/bin/sh   
  2. i=1   
  3. while [ i -le 50 ]   
  4. do   
  5. if [ -d /userdata ];then   
  6. mkdir -p -m 754 /userdata/user$i   加上-m 754 就不用寫下面那一句了  -p 是遞歸建立目錄   
  7. #chmod 754 /userdata/user$i   
  8. echo "user$i"   
  9. let "i = i + 1" (或i=$(($i+1))   
  10. else   
  11. mkdir /userdata   
  12. mkdir -p -m /userdata/user$i   
  13. #chmod 754 /userdata/user$i   
  14. echo "user$i"   
  15. let "i = i + 1" (或i=$(($i+1))   
  16. fi   
  17. done  

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn),。請注意甄別內(nèi)容中的聯(lián)系方式,、誘導(dǎo)購買等信息,謹(jǐn)防詐騙,。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,,請點(diǎn)擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多