1 解决问题
对于mysql而言,在体系结构中是有一个缓存的,但是在实际的项目中,读一般远远大于写,大概有10倍的样子,自己的公司项目是在17倍的样子,默认的mysql内部实现的缓冲不够用,无法满足高并发的需求;所以就产生了一些缓存中间件,主流的缓存中间件redis,memcached等
2 mysql主从复制
原理图:
具体流程:
1 主库更新事件(update,insert,delete)通过io-thread写入binlog
2 从库请求读取binlog,通过io-thread写入(write)从库本地relay log(中继日志)
3 从库通过sql-thread线程读取(read)relay log,并把更新事件在从库中执行(relay一遍)
binlog:它是在事务提交后产生,跟引擎无关;
redolog:在事务提交后,也会有刷盘操作
2 读写分离
1 组织图
对于这种框架来说,当从越多,主就越慢;当然也可以多个主。
3 缓存中间件介绍
读多写少,单个主节点能支撑项目数据量;数据的主要依据是mysql;
1 mysql缓存
mysql体系结构中是有缓冲层,它的作用也是用来缓冲热点数据,这些数据包括数据文件,索引文件等;它的缓冲层是从自身触发的,跟具体的业务无关;缓冲策略采用主要是LRU(当然是经过优化的LRU);
mysql数据主要存储在磁盘当中,适合大量重要数据的存储&