ibdata1和mysql-bin

问题:磁盘空间报警,经查发现ibdata1和mysql-bin日志占用空间太多(其中ibdata1超过120G,mysql-bin超过80G)

原因:ibdata1是存储格式,在INNODB类型数据状态下,ibdata1用来存储文件的数据和索引,而库名的文件夹里的那些表文件只是结构而已。

innodb存储引擎有两种表空间的管理方式,分别是:

1)共享表空间(可拆分为多个小的表空间文件),这个是我们目前多数数据库使用的方法;

2)独立表空间,每一个表有一个独立的表空间(磁盘文件)

对于两种管理方式,各有优劣,具体如下:

①共享表空间:

优点:可以将表空间分成多个文件存放到不同的磁盘上(表空间文件大小不受表大小的限制,一个表可以分布在不同步的文件上)。

缺点:所有数据和索引存放在一个文件中,则随着数据的增加,将会有一个很大的文件,虽然可以把一个大文件分成多个小文件,但是多个表及索引在表空间中混合存储,这样如果对于一个表做了大量删除操作后表空间中将有大量空隙。对于共享表空间管理的方式下,一旦表空间被分配,就不能再回缩了。当出现临时建索引或是创建一个临时表的操作表空间扩大后,就是删除相关的表也没办法回缩那部分空间了。

②独立表空间:在配置文件(my.cnf)中设置: innodb_file_per_table

特点:每个表都有自已独立的表空间;每个表的数据和索引都会存在自已的表空间中。

优点:表空间对应的磁盘空间可以被收回(Drop table操作自动回收表空间,如果对于删除大量数据后的表可以通过:alter table tbl_name engine=innodb;回缩不用的空间。

缺点:如果单表增加过大,如超过100G,性能也会受到影响。在这种情况下,如果使用共享表空间可以把文件分开,但有同样有一个问题,如果访问的范围过大同样会访问多个文件,一样会比较慢。如果使用独立表空间,可以考虑使用分区表的方法,在一定程度上缓解问题。此外,当启用独立表空间模式时,需要合理调整innodb_open_files参数的设置。

解决:

1)ibdata1数据太大:只能通过dump,导出建库的sql语句,再重建的方法。

2)mysql-bin Log太大:

①手动删除:

删除某个日志:mysql>PURGE MASTER LOGS TO ‘mysql-bin.010′;

删除某天前的日志:mysql>PURGE MASTER LOGS BEFORE ’2010-12-22 13:00:00′;

②在/etc/my.cnf里设置只保存N天的bin-log日志

expire_logs_days = 30 //Binary Log自动删除的天数

ibdata1 mysql_ibdata1 mysql-bin相关推荐

  1. mysql bin.000047_mysql-bin.0000X 日志文件处理

    一.清除文件 [root@jiucool var]# /usr/local/mysql/bin/mysql -u root -p Enter password:  (输入密码) Welcome to ...

  2. mysqlbinlog 查看mysql bin 日志 mysqlbinlog: unknown variable 'default-character-set=utf8'

    mysqlbinlog  mysql-bin.000036 | less 查询包含几个字段的语句: mysqlbinlog mysql-bin.000036| egrep '(201103061000 ...

  3. 修改XAMPP启动mysql报错Port 3306 in use by D:\xampp\mysql\bin\mysqld!

    添加小程序,兑换各种视频教程/数据资源. 参考:https://www.cnblogs.com/syq816/p/7995183.html. 解决办法: 1.cmd-->regedit 打开注册 ...

  4. mysql bin.000047_解决mysql-bin.000001占用超大空间的问题

    相关资源下载 QQ截图20160201104016.jpg (50.79 KB, 下载次数: 303) 2016-2-1 10:39 上传 最近几个月服务器总是频繁当机,导致比尔盖子的可用性得不到保证 ...

  5. mysql bin的过期时间_Mysql设置binlog过期时间并自动删除

    问题: Mysql数据库由于业务原因,数据量增长迅速,binlog日志会增加较多,占用大部分磁盘空间. 解决方案: 出于节约空间考虑,可进行删除多余binary日志,并设置定期删除操作. 1.查看bi ...

  6. mysql bin日志备份_mysql之binlog日志备份还原

    实例: 在mysql有时执行了错误的update或者delete时导致大量数据错误恢复的办法.执行时没有开启事务,也没有对数据进行.这时就需要使用到sqlbinlog工具. sqlbinlog需要开启 ...

  7. mysql bin.000013_"mysql-bin.0000*"占用空间问题及删除

    最近几个月服务器总是频繁当机,导致比尔盖子的可用性得不到保证.但说也奇怪,当机的时候,服务器可以正常连接,Nginx也看似正常,但就是PHP-FPM失去响应.后来无意中df -h一下,发现: root ...

  8. mysql bin 分析_mysql bin log 分析

    1.mysql现状 mysql> show binary  logs; +------------------+-----------+ | Log_name         | File_si ...

  9. ibdata1导致mysql打不开_关于mysql:mysql文件ibdata1增长过大导致服务器无法写的问题...

    背景 由云上的一个服务返回异样触发的,因为最近服务代码未有改变,之前运行失常,所以首先到服务所在的服务器查看服务的状态: [root@manager-01 ~]# systemctl status J ...

最新文章

  1. CKPT进程工作机制
  2. ASP.NET MVC中使用FluentValidation验证实体
  3. MVC3+Entity Framework 实现投票系统(一)
  4. 分数怎么化成带分数_小升初数学总复习第三个基础模块:分数的认识
  5. (原创)我也玩万能表单(自定义表单)(一)
  6. JDK1.8 IdentityHashMap
  7. c语言 syn扫描,syn flooder*** (C语言)
  8. python单词必背打印_为什么Python要用print打印这个单词?
  9. java common-lang_commons-lang.jar下载
  10. 冬季华丽回潮 试着搭配毛茸茸皮草
  11. 几种不同的方式用Python连接数据库
  12. 做社交电商,你还没有用小程序?
  13. 送一台高配电脑,吃鸡贼爽!
  14. week11作业——C - 必做题11-3
  15. 了解ZigBee以及硬件环境
  16. Golang + Gin + cytocsape.js + neo4j
  17. R Z-score结果
  18. 验证码图片显示不出文字
  19. python+ddt
  20. 如何用水经注万能地图下载器进行投影转换

热门文章

  1. 一起来玩AZURE SQL(一)AZURE SQL 介绍
  2. MFC开发IM-第二十三篇、C++中 UTF-8转成Unicode
  3. 完全使用CSS制作下拉菜单
  4. 小米12 Ultra延期发布:或与小米MIX Fold 2折叠屏旗舰同台亮相
  5. 春运返程高峰来了 大数据看返京热力
  6. 不是明年年初?苹果明年三季度才会推出AirPods Pro 2
  7. 郭明錤:因设计复杂 苹果可能推迟至明年底生产AR/VR头盔
  8. 蚂蚁森林:国庆节前组织网友去阿拉善等三地参与秋季验收
  9. 外媒:麦当劳、星巴克、必胜客开始在萨尔瓦多接受比特币支付
  10. 中国三大运营商发声!要求纽交所复议退市决定