数据库指定库表中的字段进行备份,并以表格的形式定时发送邮件到指定邮箱 ​
admin
2023-04-24 07:01:30
0

备份数据进行定时邮件发送

mkdir -p /opt/module/shell/
mkdir -p /opt/module/shell/sql/revenue.sql
mkdir -p /opt/module/shell/csv/revenue
#MailTool.jar 放在指定目录下 便于发送邮件使用 可自动生成表格 
vim /opt/module/shell/daily_text.sh
# !/bin/bash
#数据库指定库.表中的字段进行备份,并以表格的形式发送邮件到指定邮箱
#定义变量
dat=`date -d '1 days ago' +%Y-%m`
basepath=/opt/module/shell
sql_revenue=${basepath}/sql/revenue.sql
csv_revenue=${basepath}/csv/revenue/${dat}.csv
filename=`date +%Y-%m`
# html_revenue=${basepath}/html/revenue/${dat}.html
#current=`date -d last-day "+%Y-%m-%d"`
#timeStamp=`date -d "$current" +%s`
# 将current转换为时间戳,精确到毫秒
#currentTimeStamp=$((timeStamp*1000))
#current2=`date "+%Y-%m-%d"`
#time2Stamp=`date -d "$current2" +%s`
# 将current转换为时间戳,精确到毫秒
#current2TimeStamp=$((time2Stamp*1000))

#具体的sql语句 备份某个库里的某个表中的指定字段
sql_revenue_total="select date,tb_card_no,goodsId,outItemSKu,money from itoyo_2018.o_jujibao_record Order by date"

#数据库的登陆ip,端口,用户,密码
mysql=/usr/bin/mysql
host=数据库ip
port=3306
username=数据库指定用户名
password=密码

#将备份的内容导出到定义好的变量文件中
$mysql -h$host -P$port -u$username  -p$password  -e "$sql_revenue_total" > $csv_revenue
total=`$mysql -h$host -P$port -u$username -p$password -e "$sql_revenue_total" | tail -n+2`
echo -e "$total" >> $csv_revenue
sed -i 's/\t/","/g' $csv_revenue
sed -i 's/^/"/g'    $csv_revenue
sed -i 's/$/"/g'    $csv_revenue
sed -i '2,3d' $csv_revenue

#过滤出备份文件中当月的信息到指定文件
cat $csv_revenue | grep -E "(date|$filename)" |sed '$d' > $csv_revenue.bak
#编辑邮件内容及格式
confile=${basepath}/conf.properties
rm -f $confile
    #这里我用的是腾讯企业邮箱,exmail.qq.com  邮箱端口为465
echo  "mailhost=smtp.exmail.qq.com"                                       > $confile
echo  "mailport=465"                                                      >> $confile
echo  "username=邮箱地址"                              >> $confile
echo  "password=邮箱密码"                                                 >> $confile
echo  "from=发件人邮箱"                                  >> $confile
echo  "to=收件人邮箱" >> $confile
echo  "#cc="                                                              >> $confile
echo  "#bcc="                                                             >> $confile
echo  "subject=标题 $dat"                                           >> $confile
echo  "content=

本月数据

#table_revenue#

" >> $confile echo "table_revenue=$csv_revenue.bak" >> $confile echo "file=$csv_revenue.bak" >> $confile #发送邮件 并-mail指定邮件内容 要执行计划任务 必须写绝对路径 /data/tools/jdk1.7.0_67/bin/java -jar /opt/module/shell/MailTool.jar -mail $confile

定时计划任务

#该daily_text.sh脚本必须给执行权限
crontab -e
00 18 30 * * . /opt/module/shell/daily_text.sh

相关内容

热门资讯

伊方透露新一轮谈判先决条件 当地时间12日,伊朗方面发布消息称,一名知情人士透露了伊朗同美国新一轮谈判的五项先决条件 ——即“结...
中东危机下,莫迪将密集访问5国 【环球时报驻巴基斯坦特约记者 黄晓娜】印度外交部11日宣布,印度总理莫迪将于15日开始对阿联酋、荷兰...
“台独”顽固分子沈伯洋参选台北... 【环球时报特约记者 陈立非】台湾今年年底举行“九合一”选举,国民党很早就确定由现任台北市市长蒋万安争...
伊拉克和巴基斯坦据称已分别同伊... 总台记者当地时间5月12日获悉,伊拉克和巴基斯坦已分别同伊朗签订协议,以从海湾地区运输石油和液化天然...
京沪高铁“涨价”,调价背后有何... 昨天(11日),京沪高铁发布公告称,决定对京沪高速线、合蚌高速线动车组列车公布票价进行优化调整,时速...
第三方样品A厂家生产支架样品测... 第三方样品A厂家生产支架样品测试实验报告 一、检测范围 本次检测对象为A厂家生产的XX型医用金属...
伊朗德黑兰地区发生4.6级地震 总台记者获悉,当地时间5月12日23时47分左右,伊朗德黑兰地区发生4.6级地震。震中位于德黑兰省和...
被科威特指控“武装渗透”布比延... 新华社科威特城/德黑兰5月12日电(记者尹炣 陈霄)科威特政府12日指认,伊朗伊斯兰革命卫队多名武装...
酒吧办护士制服派对被指低俗,当... 据媒体报道,5月12日国际护士节,浙江衢州有网友发帖称,当地APK·ELITE CLUB酒吧举办所谓...
珠海冠宇获得发明专利授权:“一... 证券之星消息,根据天眼查APP数据显示珠海冠宇(688772)新获得一项发明专利授权,专利名为“一种...