mysql07---主从复制
mysql主从复制,replication,(可以一主多从,不可一从多主) 原理: 主从分离,最少2台服务器。主服务器里面的数据,要在从服务器里面都有一份。
把主服务器的所有insert,update操作,都记录在binlog二进制日志文件里面,从服务器来读取binlog进行操作。binlog是主服务器的,从服务器不能直接使用,要转换为relog再操作。 1.主服务器要配置binlog
2.从服务器要配置relaylog
3.从服务器如何有权读取binlog(2个服务器的ip地址都不一样),主服务器就要授权slave账号,从服务器通过账号连接主服务器。 实现步骤:
1.首先确保主服务器打开二进制日志binlog功能,这样主服务器一旦有数据变化就立即产生二进制日志。
2.从服务器也要开启二进制日志binlog(从服务器的二进制日志也要打开,便于以后恢复数据,如果这个从服务器有从服务器,那么二进制日志用得到的)和relay日志relay-log功能(从服务器多打开relay功能)。这样可以从主服务器读取binlog并产生relaylog
3.在主服务器建立一个从服务器的账号,并授予读binlog的权限
4.指定从服务器对应的主服务器,开启从服务器 具体实施:
1.200做从服务器,199为主服务器
2.保证从3306端口互通
3.配置主服务器,打开binlog /* binlog format : 主服务器update之后,从服务器也执行update。不看执行的语句,只看主服务器的磁盘变化了,从服务器就跟着磁盘变化。
binlog format:row/statement //2进制日志记录的格式
statement:记录的是执行语句,如update
row:记录磁盘的变化
哪个好:
update age=age+1 where id=3; //语句长磁盘变化小,宜用row
update salary = saslary +10000; //语句短,但是影响上万行,宜用statement,
拿不准就用mixed:由系统判断。 */ //配置主服务器
192.168.1.201>
[mysqld]
datadir=/var/lib/mysql
socket=/var/mysql/mysql.sock
user=mysql
symbolic-links=0 server-id=201 //给服务器起一个独特的id
log-bin=mysql-bin //声明2进制日志的文件为mysql-bin-xxxx
binlog-format=mixed 192.168.1.201> cd /var/lib/mysql/
192.168.1.201> rm -rf ./mysql-bin* //删除之前产生的日志文件
192.168.1.201> service mysqld start //重启mysql //配置从服务器
192.168.1.202>
[mysqld]
datadir=/var/lib/mysql
socket=/var/mysql/mysql.sock
user=mysql
symbolic-links=0 server-id=202 //给服务器起一个独特的id
log-bin=mysql-bin //开启binlog,如果数据丢失了,但是二进制日志没有丢可以恢复数据。
binlog-format=mixed relay-log=mysql-relay //从服务器多打开relay日志功能 192.168.1.202> cd /var/lib/mysql/
192.168.1.202> rm -rf ./mysql-bin* //删除之前产生的日志文件
192.168.1.202> service mysqld start //重启mysql //主从服务器已经建立起来了,但是2者还没有关系
//配置主服务器
192.168.1.201> mysql -uroot -p //登陆进去,cd /var/lib/mysql 可以看到mysql-bin.00001日志文件
192.168.1.201> show master status //可以查看当前binlog文件,可以看到他已经具有了主服务器的权限了(mysql库里面有表)
192.168.1.201> grant replication client,replication slave on *.* to repl@'192.168.1.%' identified by 'repl' //授权账号,'192.168.1.%'局域网都可以,密码'repl',
192.168.1.201> flush privileges //现在有了一个repl账号,有权读取主服务器的binlog //配置从服务器
192.168.1.202> mysql -uroot -p //登陆进去
192.168.1.202> show slave status //(mysql库里面有表),现在是空的。
192.168.1.202> change master to //连接哪个主服务器
master_host='192.168.1.201',
master_user='repl', //连接的时候使用什么账号
master_password='repl',
master_log_file='mysql-bin.00001', //现在主服务器正在使用的binlog日志文件,通过主服务器show master status可以看到
master_log_pos=348; //通过主服务器show master status可以看到
192.168.1.202> show slave status //可以看到已经打通了
192.168.1.202> start slave //起
192.168.1.202> sop slave //关闭
192.168.1.202> start slave //起
192.168.1.202> show slave status //看起的时候有没有错误。 //测试:主服务器有从服务器也有。
//telnet 192.168.1.201 3306 ; ping 192.168.1.201
192.168.1.201> create database test8
192.168.1.202> show database //多了test8
192.168.1.201> use test8
192.168.1.201> create table stu(sid int,sname char(20))
192.168.1.202> use test8 show database //多了stu
192.168.1.201>insert into stu values(1,'lili')
192.168.1.202> #还有主主复制,你当我的主我当你的从。两台主主背后还可以拖着一个从。 这时mysql的主从复制,但不是读写分离。读写分离是:读只从从服务器,insert.delete.update在主服务器。是sql语句自动分开执行。
读写分离可以在php级别做判断,也可以用集群中间件例如mysql_proxy,
mysql07---主从复制的更多相关文章
- MySQL 系列(四)主从复制、备份恢复方案生产环境实战
第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...
- [原]Redis主从复制各种环境下测试
Redis 主从复制各种环境下测试 测试环境: Linux ubuntu 3.11.0-12-generic 2GB Mem 1 core of Intel(R) Core(TM) i5-3470 C ...
- MySQL+Amoeba实现数据库主从复制和读写分离
MySQL读写分离是在主从复制的基础上进一步通过在master上执行写操作,在slave上执行读操作来实现的.通过主从复制,master上的数据改动能够同步到slave上,从而保持了数据的一致性.实现 ...
- Redis主从复制
大家可以先看这篇文章ASP.NET Redis 开发对Redis有个初步的了解 Redis的主从复制功能非常强大,一个master可以拥有多个slave,而一个slave又可以拥有多个slave,如此 ...
- MySQL主从复制(Master-Slave)实践
MySQL数据库自身提供的主从复制功能可以方便的实现数据的多处自动备份,实现数据库的拓展.多个数据备份不仅可以加强数据的安全性,通过实现读写分离还能进一步提升数据库的负载性能. 下图就描述了一个多个数 ...
- 2.快速部署MySQL主从复制
1.快速部署MySQL主从复制 [root@mysql ~]# mysql -uroot -p123456 -S /data/3307/mysql.sock -e "show slave ...
- MySQL 主从复制
1 复制概述 Mysql内建的复制功能是构建大型,高性能应用程序的基础.将Mysql的数据分布到多个系统上去,这种分布的机制,是通过将Mysql的某一台主机的数据复制到其它主机(slaves)上,并重 ...
- MySQL 主从复制与读写分离概念及架构分析
1.MySQL主从复制入门 首先,我们看一个图: 影响MySQL-A数据库的操作,在数据库执行后,都会写入本地的日志系统A中. 假设,实时的将变化了的日志系统中的数据库事件操作,在MYSQL-A的33 ...
- Mongodb数据库学习系列————(一)Mongodb数据库主从复制的搭建
Mongodb数据库主从复制的搭建 Writeby:lipeng date:2014-10-22 最近项目上用到了位置查询,在网上 ...
- mysql主从复制操作步骤
注: .做主从复制的两台服务器server-id不能相同 .主从的字符集要一样,不然数据导入会报错 .开启db01的log-bin功能 [root@db01 mysql]# vim /etc/my.c ...
随机推荐
- scrollLeft属性设置无效的一个记录
首先应该明确scrollLeft这个属性,只有当div中的内容长度大于当前div的长度是才能working,根据这个我我找到了一个很神奇的地方,而且我注意到这个${}连注释里面都能替换过来! 以下是正 ...
- Linux Notes:Linux下的远程登录协议及软件
常见的远程登录协议 1.RDP(remote desktopp protocol)协议,windows远程桌面协议 2.telnet CLI 界面下远程管理,几乎所有的操作系统都有,数据明文传输,不安 ...
- HDU1213最简单的并查集问题
题目地址 http://acm.hdu.edu.cn/showproblem.php?pid=1213 #include<iostream> using namespace std; #d ...
- POJ 1486 Sorting Slides【二分图匹配】
题目大意:有n张幻灯片和n个数字,幻灯片放置有重叠,每个数字隶属于一个幻灯片,现在问你能够确定多少数字一定属于某个幻灯片 思路:上次刷过二分图的必须点后这题思路就显然了 做一次二分匹配后将当前匹配的边 ...
- 在RedHat 5下安装Oracle 10g详解(转)
在RedHat 5下安装Oracle 10g详解(转) Posted on 2012-09-14 13:26 疯狂 阅读(5075) 评论(0) 编辑 收藏 所属分类: database .uni ...
- PHP中的魔术方法【转载】
__construct, __destruct , __call, __callStatic,__get, __set, __isset, __unset , __sleep, __wakeup, _ ...
- Codeforces 660E Different Subsets For All Tuples【组合数学】
看了官方题解+q神的讲解才懂... 智商问题.. 讲道理..数学真的比脱单难啊... 题目链接: http://codeforces.com/problemset/problem/660/E 题意: ...
- T1365 浴火银河星际跳跃 codevs
http://codevs.cn/problem/1365/ 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 小 K 又在玩浴 ...
- P1396 营救 洛谷
https://www.luogu.org/problem/show?pid=1396 题目描述 “咚咚咚……”“查水表!”原来是查水表来了,现在哪里找这么热心上门的查表员啊!小明感动的热泪盈眶,开起 ...
- 转 常见hash算法的原理
散列表,它是基于快速存取的角度设计的,也是一种典型的“空间换时间”的做法.顾名思义,该数据结构可以理解为一个线性表,但是其中的元素不是紧密排列的,而是可能存在空隙. 散列表(Hash table,也叫 ...