洛杉矶MC机房 高速低价18元起

DIYVM

记录一键shell脚本清理MySQL碎片文件的脚本

提示:如果官网是英文页面,建议使用谷歌浏览器能同步翻译页面。点击下载【谷歌浏览器最新绿色便携版】
注意:部分文章发布时间较长,可能存在未知因素,购买时建议在本站搜索商家名称,先充分了解商家动态。
交流:唯一投稿邮箱:hostvps@88.com。

肯定很多网友和贝壳一样会发现网站在使用MYSQL数据库的时候会发现有些表会加载很多的碎片文件,其实这些文件都是通过缓存的模式慢慢记录下来的,随着时间的积累使得无用的碎片文章增加充实数据库表格,数据库实际上有用的数据也不多,但是碎片可能就有几M。

遇到这样的问题我们一般先去找对应程序可能是否有优化数据表的办法,如果没有的话,我们就要自己来解决问题。当然在解决之前我们需要先备份数据库,以免出现一些问题。这里贝壳也在寻找一些解决MYSQL碎片的办法,这里看到有一篇工具记录的shell脚本处理碎片的,这里先记录下来。

#!/bin/sh
mysql_user=root
mysql_pass=123123
time_log=/opt/time
databases=/opt/databases
/usr/bin/mysql -u$mysql_user -p$mysql_pass -e “show databases” | grep -v “Database” > /opt/databases
sed -i “s/information_schema//” $databases
sed -i “s/mysql//” $databases
sed -i “s/test//” $databases
databases1=$(cat /opt/databases)
for i in $databases1
do
echo “database $i starting”
tables=$(/usr/bin/mysql $i -u$mysql_user -p$mysql_pass -e “show tables” | grep -v “Tables” > /opt/$i)
tablelist=$(cat /opt/$i)
echo “optimize database $i starting” >> $time_log
echo “$i start at $(date +[%Y/%m/%d/%H:%M:%S])” >> $time_log
for list in $tablelist
do
echo $list
/usr/bin/mysql $i -u$mysql_user -p$mysql_pass -e “optimize table $list”
done
echo “$i end at $(date +[%Y/%m/%d/%H:%M:%S])” >> $time_log
echo >> $time_log
done

我们可以看到在脚本前面可以设置数据库的账户和密码,然后对应执行,这里我没有测试,而是记录下来,以后有时间去测试是否可行。文章参考自:https://blog.51cto.com/11910656/1839091,如果我们自己要测试的话一定要先备份数据库。

About 贝壳

【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。

 收藏 (0) 打赏

您可以选择一种方式赞助本站

支付宝扫一扫赞助

微信钱包扫描赞助

本文链接:贝壳主机网 » 记录一键shell脚本清理MySQL碎片文件的脚本

分享到: 生成海报
香港/美国/国内高速VPS
切换注册

登录

忘记密码 ?

切换登录

注册

我们将发送一封验证邮件至你的邮箱, 请正确填写以完成账号注册和激活