Shell脚本一

1、ping局域网IP
脚本一
--------------------------------------------------------------------------------------------------
#!/bin/bash
ip=1
while [ $ip != "254" ];do
ping 192.168.14.$ip -c 1 | grep -q "ttl=" && echo "192.168.14.$ip yes" || echo "192.168.14.$ip no"
ip=`expr "$ip" "+" "1"`
done
--------------------------------------------------------------------------------------------------
脚本二

#!/bin/bash
ip="192.168.14."
for i in `seq 1 254`
do
  ping -c 1 $ip$i | grep -q 'ttl=' && echo "$ip$i yes" || echo "$ip$i no"
done
--------------------------------------------------------------------------------------------------

2、ping 多个域名脚本  list为域名文件

#!/bin/sh
for a in `cat list`;do
ping -c 1 $a;
done
--------------------------------------------------------------------------------------------------


3、ping时返回mac
#!/bin/bash

PREFIX=192.168.14
octet=1
while [ "$octet" -lt "255" ];do
        echo -en "Pinging ${PREFIX}.${octet}..."
        ping -c1 -w1 ${PREFIX}.${octet} > /dev/null 2>&1
        if [ "$?" -eq "0" ];then
                echo "OK"
        else
                echo "Failed"
        fi

        let octet=$octet+1
done



--------------------------------------------------------------------------------------------------
4 带输入的ping 
#!/bin/bash
#Filename: netscan.sh

network=$1
time=$(date +%H%M%S)

for i in $(seq $2 $3)
do
    ping -c 1 -w 2 $network.$i > /dev/null
    if [ $? -eq 0 ]; then
          arp $network.$i | grep ":" | awk '{print $1,$3}' >> $time.log
          echo "host $network.$i is up"
   else
          echo "host $network.$i is down"
   fi
done

执行时加参数
[root@3F-209 ~]# sh ping.sh 192.168.14 80 100
host 192.168.14.80 is up
host 192.168.14.81 is down
--------------------------------------------------------------------------------------------------


5 速度快
#!/bin/bash
for i in `seq 1 254`
do
    {
        ping -c2 192.168.14.$i &>/dev/null && echo "192.168.14.$i is alive"
    }&
done
--------------------------------------------------------------------------------------------------


6 从文件读取IP
#! /bin/bash
for i in `cat allip`
do
ping=`ping -c 1 $i|grep loss|awk '{print $6}'|awk -F "%" '{print $1}'`
if [ $ping -eq 100  ];then
echo ping $i fail
else
echo ping $i ok
fi
done


7 for循环批量操作服务器
for i in `cat idc-xiaomi-a`;do scp A $i:/home/work/A.new;done
for i in `cat idc-xiaomi-a`;do ssh $i:`cd /home/work; cp A A.20150102; mv A.new A;md5sum A`;done
for ip in `cat 3Fip.txt`;do ssh $ip ' echo "------------------------------------" && hostname && cat ~/.bashrc';done
for ip in `cat 3Fip.txt`;do scp nohup.out $ip:/root ;done
--------------------------------------------------------------------------------------------------

8 文件重命名
a) rename 替换比较方便
owl owl- *  把当前目录下所有文件名中的owl替换为owl-
--------------------------------------------------------------------------------------------------

b) for循环   要重命名的文件 20141113_0500_owl-owl-test.tgz

将文件名中以-分割为两部分,并调换两部分顺序
#!/bin/bash

for file in `ls *.tgz`
do
  filename=${file%.tgz}                           #获取文件名,不包括后缀tgz
  one=`echo $filename | awk -F '_' '{print $1}'`
  two=`echo $filename | awk -F '_' '{print $2}'`
  mv ${filename}.tgz ${two}-${one}.tgz
done
--------------------------------------------------------------------------------------------------

c) awk重命名 相当灵活  要重命名的文件 20141113_0500_owl-owl-test.tgz

ls *.tgz | awk -F'[.-]' '{system("mv "$0" "$2"_"$1"-owl-test.tgz")}'

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目录下
#!/bin/sh  
DIRNAME=`ls /root | grep bak`  
if [ -z "$DIRNAME" ] ; then  
mkdir /root/bak  
cd /root/bak  
fi  
YY=`date +%y`  
MM=`date +%m`  
DD=`date +%d`  
BACKETC=$YY$MM$DD_etc.tar.gz  
tar zcvf $BACKETC /etc  
echo “fileback finished!” 

12.设计一个Shell程序,在/userdata目录下建立50个目录,即user1~user50,并设置每个目录的权限,
其中其他用户的权限为:读;文件所有者的权限为:读、写、执行;文件所有者所在组的权限为:读、执行。
#!/bin/sh  
i=1  
while [ i -le 50 ]  
do  
if [ -d /userdata ];then  
mkdir -p /userdata/user$i  
chmod 754 /userdata/user$i  
echo “user$i”  
let “i = i + 1″ (或i=$(($i+1))  
else  
mkdir /userdata  
mkdir -p /userdata/user$i  
chmod 754 /userdata/user$i  
echo “user$i”  
let “i = i + 1″ (或i=$(($i+1))  
fi  
done  

13.mysql备份实例,自动备份mysql,并删除30天前的备份文件
#!/bin/sh  
  
#auto backup mysql  
#wugk  2012-07-14  
#PATH DEFINE  
  
BAKDIR=/data/backup/mysql/`date +%Y-%m-%d`  
MYSQLDB=www  
MYSQLPW=backup  
MYSQLUSR=backup  
  
if[ $UID -ne 0 ];then  
echo This script must use administrator or root user ,please exit!  
sleep 2  
exit 0  
fi  
  
if[ ! -d $BAKDIR ];then  
mkdir -p $BAKDIR  
else  
echo This is $BAKDIR exists ,please exit ….  
sleep 2  
exit  
fi  
  
###mysqldump backup mysql  
  
/usr/bin/mysqldump -u$MYSQLUSR -p$MYSQLPW -d $MYSQLDB >/data/backup/mysql/`date +%Y-%m-%d`/www_db.sql  
  
cd $BAKDIR ; tar -czf  www_mysql_db.tar.gz *.sql  
  
cd $BAKDIR ;find  . -name “*.sql” |xargs rm -rf[ $? -eq 0 ]&&echo “This `date +%Y-%m-%d` RESIN BACKUP is SUCCESS”  
  
cd /data/backup/mysql/ ;find . -mtime +30 |xargs rm -rf

14. 自动安装Nginx脚本,采用case方式,选择方式,也可以根据实际需求改成自己想要的脚本
#!/bin/sh  
  
###nginx install shell  
###wugk 2012-07-14  
###PATH DEFINE  
  
SOFT_PATH=/data/soft/  
NGINX_FILE=nginx-1.2.0.tar.gz  
DOWN_PATH=http://nginx.org/download/  
  
if[ $UID -ne 0 ];then  
echo This script must use administrator or root user ,please exit!  
sleep 2  
exit 0  
fi  
  
if[ ! -d $SOFT_PATH ];then  
mkdir -p $SOFT_PATH  
fi  
  
download ()  
{  
cd $SOFT_PATH ;wget $DOWN_PATH/$NGINX_FILE  
}  
  
install ()  
{  
yum install pcre-devel -y  
cd $SOFT_PATH ;tar xzf $NGINX_FILE ;cd nginx-1.2.0/ &&./configure –prefix=/usr/local/nginx/ –with-http_stub_status_module –with-http_ssl_module  
[ $? -eq 0 ]&&make &&make install  
}  
  
start ()  
{  
lsof -i :80[ $? -ne 0 ]&&/usr/local/nginx/sbin/nginx  
}  
  
stop ()  
{  
ps -ef |grep nginx |grep -v grep |awk ‘{print $2}’|xargs kill -9  
}  
  
exit ()  
{  
echo $? ;exit  
}  
  
###case menu #####  
  
case $1 in  
download )  
download  
;;  
  
install )  
install  
;;  
  
start )  
start  
;;  
stop )  
stop  
;;  
  
* )  
  
echo “USAGE:$0 {download or install or start or stop}”  
exit  
esac

15.例如123189.zip 132342.zip 等等批量文件,默认unzip直接解压不带自身目录,意思是解压123189.zip完当前目录就是图片,不能创建123189目录下并解压,可以用shell脚本实现

#!/bin/sh  
PATH1=/tmp/images  
PATH2=/usr/www/images  
cd $PATH1  
  
for i in `find  . -name  ”*.zip”|awk  -F.  {print $2} `  
do  
  
mkdir -p   PATH2$i  
  
unzip -o  .$i.zip  -d   PATH2$i  
done  

16.批量上传的脚本
#!/bin/sh  
  
DATE=`date +%Y_%m_%d_%H`  
  
if [ $1 ]  
then  
  for file in $(sed '/^$/d' $1)     //去掉空行  
  do  
    if [ -f $file ]                 //普通文件  
    then  
      res=`scp $file $2:$file`      //上传文件  
      if [ -z $res ]                //上传成功  
      then  
        echo $file >> ${DATE}_upload.log   //上传成功的日志  
      fi  
    elif [ -d $file ]              //目录  
    then  
      res=`scp -r $file $2:$file`  
      if [ -z $res ]  
      then  
        echo $file >> ${DATE}_upload.log  
      fi  
    fi  
  done  
else  
  echo "no file" >> ${DATE}_error.log  
fi  

17.检查端口号是否已启动
#!/bin/bash
n=1
echo "检查xxx服务..."
while true
do
        if test $n -gt 20
        then 
                echo "xxx服务启动失败"
                break
        fi
                
        sleep 5
        n=$(($n+1))
        port=`netstat -antp | grep "0.0.0.0:8080"`
        if [ ${#port} -gt 3 ]; then
                echo "xxx服务已经启动"
                break;
        fi
done

转载于:https://my.oschina.net/direnjie/blog/542229

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值