日常工作中的shell脚本

由于nginx开启了ssl证书,从http升级到https,所以要把网站的html文件中的http替换成https,写了个小脚本,代码如下


#!/bin/bash  #shell声明
dir_num=`find /test/ -name "*.html"` #获取test目录下所有的html文件
time=`date`    #定义时间变量
echo "开始 $time" >> /tmp/shell/excute.txt  #脚本开始运行,将开始运行的时间 追加到excute.txt文件中
for i in $dir_num    #for循环每一个html文件
do #循环开始
   cat $i |grep "<base href=\"http://www.test.com/\" />" >> /dev/null #查找出该文件中是否有这一行
   if [ $? == 0 ];then  #如果有这一行$?的返回值是0,没有返回1或者其他值,if判断是否为0
      sed -i 's/<base href=\"http:\/\/www.test.com\/\" \/>/<base href=\"https:\/\/www.test.com\/\" \/>/' $i
     #sed替换将http替换成https
       echo " $i replace success..." >> /root/test/replace.txt   #追加替换成功消息到replcae.txt文件中
   fi #判断结束
done  #循环结束 
exit_time=`date`
echo "运行结束 $exit_time" >> /root/shell/excute.txt #脚本运行结束,将结束时间追加到excute.txt文件中(别调用$time,否则结束时间和开始时间是一样的,因为time变量从脚本运行开始就已经存入值了)

其实一条find命令就可以搞定的,但是文件数量太多,怕出错,而且是在线上跑,所以就写了这个脚本,可以计算时常和统计修改文件的数量,find如果要一条命令的话应该是这样的:
find /test/ -name "*.html" -exec   sed -i 's/<base href=\"http:\/\/www.test.com\/\" \/>/<base href=\"https:\/\/www.test.com\/\" \/>/'  {} \;

猜你喜欢

转载自blog.csdn.net/wojiuwangla/article/details/80416054