博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
shell脚本常规技巧
阅读量:6696 次
发布时间:2019-06-25

本文共 11768 字,大约阅读时间需要 39 分钟。

邮件相关

发送邮件:

#!/usr/bin/pythonimport sys;import smtplib;from email.MIMEText import MIMETextmail_host = sys.argv[1]mail_user = sys.argv[2]mail_pass = sys.argv[3]mail_from = sys.argv[4]mail_to = sys.argv[5]mail_to_list = mail_to.split(';')mail_subject = sys.argv[6]mail_content = sys.argv[7]msg = MIMEText(mail_content, _subtype = 'html', _charset = 'utf-8')msg['From'] = mail_frommsg['Subject'] = mail_subjectmsg['To'] = mail_tomsg['MIME-Version'] = "1.0"msg['Content-Type'] = "text/html"try:    client = smtplib.SMTP()    client.connect(mail_host)    client.login(mail_user, mail_pass)    client.sendmail(mail_from, mail_to_list, msg.as_string())except:    print "something error..."

用法:python ./send_mail.py $MAIL_HOST $MAIL_USER $MAIL_PASS $MAIL_FROM $MAIL_TO "$MAIL_SUBJECT" "$MAIL_CONTENT"

带附件版本:

#!/usr/bin/pythonimport osimport sys;import smtplib;from email.MIMEText import MIMETextfrom email.MIMEMultipart import MIMEMultipartmail_host = sys.argv[1]mail_user = sys.argv[2]mail_pass = sys.argv[3]mail_from = sys.argv[4]mail_to = sys.argv[5]mail_to_list = mail_to.split(';')mail_subject = sys.argv[6]mail_content = sys.argv[7]mail_attach  = '' if len(sys.argv) > 8:        mail_attach  = sys.argv[8]        #print mail_attachmsg = MIMEMultipart()# body = MIMEText(mail_content, _subtype = 'html', _charset = 'utf-8')msg.attach(body)#if os.path.isfile(mail_attach):        att = MIMEText(open(mail_attach,'rb').read(),'base64','gb2312')        att["Content-Type"] = 'application/octet-stream'        att["Content-Disposition"] = 'attachment;filename="' + os.path.basename(mail_attach) +'"'        msg.attach(att)msg['From'] = mail_frommsg['Subject'] = mail_subjectmsg['To'] = mail_tomsg['MIME-Version'] = "1.0"msg['Content-Type'] = "text/html"try:    client = smtplib.SMTP()    client.connect(mail_host)    client.login(mail_user, mail_pass)    client.sendmail(mail_from, mail_to_list, msg.as_string())except:    print "something error..."

发送脚本:

#! /bin/bashexport LC_ALL="en_US.UTF-8"if [ $# -lt 1 ]then        echo "Usage: $0 process_name"        exit -1ficd $(dirname $0)LOCALIP=`/sbin/ifconfig eth0 | grep "inet addr" | cut -f 2 -d ":" | cut -f 1 -d " "` HOSTNAME=`hostname`gday=`date +"%x %X"`MAIL_HOST="smtp.exmail.qq.com"MAIL_USER="op@test.com"MAIL_PASS="optest"MAIL_FROM="op@test.com"MAIL_TO="chenzhj@test.com"MAIL_SUBJECT="$HOSTNAME[$LOCALIP] $1 $gday"MAIL_CONTENT=""echo "$MAIL_SUBJECT"#echo "python ./send_mail.py" $MAIL_HOST $MAIL_USER $MAIL_PASS $MAIL_FROM $MAIL_TO "$MAIL_SUBJECT" "$MAIL_CONTENT"python ./send_mail.py $MAIL_HOST $MAIL_USER $MAIL_PASS $MAIL_FROM $MAIL_TO "$MAIL_SUBJECT" "$MAIL_CONTENT"

 

生成表格邮件:

#!/bin/shTIME=`date +%Y-%m-%d -d "1 days ago"`echo ""echo ""echo ""echo "
"#echo "
"echo ""echo " "echo "

今日半价mysql数据统计

"echo '
'echo "
"echo "
"echo "
"echo "
"echo "
"echo "
"echo "
"echo "
"echo "
"YESTERDAY=`date +%Y-%m-%d -d'-1 days'`cat ../data/static.$YESTERDAY | while read linedo echo $line | awk ' { print "\t\t\t
\n\t\t\t\t
" for (i=1; i<=6; i++) { print "\t\t\t\t
" } print "\t\t\t
" }'doneecho "
DateTime 统计站点 总商品数 在架商品数 下架商品数 增量总数 在架的增量数
'$TIME' "$i"
"echo " "echo " "

awk

1、传递外部shell参数(-v)、同时处理多文件(getline) 示例:

#!/bin/bashif [ $# -ne 2 ]then        echo "Usage: $0  local_log  bc_log"        exitfiawk -v bc_log=$2 'BEGIN{
SRC=0; TAR=0;/*print "bc_log:",bc_log;*/}{ SRC=$1; close(bc_log); while(getline TAR < bc_log ) { if(TAR>SRC) { print SRC; break; } if(TAR==SRC) { break; } } }

字典过滤

#! /bin/gawk -f BEGIN{         total=0;        while( getline< "/home/hadoop/zhenjing/solr/2.data" >0)         {                  dict[$1] = 1;                total++;        }        #print total;}{        if( $1 in dict ){            next        }        print $1}END{}

分析日志,计算平均时间

#! /bin/gawk -fSTART {    sum_time["item.get"] = 0;    sum_count["item.get"] = 0;}{    tmp = substr($0, index($0, "method"));    split(tmp, arr, "\"");    method = arr[3];    if(method == "") {        next;    }    tmp = substr($0, index($0, "time:"));    split(tmp, arr, ":");    time = arr[2];    # print method, time;    if(time > 0){        sum_time[method] = sum_time[method] + time;        sum_count[method] = sum_count[method] + 1;    }}END {    for(method in sum_time){        if(sum_count[method] > 0){            print method " = " sum_time[method] / sum_count[method];        }    }}

awk统计tomcat android机型:

#! /bin/gawk -f# tail  /tmp/temai.txt | grep Android | cut -d" " -f 18-23 | cut -d')' -f1BEGIN{        FS = "; ";}{        if( $1 in dict_os ){                dict_os[$1] = dict_os[$1] + 1;        } else {                dict_os[$1] = 1;        }        if( $3 in dict_jixing ){                dict_jixing[$3] = dict_jixing[$3] + 1;        } else {                dict_jixing[$3] = 1;        }}END {    for(os in dict_os){            print  dict_os[os] " "  os;    }    for(jx in dict_jixing){            print  dict_jixing[jx] " " jx;

awk平均分拆文件:

awk '{hash=int(NR % 10 ); print $0 >> "outfile_tmp_"hash }' weiboid.txt

时间相关

基于时间的循环:date命令

typeset readonly START_DATE=$(date --date="$1" +%Y%m%d);

for ((CUR_DATE=START_DATE; CUR_DATE<=END_DATE; CUR_DATE=$(date --date="${CUR_DATE} 1 days" +%Y%m%d) ))

Linux时钟分为系统时钟(System Clock)和硬件(Real Time Clock,简称RTC)时钟。系统时钟是指当前Linux Kernel中的时钟,而硬件时钟则是主板上由电池供电的时钟,这个硬件时钟可以在BIOS中进行设置。当Linux启动时,硬件时钟会去读取系统时钟的设置,然后系统时钟就会独立于硬件运作。Linux中的所有命令(包括函数)都是采用的系统时钟设置。在Linux中,用于时钟查看和设置的命令主要有date、hwclock和clock。其中,clock和hwclock用法相近。

date 010318242008.30(月日时分年.秒)

date 010318242008(月日时分年)

date -s 20080103

date -s 18:24

clock -w

hwclock --set --date="07/07/06 10:19" (月/日/年 时:分:秒)

硬件时钟与系统时钟同步:# hwclock --hctosys(hc代表硬件时间,sys代表系统时间)或者# clock --hctosys

系统时钟和硬件时钟同步:# hwclock --systohc或者# clock --systohc

xargs

echo "FILE.txt" | grep -v '^$' \

| xargs -L 1 -I {} find . -maxdepth 1 -type f -name "{}" \
| sort | xargs -L 1 basename | xargs md5sum

 somecommand | xargs -s 50000 echo | xargs -I '{}' -s 100000 rm '{}'

 

LOCALIP=`/sbin/ifconfig eth1 | grep "inet addr" | cut -f 2 -d ":" | cut -f 1 -d " "`

LOCALIP="$(/sbin/ifconfig eth1 | sed -n '/inet addr/s/.*inet addr:\([0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\).*/\1/gp')"

LOCAL_IP="$(/sbin/ifconfig | sed -n 's/^.*inet addr\:\([[:digit:]\.]\{7,14\}\).*$/\1/gp' | head -1)";

 array 相关

#! /bin/bashcolors=(red green blue)element_count=${#colors[@]}# Special syntax to extract number of elements in array.#     element_count=${#colors[*]} works also.##  The "@" variable allows word splitting within quotes#+ (extracts variables separated by whitespace).##  This corresponds to the behavior of "$@" and "$*"#+ in positional parameters. # array loop:# Way 1:index=0while [ "$index" -lt "$element_count" ]do    # List all the elements in the array.  echo ${colors[$index]}  #    ${colors[index]} also works because it's within ${ ... } brackets.  let "index = $index + 1"  # Or:  #    ((index++))done# Way 2:# Each array element listed on a separate line.# If this is not desired, use  echo -n "${colors[$index]} "# Doing it with a "for" loop instead:for i in "${colors[@]}"do    echo "$i"doneecho echo "For test:"# Usage: ArrayCheckExist "$value" "${arr[@]}"function ArrayCheckExist{    value=$1    i=0    for str in "$@"    do        ((i++))        if [ $i -eq 1 ]; then  # first parameter is checked value            continue        fi        if [[ "$value" == "$str" ]]; then            #echo "$value" "$str"            return 1   #  exist        fi    done    return 0}dirs=()  # empty arrayindex=0while read ip dir info tomcat portdo    if [[ $ip == "#" || -z $port ]]    then        continue    fi    # index=`echo -n $tomcat |md5sum|cut -d ' ' -f1`   # get string md5sum    ArrayCheckExist "$tomcat" "${dirs[@]}"    if [ $? -eq 0 ]; then        dirs[ ${#dirs[@]} ]=$tomcat    fidone < ./di.conffor i in "${dirs[@]}"do    echo "$i"doneecho "Array function test:"ArrayCheckExist "${dirs[@]}"return_val=$?if [[ $return_val -gt 0 ]]; then     echo "${dirs[0]} Exist."fiArrayCheckExist "test" "${dirs[@]}"if [ $? -gt 0 ]; then     echo "test Exist."fiArrayCheckExist "test"if [ $? -gt 0 ]; then     echo "test Exist."fiArrayCheckExist "/usr/local/webserver/di/tomcat-di2"  "${dirs[@]}"if [ $? -gt 0 ]; then     echo "Exist."fi

统计脚本

solr:

cat shards | awk -F "QTime=" '{sum+=$2; cnt++; if($2> 500) slow++;} END{print cnt; print slow++; print sum/cnt; print slow/cnt}'

dc:

cat dc.log | grep -o "spending time:[0-9]\+" | awk -F: '{sum+= $2; cnt++; if($2 > 500) slow++ } END{print cnt; print slow; print sum/cnt; print slow/cnt}'

rts:

cat dc.log | grep -o "search rts used: [0-9]\+" | awk -F: '{sum+= $2; cnt++; if($2 > 20) slow++ } END{print cnt; print slow; print sum/cnt; print slow/cnt}'

searchserver:

cat searchserver.log.2013-07-08.log | grep -o "totalTime=[0-9]\+" | awk -F= '{sum+= $2; cnt++; if($2 > 500) slow++ } END{print cnt; print slow; print sum/cnt; print slow/cnt}'

appserver:

cat userTime-appserver-2013-07-25_* | awk '{sum+= $5; cnt++; if($5 > 500) slow++ } END{print cnt; print slow; print sum/cnt; print slow/cnt}'

solr相关

solr core数据对比

#! /bin/bashif [ $# -lt 3 ]then    echo "Usage $0 query_file solr1 solr2 [out_file]"    exit -1fiOUT_FILE="/tmp/query"if [ $# -gt 3 ]thenOUT_FILE=$4fiwhile read query do    query=`echo $query | sed 's/wt=javabin/wt=json/g'`    # KEY: set wt=json for solr request.    wget "http://$2/solr/C2C_TAOBAO_0/select/?$query" -q  -O ${OUT_FILE}_0    wget "http://$3/solr/C2C_TAOBAO_0/select/?$query" -q  -O ${OUT_FILE}_1    # del QTime from solr "json" response    sed  -i 's/"QTime":[0-9]\+,//g'  ${OUT_FILE}_0    sed  -i 's/"QTime":[0-9]\+,//g'  ${OUT_FILE}_1    cmp  ${OUT_FILE}_0  ${OUT_FILE}_1 > /dev/null    if [ "$?" != 0 ]    then        echo "$query"    fidone < $1

solr查询参数提取

#! /bin/gawk -f/select params=\{/,/\}/ {        if( match($0, /\{[^\}]+\}/, str)){                pos = length(str[0]) - 2                print substr(str[0], 2, pos)        } }

获取淘宝真实链接:

#! /bin/bashif [ $# -lt 1 ]then        echo "Usage: $0 url"        exit 1fiexport LC_ALL=en_US.UTF-8 OUT=logwget $1 -o $OUT -O tmpreq_arr=`grep "Location:" $OUT | grep "s.click.taobao.com" | cut -d" " -f 2`taobao_req=`echo $req_arr | cut -d" " -f 2`refer_req=`echo $req_arr | cut -d" " -f 3`ext_key=`echo $refer_req | awk -F"et%3D" '{print $2}' | sed -e 's/%25/%/g'`#echo "$taobao_req&ref=&et=$ext_key"#echo "curl  \"$taobao_req&ref=&et=$ext_key\" -I -e \"$refer_req\""#curl -s  "$taobao_req&ref=&et=$ext_key" -I -e "$refer_req" curl -s "$taobao_req&ref=&et=$ext_key" -I -e "$refer_req" | grep "^Location" | cut -d" " -f 2

 日常数据备份脚本

#! /bin/bashexport LC_ALL=en_US.UTF-8echo `date`cd `dirname $0`pwdecho `date +%s`# back taday dataDATE=`date +%Y-%m-%d`SQL_FILE="jira_$DATE.sql"/opt/lampp/bin/mysqldump --default-character-set=utf8 -h 10.1.22.40 -u jira -pkoudai123  jira > $SQL_FILEr1=`ls -ld $SQL_FILE | awk '{print int($5/1024)}'`DATA_FILE="jira_home_$DATE.tar.gz"tar czf  $DATA_FILE  /data/server/jira-homer2=`ls -ld $DATA_FILE | awk '{print int($5/1024)}'`echo $r1echo $r2echo `date +%s`if [[ $r1 -gt 1024 && $r2 -gt 1024 ]]then# del old dataDELDAY=`date --date='-15 day' +%Y-%m-%d`echo "del data : $DELDAY"rm *$DELDAY*fiecho "`date +%s` FINISH !"

 操作文件

#! /bin/bashif [ $# -lt 3 ]then    echo "Usage $0 in_file out_file num"    exit -1fiINPUT=$1OUTPUT=$2num=100if [ $# -gt 2 ]then    num=$3fifor i in `seq 0 $num`do    echo "$i"    awk -F ^ -v prefix=$i '{ if(NF > 10) print prefix$0}' ${INPUT} >> ${OUTPUT}done

 

 

转载地址:http://ilpoo.baihongyu.com/

你可能感兴趣的文章
用户端传入参数问题
查看>>
Vue 踩坑之旅
查看>>
一个程序员的自白(危机可导)
查看>>
JSP页面输出的几种方式:
查看>>
svn服务器
查看>>
Ubuntu 18.04 手动编译安装 ffmpeg
查看>>
DotNet 学习笔记 Servers
查看>>
实现who
查看>>
EL表达式取值中文再发送请求时会乱码
查看>>
python3全栈学习笔记-01
查看>>
最小生成树--Prim算法和Kruskal算法
查看>>
《统一沟通-微软-实战》-3-部署-Exchange 2010-1-先决条件
查看>>
FireEye:2012年下半年高级威胁分析报告
查看>>
iOS开发那些事--创建基于故事板的iOS 6的HelloWorld
查看>>
业界重磅新书《UNIX/Linux网络日志分析与流量监控》首发
查看>>
iTunes“解决方案”发展历程及研究(上)
查看>>
为什么在中国“公有云”落地那么难?
查看>>
Provisioning Services 7.8 入门系列教程之十一 通过版本控制自动更新虚拟磁盘
查看>>
Jconsole查看Weblogic自定义MBean
查看>>
扫盲:php session缓存至memcached中的方法
查看>>