mysql主从复制的一些东西的整理
最近给新上线的项目进行主从结构的搭建,因此整理些有用的东西出来,供作记录:
一.mysql主从复制的一般配置步骤:
1.准备两台数据库环境,或者单台多实例的环境,能够正常的启动和登陆。
2.配置my.cnf文件,主库配置log-bin和server-id参数,从库配置server-id参数,不能和主库及其他从库一样,一般不开启从库的log-bin功能。注意:参数配
置后要重启才能生效。
3.登陆主库增加用于从库连接主库同步的账户例如:rep,并授权replication slave同步的权限。
4.登陆主库,并进行整库锁表 flush table with read lock (窗口关闭后即失效,超时参数到了也失效);然后show master status查看binlog的位置状态。
5.新开窗口,linux命令行备份或者导出原有的数据库数据,并拷贝到从库所在的服务器上。
6.解锁主库,unlock tables;
7.把主库导出的原有数据恢复到从库。
8.根据主库的show master status查看binlog的位置状态,在从库下面执行change master to..的语句。
9.从库开启同步开关,start slave.
10.从库show master status \G查看同步的状态
二.复制主线程的状态:
下面列出了主服务器的Binlog Dump线程的State列的最常见的状态。如果你没有在主服务器上看见任何的Binlog Dump线程,这说明复制没有在运行,目前没有连接任何从服务器。
1.sending binlog event to slave ----- 线程已经从二进制日志读取了一个事件并且正将它发送到从服务器。
2.finished reading one binlog;switch to next binlog --- 线程已经读完二进制日志并且正打开下一个要发送到从服务器的日志文件。
3.Has sent all binlog to slave;waiting for binglog to be updated -- 线程已经从二进制日志读取所有主要的更新并已经发送到了从服务器。线程现在正空闲,等待由主服务器上新的更新导致出现在二进制日志中的新事件。
4.waiting to finalize termination -- 线程停止时发生的一个很简单的状态。
三.复制从I/O线程状态:
使用 show slave status 显示State的最新状态,常见的状态如下:
1.connecting to master --- 线程正试图连接主服务器
2.checking master version -- 建立同主服务器之间的连接 后出现的短暂的状态。
3. requesting binlog dump
四. (1).生产授权方案1:
主库:web oldboy123 10.0.0.1 3306 (select insert delete update)
从库:主库的web用户同步到从库,然后回收insert delete,update的权限
不收回从库的权限,设置read-only参数去报从库只读。(注释:read-only参数只允许来自root或者super权限的账号的连接,对与普通用户则不会生效)
对开发而言:
主库:web oldboy123 10.0.0.1 3306 (select insert delete update)
从库:web oldboy123 10.0.0.2 3306 (select)
(2).生产授权方案:
主库:web_w oldboy123 10.0.0.1 3306 (select insert delete update)
从库:web_r oldboy123 10.0.0.2 3306 (select)
风险:web_w连接从库! 对开发而言,多套用户密码不专业。
(3).生产授权方案3:
mysql库不同步,即不同步授权的mysql库:
使用:replicate-ignore-db=mysql; binlog-ignore-db=mysql即可不用同步授权的账号
然后对主从库进行如下的授权:
主库:web oldboy123 10.0.0.1 3306 (select insert delete update)
从库:web oldboy123 10.0.0.2 3306 (select)
缺陷:当从库换成主库的时候,发生问题
方案:保留一个从库专门接替主库即可
replication中还可以通过一下的选项来减少binlog的数据量,来达到提升效率的目的,前两个用在Master端,后六个用在Slave端
Master端:
--binlog-do-db:二进制日志记录的数据库(多个数据库用,分隔)
--binlog-ignore-db:二进制日志记录的忽略的数据库(多个数据库用,分隔)
Slave端:
--replication-do-db:设定需要复制的数据库(多个数据库用,分隔)
--replication-ignore-db:设定忽略复制的数据库(多个数据库用,分隔)
--replication-do-table:设定需要复制的表(多个表用,分隔)
--replication-ignore-table:设定需要忽略的复制的表(多个表用,分隔)
binlog_format="MIXED" #设置bin-log日志文件格式为:MIXED,可以防止主键重复。
五.mysql的主从复制的应用场景:
mysql主从复制有利于数据库结构的健壮性,提升访问速度和易于维护管理。
1).主从服务器互为备份
主从服务器架构的设计,可以大大的加强数据库架构的健壮性。例如:当主服务器出现问题的时候,我们可以人工或者自动的切换到从服务器继续提供服务。
这个类似于之前nfs存储数据通过inotify+rsync同步到备份的nfs非常的类似,只不过MySQL的同步方案,是其自带的工具。
2).主从服务器读写分离分担网站的压力:
主从服务器的架构可通过程序(php,java)或者代理软件(mysql-proxy,amoeba)对用户的请求实现读写分离,即通过在从服务器上仅仅处理select查
询的请求,降低用户的查询时间以及读写同时在主服务器上带来的压力,对于更新的数据(update insert delete)仍然交给主服务器处理,确保主服务器
和从服务器保持实时的同步,如果网站是以非更新为主的业务,如blog,www的首页展示等业务,查询的请求比较多,这是从服务器的读写分离负载均衡策
略就很有效了,这就是读写分离数据结构。
中大型公司:通过程序(php,java)
测试环境:代理软件(mysql-proxpy,amoeba)
门户网站:分布式dbproxy(读写分离,hash负载均衡,健康检查)。
下面是一个常用的mysql的架构:
mysql主从复制的一些东西的整理的更多相关文章
- MYSQL主从复制配置(整理)
MYSQL主从原理及过程 原理 Mysql的 Replication 是一个异步的复制过程(mysql5.1.7以上版本分为异步复制和半同步两种模式),从一个 Mysql instace(我们称之为 ...
- Mysql主从复制,读写分离(mysql-proxy),双主结构完整构建过程
下面介绍MySQL主从复制,读写分离,双主结构完整构建过程,不涉及过多理论,只有实验和配置的过程. Mysql主从复制(转载请注明出处,博文地址:) 原理是master将改变记录到二进制日志(bina ...
- MySQL主从复制与读写分离
MySQL主从复制(Master-Slave)与读写分离(MySQL-Proxy)实践 Mysql作为目前世界上使用最广泛的免费数据库,相信所有从事系统运维的工程师都一定接触过.但在实际的生产环境中, ...
- mysql主从复制的一篇文章(转载)
管理mysql主从有2年多了,管理过200多组mysql主从,几乎涉及到各个版本的主从,本博文属于总结性的,有一部分是摘自网络,大部分是根据自己管理的心得和经验所写,整理了一下,分享给各位同行,希 ...
- MySQL主从复制与读写分离 --非原创
原文出处:http://www.cnblogs.com/luckcs/articles/2543607.html MySQL主从复制(Master-Slave)与读写分离(MySQL-Proxy)实践 ...
- mysql主从复制原理探索
上一篇文章里面,讲到了遇到mysql主从延迟的坑,对于这次的坑多说两句,以前也看过这样的例子,也知道不能够写完之后马上更新,但是真正开发的时候还是没有注意到这一点,道理大家都懂,但是还是会犯错,只有等 ...
- Mysql主从复制原理及配置
Mysql主从复制原理及配置 1.复制概述 Mysql内建的复制功能是构建大型,高性能应用程序的基础.将Mysql的数据分布到多个系统上去,这种分布的机制,是通过将Mysql的某一台主机的数据复制到其 ...
- 在线建立或重做mysql主从复制架构方法(传统模式和GTID模式)【转】
mysql主从复制架构,是mysql数据库主要特色之一,绝大多数公司都有用到. 而GTID模式是基于事务的复制模式的意思,发展到现在也是越来越多人用. 以前很多文章,介绍搭建mysql主从复制架构,是 ...
- [转]MySQL主从复制(Master-Slave)与读写分离(MySQL-Proxy)实践
转自:http://heylinux.com/archives/1004.html Mysql作为目前世界上使用最广泛的免费数据库,相信所有从事系统运维的工程师都一定接触过.但在实际的生产环境中,由单 ...
随机推荐
- 网络数据包收发流程(四):协议栈之packet_type
进入函数netif_receive_skb()后,skb正式开始协议栈之旅.先上图,协议栈大致过程如下所示:跟OSI七层模型不同,linux根据包结构对网络进行分层.比如,arp头和ip头都是紧跟在以 ...
- PAT (Basic Level) Practise:1023. 组个最小数
[题目链接] 给定数字0-9各若干个.你可以以任意顺序排列这些数字,但必须全部使用.目标是使得最后得到的数尽可能小(注意0不能做首位).例如:给定两个0,两个1,三个5,一个8,我们得到的最小的数就是 ...
- 原生javascript里jsonp的实现原理
ajax不能跨域,jsonp可以跨域 跨域的核心思想: 调用(拿到的接口),定义(jsonp核心处理器)分别是不同的script标签里面进行跨script取数据(只有get方式进行取数据 ) ...
- HTML5实战与剖析之触摸事件(touchstart、touchmove和touchend)
HTML5中新添加了很多事件,但是由于他们的兼容问题不是很理想,应用实战性不是太强,所以在这里基本省略,咱们只分享应用广泛兼容不错的事件,日后随着兼容情况提升以后再陆续添加分享.今天为大家介绍的事件主 ...
- 我的STL之旅 MyStack
#include<iostream> #include<cstdio> #include<cstring> #include<algorithm> us ...
- Java 报表之JFreeChart(第二讲)
1.利用 JFreeChart 创建按颜色分类的水果销售报表 package com.wcy.chart.bar; import javax.servlet.http.HttpSession; imp ...
- 基于MVC4+EasyUI的Web开发框架形成之旅--MVC控制器的设计
自从上篇<基于MVC4+EasyUI的Web开发框架形成之旅--总体介绍>总体性的概括,得到很多同行的关注和支持,不过上一篇主要是介绍一个总体的界面效果和思路,本系列的文章将逐步介绍其中的 ...
- mysql操作汇集
1.修改root密码 cmd进如mysql的bin目录 >mysql -u root -p Enter password: ****** mysql> use mysql; mysql&g ...
- Mac 下 Intellij IDEA 2016.1.2+maven+jetty+ JRebel 6.4.3 破解+spring mvc
准备阶段: Intellij IDEA 2016.1.2 (官方下载,作者下载的是社区版): JRebel for IntelliJ插件安装,可选择在线安装,在线安装的是最新版,我选择本地安装, 下 ...
- TOMCAT如何建立两个端口或服务
近日,一个客户需要将系统放到公网上,局网测试的时候用的8080,但该端口已经被其它应用占用,但又不想更改之前的端口,于是查了下资料,以供后阅 针对客户的这个情况,只是说想增加一个端口,这时只需要去to ...