实际开发环境中,前端程序需要在给定时间段内,将数据更新/插入到MySQL指定的库表中。随着数据量的增多,基础库表基数的增长,每更新一次都会有5s左右的卡顿。 改进方案一:批量更新,累计数10条或者100条进行一次更新入库操作; 改进方案二:将当前日期前1个月之前的数据进行备份操作,并删除当前库表中1个月前的数据。经测定,该方法一定程度提高了访问效率。根因:基础表基数少,查询效率相对提高。
使用 mysqldump,设定周期30天。
crontab设定。
[root@mysql_bak]# cat mysql_bak.sh#!/bin/sh#DATABASE INFODB_NAME="ppdb"DB_USER="root"DB_PASS="passWord"DISPOSE_TABLE="dispose_ticles"RST_TABLE="match_rst"DB_ip=100.55.1.129BIN_DIR="/usr/bin"BAK_DIR="/home/mysql_bak/data"DATE=`date +%Y%m%d_%H%M%S`#mkdir -p $BAK_DIR#备份包 形成压缩包$BIN_DIR/mysqldump $DB_NAME $DISPOSE_TABLE > $BAK_DIR/$DISPOSE_TABLE.dump_$DATE.sql$BIN_DIR/mysqldump $DB_NAME $DISPOSE_TABLE | gzip > $BAK_DIR/$DISPOSE_TABLE.dump_$DATE.sql.gz$BIN_DIR/mysqldump $DB_NAME $RST_TABLE > $BAK_DIR/$RST_TABLE.dump_$DATE.sql$BIN_DIR/mysqldump $DB_NAME $RST_TABLE | gzip > $BAK_DIR/$RST_TABLE.dump_$DATE.sql.gz#定期删除60天的备份包find $BAK_DIR -name "name_*.sql.gz" -type f -mtime +60 -exec rm {} /; > /dev/null 2>&1#30天前的指定库表数据删除操作 (当前时间减去30天)delete_date=`date --date='30 day ago' +%Y-%m-%d`echo "delete_date=$delete_date"#删除rst表信息rst_sql="delete from $RST_TABLE where update_time <= $delete_date order by update_time;";echo "rst_sql=$rst_sql"#ret=$(mysql -u $DB_USER -h ${DB_IP} -p${DB_PASS} $DB_NAME -e "$sql");ret=$(mysql -h${DB_IP} $DB_NAME -e "$rst_sql");echo $ret#删除dispose表信息dispose_sql="delete from $DISPOSE_TABLE where judge_time <= $delete_date order by judge_time;";echo "dispose_sql=$dispose_sql"ret=$(mysql -h${DB_IP} $DB_NAME -e "$dispose_sql");echo $ret重启crontab服务 service crond restart
20170304 21:10 于家中床前
作者:铭毅天下 转载请标明出处,原文地址: http://blog.csdn.net/laoyang360/article/details/60347828 如果感觉本文对您有帮助,请点击‘顶’支持一下,您的支持是我坚持写作最大的动力,谢谢!
新闻热点
疑难解答