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,

最新文章

  1. supervisor program配置实例
  2. 键盘按钮keyCode大全,keyCode列表对照表
  3. 深入浅出设计模式——工厂方法模式(Factory Method)
  4. 线段树好题(2004集训队林涛PPT中的3题)
  5. java语法学习问题总结
  6. 嵌入式 uboot引导kernel,kernel引导fs
  7. Tkinter教程之Listbox篇
  8. 5.1:FactoryBean的使用
  9. POJ_3616_Milking_Time_(动态规划)
  10. Scala入门系列(五):面向对象之类
  11. tensorflow建造神经网络-【老鱼学tensorflow】
  12. mybatis中使用Integer类型的参数<if>判断问题
  13. WireShark Wifi认证数据包分析(论文idea)
  14. Mac使用Clion配置OpenGL
  15. 7个管理和优化网站资源的 Python 工具
  16. spoj Minimax Triangulation
  17. mysql set
  18. SQL 增删字段
  19. css3制作梯形导航
  20. CSS3的Animation

热门文章

  1. NYOJ 1875 畅通工程再续 (无节点间距离求最小生成树)
  2. 洛谷2016 战略游戏 (0/1状态的普通树形Dp)
  3. Java学习之理解递归
  4. python之Gui编程事件绑定 2014-4-8
  5. js的几个可能不清晰的问题
  6. Leetcode 307.区域检索-数组可修改
  7. Python和Mongodb
  8. @locked_cached_property ---flask.helpers模块
  9. BZOJ 1509[NOI 2003]逃学的小孩 树形dp
  10. docker镜像没有ifconfig、ping指令