Mysql开发实践8问,你能hold住几个?(三)

2014-11-24 15:39:47 · 作者: · 浏览: 2
lect出需要的字段,避免select *
+----------+------------+-----------------------------------------------------+
| Query_ID | Duration | Query |
+----------+------------+-----------------------------------------------------+
| 1 | 0.02948800 | select count(1) from ( select id from mytable ) a |
| 2 | 1.34369100 | select count(1) from ( select * from mytable ) a |
+----------+------------+-----------------------------------------------------+
3、尽量早做过滤,使Join或者Union等后续操作的数据量尽量小
4、把能在逻辑层算的提到逻辑层来处理,如一些数据排序、时间函数计算等
5、......


PS:关于SQL优化,KM已经有足够多文章了,所以就不讲太全面了,只重点说自己1个感受:索引!基本都是因为索引!

======================================================

4、SQL层面已难以优化,请求量继续增大时的应对策略?

* 下面是我能想到的几个方法,每个方法又都是一篇大文章了,这里就不展开
分库分表
使用集群(master-slave),读写分离
增加业务的cache层
使用连接池

======================================================

5、Mysql如何做主从数据同步?

* 复制机制(Replication)
master通过复制机制,将master的写操作通过binlog传到slave生成中继日志(relaylog),slave再将中继日志redo,使得主库和从库的数据保持同步

* 复制相关的3个Mysql线程
1、slave上的I/O线程:向master请求数据
2、master上的Binlog Dump线程:读取binlog事件并把数据发送给slave的I/O线程
3、slave上的SQL线程:读取中继日志并执行,更新数据库
属于slave主动请求拉取的模式

* 实际使用可能遇到的问题
数据非强一致:默认为异步复制,master和slave的数据会有一定延迟(称为主从同步距离,一般<1s)
主从同步距离变大:可能是DB写入压力大,也可能是slave机器负载高,网络波动等原因,具体问题具体分析

* 相关监控命令
show processlist :查看Mysql进程信息,包括3个同步线程的当前状态
show master status :查看master配置及当前复制信息
show slave status :查看slave配置及当前复制信息

======================================================

6、如何防止DB误操作和做好容灾?

* 业务侧应做到的几点:
重要DB数据的手工修改操作,操作前需做到2点:1 先在测试环境操作 2 备份数据
根据业务重要性做定时备份,考虑系统可承受的恢复时间
进行容灾演练,感觉很必要


* Mysql备份和恢复操作
1、备份:使用mysqldump导出数据
mysqldump -u 用户名 -p 数据库名 [表名] > 导出的文件名
mysqldump -uroot -p test mytable > mytable.20140921.bak.sql
2、恢复:导入备份数据
mysql -uroot -p test < mytable.20140921.bak.sql
3、恢复:导入备份数据之后发送的写操作。先使用mysqlbinlog导出这部分写操作SQL(基于时间点或位置)
如导出2014-09-21 09:59:59之后的binlog:
mysqlbinlog --database="test" --start-date="2014-09-21 09:59:59" /var/lib/mysql/mybinlog.000001 > binlog.data.sql
如导出起始id为123456之后的binlog:
mysqlbinlog --database="test" --start-position="123456" /var/lib/mysql/mybinlog.000001 > binlog.data.sql
最后把要恢复的binlog导入db
mysql -uroot -p test < binlog.data.sql

======================================================

7、该选择Mysql哪种存储引擎,Innodb具有什么特性?

* 存储引擎简介
插件式存储引擎是Mysql的重要特性,Mysql支持多种存储引擎以满足用户的多种应用场景
存储引擎解决的问题:如何组织mysql数据在介质中高效地读取,需考虑存储机制、索引设计、并发读写的锁机制等
Mysql5.0支持的存储引擎有MyISAM、InnoDB、Memory、Merge等

* MyISAM和InnoDB的区别(只说重点了)
1、InnoDB
Mysql5.5之后默认引擎。
1 支持行锁:并发性能好
2 支持事务:故InnoDB称为事务性存储引擎,支持ACID,提供了具有提交、回滚和崩溃恢复能力的事务安全
3 支持外键:当前唯一支持外键的引擎
2、MyISAM
Mysql5.5之前默认引擎。
1 支持表锁:插入+查询速度快,更新+删除速度慢
2 不支持事务

* 使用show engines可查看当前Mysql支持的存储引擎详情
\

======================================================

8、Mysql内部结构有哪些层次?

* 非专业DBA,这里只简单贴个结构图说明下。Mysql是开源系统,其设计思路和源代码都出自大牛之手,有空可以学习下。
n     bz{[    觑z'暴 廿   y系统管理和控制工具
3 Connection Pool: 连接池。管理用户连接
4 SQL Interface: SQL接口。接受用户的SQL命令,并且返回用户需要查询的结果
5 Parser: 解析器。验证和解析SQL语句成内部数据结构
6 Optimizer: 查询优化器。为查询语句选择合适的执行路径
7 Cache和Buffer:查询缓存。缓存查询的结果,有命中即可直接返回
8 Engine :存储引擎。Mysql数据最后组织并存储成具体文件