接上篇Mysql性能优化二html
若是一个表的记录数太多了,好比上千万条,并且须要常常检索,那么咱们就有必要化整为零了。若是我拆成100个表,那么每一个表只有10万条记录。固然这须要数据在逻辑上能够划分。一个好的划分依据,有利于程序的简单实现,也能够充分利用水平分表的优点。好比系统界面上只提供按月查询的功能,那么把表按月拆分红12个,每一个查询只查询一个表就够了。若是非要按照地域来分,即便把表拆的再小,查询仍是要联合全部表来查,还不如不拆了。因此一个好的拆分依据是 最重要的。关键字:UNION
例:mysql
有些表记录数并很少,可能也就二、3万条,可是字段却很长,表占用空间很大,检索表时须要执行大量I/O,严重下降了性能。这个时候须要把大的字段拆分到另外一个表,而且该表与原表是一对一的关系。 (JOIN) sql
【试题内容】、【答案信息】两个表,最初是做为几个字段添加到【试题信息】里的,能够看到试题内容和答案这两个字段很长,在表里有3万记录时,表已经占 了1G的空间,在列试题列表时很是慢。通过分析,发现系统不少时候是根据【册】、【单元】、类型、类别、难易程度等查询条件,分页显示试题详细内容。而每 次检索都是这几个表作join,每次要扫描一遍1G的表。咱们彻底能够把内容和答案拆分红另外一个表,只有显示详细内容的时候才读这个大表,由此 就产生了【试题内容】、【答案信息】两个表。 数据库
选择字段的通常原则是保小不保大,能用占用字节小的字段就不用大字段。好比主键, 建议使用自增类型,这样省空间,空间就是效率!按4个字节和按32个字节定位一条记录,谁快谁慢太明显了。涉及到几个表作join时,效果就更明显了。
建议使用一个不含业务逻辑的id作主角如s1001。例:windows
int 4 bigint 8 mediumint smallint 2 tinyint 1 md5 char(32) id :整数 tinyint samllint int bigint student表 id stuno stuname adress 1 s1001 小民 深圳
数据库只存储路径。图片和文件存放在文件系统,甚至单独放在一台服务器(图床 / 视频服务器 ).性能优化
最重要的参数就是内存,咱们主要用的innodb引擎,因此下面两个参数调的很大服务器
innodb_additional_mem_pool_size = 64M
innodb_buffer_pool_size =1G
对于myisam,须要调整key_buffer_size,固然调整参数仍是要看状态,用show status语句能够看到当前状态,以决定改调整哪些参数
在my.ini修改端口3306,默认存储引擎和最大链接数post
在my.ini中.
port=3306 [有两个地方修改]
default-storage-engine=INNODB
max_connections=100
若是你的机器内存超过4G,那么毋庸置疑应当采用64位操做系统和64位mysql 5.5.19 or mysql5.6
读写分离
若是数据库压力很大,一台机器支撑不了,那么能够用mysql复制实现多台机器同步,将数据库的压力分散。 性能
Master
Slave1
Slave2
Slave3
主库master用来写入,slave1—slave3都用来作select,每一个数据库分担的压力小了不少。
要实现这种方式,须要程序特别设计,写都操做master,读都操做slave,给程序开发带来了额外负担。固然目前已经有中间件来实现这个代理,对程 序来读写哪些数据库是透明的。官方有个mysql-proxy,可是仍是alpha版本的。新浪有个amobe for mysql,也可达到这个目的,结构以下 优化
项目实际需求,请完成定时备份某个数据库,或者定时备份数据库的某些表的操做
windows 下每隔1小时,备份一次数据newsdb
windows 天天晚上2:00 备份 newsdb 下 某一张表
cmd> mysqldump –u root –p密码 数据库名 > 把数据库放入到某个目录
案例,备份 mydb 库的全部表
进入mysqldump所在的目录
cmd> mysqldump –u root –phsp shop> d:/shop.log [把shop数据库的全部表所有导出]
cmd> mysqldump –u root –phsp shop temusers emp > d:/shop2.log [shop数据库的 temusers和emp导出]
如何恢复数据的表
进入的mysql操做界面
mysql>source 备份文件的全路径
定时备份:(把命令写入到my.bat 问中)
windows 如何定时备份 (天天凌晨2:00)
使用windows自带的计划任务,定时执行批处理命令。
定义:mysql数据库会以二进制的形式,自动把用户对mysql数据库的操做,记录到文件,当用户但愿恢复的时候,可使用备份文件进行恢复。
增量备份会记录dml语句、建立表的语句,不会记录select。记录的东西包括:sql语句自己、操做时间,位置
进行增量备份的步骤和恢复
注意:mysql5.0及以前的版本是不支持增量备份的
一、配置my.ini文件或者my.conf,启用二进制备份。
打开my.ini文件,查找log-bin,进行配置:log-bin=G:\Database\mysqlbinlog\mylog
若是是5.7还要进行配置:binlog_format=mixed
在G:\Database目录下面新建目录mysqlbinlog
二、重启mysql服务
这个时候会在mysqlbinlog目录下面看到如下两个文件:
mylog.000001:日志备份文件。若是要查看这个日志文件里面的信息,咱们可使用mysqlbinlog程序查看,mysqlbinlog程序存放在mysql的bin目录下面(“C:\Program Files\MySQL\MySQL Server 5.6\bin”)。
执行sql语句
UPDATE emp set ename='zouqj' where empno=100003;
开始——运行——cmd,mysqlbinlog 备份文件路径
C:\Program Files\MySQL\MySQL Server 5.6\bin>mysqlbinlog G:\Database\mysqlbinlog\mylog.000001
mylog.index:日志索引文件,里面记录了因此的日志文件。(G:\Database\mysqlbinlog\mylog.000001)
三、假设如今问题来了,我这条update是误操做,如何进行恢复
在mysql日志中会记录每一次操做的时间和位置,因此咱们既能够根据时间来恢复,也能够根据位置来恢复。
那么,咱们如今立刻能够从上图看出,这条语句产生的时间是"2016-04-17 12:01:36",位置是614
按时间来恢复
咱们能够选择在语句产生时间的前一秒
执行cmd命令:mysqlbinlog --stop-datetime="2016-04-17 12:01:35" G:\Database\mysqlbinlog\mylog.000001 | mysql -uroot -p
这个时候我再执行SQL语句查看
SELECT * from emp where empno=100003;
结果变成了
按位置来恢复
执行cmd命令:mysqlbinlog --stop-position="614" G:\Database\mysqlbinlog\mylog.000001 | mysql -uroot -p
这个时候再执行SQL来查看结果,又变回来了。