[如何解决数据库崩溃.docVIP

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[如何解决数据库崩溃

如何解决数据库崩溃,数据丢失?   基础知识   数据库日志的分类   1.二进制日志 2.错误日志 3.一般查询日志4.中继日志5.慢查询日志   二进制日志的格式:   statement:基于语句   row:基于行   mixed:混合方式   mysql的隔离级别:   readuncommitted:读未提交   readcommitted:读提交   repeatableread:可重读   serializable:可串行   二进制日志,默认放在数据库,名称为mysql-bin.xxxxx,当日志文件达到上限时,会不停的滚动,可以使用如下命令:   刷新日志   mysqlflush logs;   查看当前正在使用的二进制日志   mysqlshow master status;   查看二进制日志的内容   mysqlshow binarylogs;   二进制日志的用途:   二进制日志可以用来做即时点还原,因为里面记录了此前可以改变数据库的各种操作,这样,若数据库损坏,可以用二进制日志文件重新执行一遍   mysql的复制   A服务器把可能改变数据改变的操作,保存于二进制日志文件,A服务器把二进制日志文件的内容的事件随时通过本地服务器发送到B服务器,B服务器把事件保存至中继日志,通过读取中继日志的事件在B服务器执行操作,结果保存于数据库,同时会产生二进制日志,mysql的复制,这个流程就是mysql的复制,其中的A服务器就是主服务器,B服务器就称之为从服务器   主从服务器数据的传输方式   异步传输。因为从服务器的数据是从主服务器复制得到,所以从服务器的数据会比主服务器得到数据的速度要慢,从种种角度来讲从服务器比主服务器慢,所以主从服务器传输数据的方式是异步传输   传输方式:   异步传输:只要主服务器本地执行成功,就宣告执行成功,不管从服务器是否收到数据   半同步传输:对于主服务器来讲,只要最近一台的节点传输成功,就宣告成功   规定主从服务器的读写操作   从服务器是不允许写操作的,因为若从服务器写入数据,而又不能同步到主服务器,会导致主从服务器数据的不一致,会造成数据库崩溃,所以对于非主服务器的服务器都不允许写操作,就导致了主服务器允许读写操作,而从服务器只能允许读操作   从服务器有必要有二进制日志文件吗?   答案是:有,虽说从服务器无非就是同步主服务器的数据而已,多了二进制日志文件反而会降低存储速度,但是这个从服务器可以是别的从服务器的主服务器,可称为多级日志,中继日志是不能拿来发给别人的,所以就有了二进制日志存在的必要啦......那么为什么要用多级复制呢?如果主服务器忽然宕机,可以让这个从服务器做些简单修复,成为主服务器,这同时也就达到了服务器的高可用   复制数据的特点:(1)辅助实现备份。(2)高可用。(3)异地容灾   读写分离:   若规定各个服务器的操作,会出现负载不均衡现象,所以就在mysql服务器的前端出现了代理服务器,若是读操作,就发送至从服务器,若是写操作,就发送至主服务器。由于读操作较多与写操作。所以在众多可读的从服务器前端增加调度器,同时对主服务器、调度服务器、代理服务器做高可用.   mysql缓存服务器的好处:   若每次操作都到服务器上执行时,会发现速度很慢,所以建立共享式缓存(memcache),若下次访问memcache,若有所要查询的结果,就把结果返回至客户端,减少传输时间.   主从架构中,不使用mysql代理服务器,怎么实现数据同步?   使用双主模型,两个服务器都可以读写操作,A服务器的写操作的结果存储到二进制日志文件,将二进制日志文件发送至B服务器,存放于B服务器的中继日志,进行各种操作,保存二进制日志。B服务器执行各种操作,保存于二进制日志,传送至A服务器,保存于中继日志,执行各种操作,保存于二进制日志,但这样就称为了死循环,所以给各个服务器赋予server id,根据不同的server id来识别哪些内容是本地日志,同时对本地日志不进行操作,只操作非本地的日志,就完成了数据的同步   配置mysql复制的基本步骤   1. master   1.启用二进制日志   log-bin=master-bin   log-bin-index=master-bin.index   2.选择一个惟一server-id   serve r- id={0-2^32}   3.增加表空间   innodb_file_per_table = 1   4.创建具有复制权限的用户(require ssl)   mysqlgrant replication slave on *.* to username@172.16.%.%identified by pa

文档评论(0)

xiaoyi2013 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档