晋中住房与城乡建设厅网站,wordpress链接失效,建筑公司注册条件,网上下载的网页模板怎么用今天发现网站不能正常访问#xff0c;于是登陆服务器查找问题。
机智的我随手用命令#xff1a;df -l 发现 硬盘爆满了#xff0c;于是就知道问题所在了。
Filesystem 1K-blocks Used Available Use% Mounted on/dev/xvda1 20641404 16963004 16929876 10…今天发现网站不能正常访问于是登陆服务器查找问题。
机智的我随手用命令df -l 发现 硬盘爆满了于是就知道问题所在了。
Filesystem 1K-blocks Used Available Use% Mounted on/dev/xvda1 20641404 16963004 16929876 100% /
tmpfs 960368 0 960368 0% /dev/shm/dev/xvdb1 51599192 4845536 44132564 10% /home/sam/share然后通过命令 du -sh * 一路检查发现mysql的日志文件占据了大部分空间 , 整整27G于是现在的任务就是清理mysql的日志文件主要是清理.log文件和mysql-bin.00000X二进制日志文件
一、删除mysql日志文件
第一步登陆进入mysql并使用 show binary logs; 查看日志文件。
mysql -u root -pmysql show binary logs; ±-----------------±----------| Log_name | File_size |±-----------------±---------- | mysql-bin.000001 | 234592362 | | mysql-bin.000002 | 425234342 | | mysql-bin.000003 | 425345345 | | mysql-bin.000004 | 234234222 | | mysql-bin.000005 | 425994852 | ±-----------------±----------1 row in set (0.00 sec) 第二步查看正在使用的日志文件show master status;
mysql show master status; ±-----------------±----------±-------------±-----------------±------------------ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | ±-----------------±----------±-------------±-----------------±------------------ | mysql-bin.000005 | 425994852 | | | | ±-----------------±----------±-------------±-----------------±------------------1 row in set (0.00 sec)
当前正在使用的日志文件是mysql-bin.000005那么删除日志文件的时候应该排除掉该文件。 删除日志文件的命令purge binary logs to ‘mysql-bin.000005’;
mysql purge binary logs to ‘mysql-bin.000005’; 删除除mysql-bin.000005以外的日志文件。
删除后就能释放大部分空间。
二、mysql 定时清理日志文件
如果每次等到发现空间不足的时候才去手动删除日志文件这种方式是很不理想的。
那么我们就需要设置mysql让它能自动清理日志文件。
编辑mysql的配置文件设置expire_logs_daysmysql定时删除日志文件
[rootsam ~]# vim /etc/my.cnf 在my.cnf中添加或修改expire_logs_days的值 (这里设置的自动删除时间为10天, 默认为0不自动删除)
expire_logs_days10 修改后重启mysql就会生效。
但是在生产环境中重启mysql数据库往往会付出很高的代价。
于是可以在不重启mysql的情况下修改expire_logs_days值
如下
登陆到mysql并输入一下命令。
mysql show variables like ‘%log%’;mysql set global expire_logs_days 10; 设置完后可以通过 show variables like ‘%log%’; 看到expire_logs_days的值已被修改成10。
注意通过这种方式设置expire_logs_days虽然不需要重启mysql即可生效但是该方式在重启mysql之后值会被恢复。
于是建议通过mysql命令设置expire_logs_days的同时也修改/etc/my.cnf下的expire_logs_days10配置这样在下次重启mysql的时候expire_logs_days也一样是10