> 데이터 베이스 > MySQL 튜토리얼 > MySQL Innodb独立表空间的配置

MySQL Innodb独立表空间的配置

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-06-07 17:29:42
원래의
1065명이 탐색했습니다.

mysql innodb的独立表空间和共享表空间,独立表空间是把每个表的数据和表文件放在一起。共享表空间是所有库的数据都放在ibdate1文

没经验真可怕

项目是去年9月份开始运行的,现在数据库中的那些统计表非常庞大,并且时不时领导要你在这些统计表中加个字段什么的,哇,那真是头疼,虽然每个月项目升级我们都会删数据,,可一个月那些统计表的数据也达到千万啊,蛋疼!周五项目升级,就卡在这些大数据上面去了,因为要加那些字段,到后面实在是慢的可以,干脆全部数据干掉,不管了!

将数据库配置成独立表空间:

1.查看一下:

mysql> show variables like '%per_table%'; 
+-----------------------+-------+ 
| Variable_name        | Value | 
+-----------------------+-------+ 
| innodb_file_per_table | OFF  | 
+-----------------------+-------+ 
1 row in set (0.00 sec) 

说明:OFF代表mysql是共享表空间,也就是所有库的数据都存放在一个ibdate1文件中

rpm安装mysql的目录结构

数据库目录:/var/lib/mysql/

配置文件:/usr/share/mysql(mysql.server命令及配置文件)

相关命令:/usr/bin(mysqladmin、mysqldump等命令)(*mysql的一种安全启动方式:/usr/bin/mysqld_safe  --user=root &)

启动脚本:/etc/rc.d/init.d/

2.停掉mysql服务器:

以rpm方式安装的mysql
[root@localhost ~]# /etc/rc.d/init.d/mysqld stop
[root@localhost ~]#/etc/init.d/mysqld stop

3.修改my.cnf文件:在my.cnf文件mysqld后面加上下面这句话:

因为是rpm安装,所以找不到,从mysql配置文件目录中随便复制个my-*.cnf文件到etc目录下,改成my.cnf

innodb-file-per-table=1

4.启动mysql

[root@localhost ~]#service mysql start

[root@localhost ~]#/etc/init.d/mysqld start

5.再查看一下

mysql> show variables like '%per_table%'; 
+-----------------------+-------+ 
| Variable_name        | Value | 
+-----------------------+-------+ 
| innodb_file_per_table | ON  | 
+-----------------------+-------+ 
1 row in set (0.00 sec) 

总结: mysql innodb的独立表空间和共享表空间,独立表空间是把每个表的数据和表文件放在一起。共享表空间是所有库的数据都放在ibdate1文件中,网上说这个文件你删除数据,不会收缩,也就是说如果你这个文件有40G,你删了表数据,这个文件还是40G,这就很恐怖了,所以我们换成独立表空间。还有就是虽然说独立,但个人觉得还真不是很彻底,我把那些文件复制到另一个库里面,只有表,没有数据,所以不彻底啊!

linux

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿