复制多主一从

replicaion

原理

复制有三个步骤:(分为三个线程 slave:io线程 sql线程 master:io线程)

1、master将改变记录到二进制日志(binary log)中(这些记录叫做二进制日志事件,binary log events)

2、slave将master的binary log events拷贝到它的中继日志(relay log)

3、slave读取中继日志中的事件,将其重放到slave数据之上

日志解释

从库先通过io线程读取主库的二进制文件(Master_Log_File)和位置(Read_Master_Log_Pos)然后缓存到本地(从库服务器)的中继文件(Relay_Log_File)中并记录已经读取到的位置(Relay_Log_Pos),再通过从库的sql线程去读取中继文件(Relay_Log_File),这个sql线程执行会记录已经执行到了哪个文件(Relay_Master_Log_File)和哪个位置(Exec_Master_Log_Pos)。

配置复制

1、在master创建复制账号  

GRANT REPLICATION SLAVE,REPLICATION CLIENT ON *.* TO repl@'192.168.0.%' IDENTIFIED BY 'PASSWD';

2、配置master和slave

master
server-id =
log-bin = mysql-bin
expire-logs-days = # 设置二进制日志过期的天数
max_binlog_size = 512M # 二进制日志滚动的阀值 slave
server-id =
expire-logs-days =
max-relay-log-size = 512M
relay-log = mysql-relay-bin
relay_log_recovery = # 修复中继日志
replicate_wild_ignore_table = mysql.% # 过滤哪些主库不复制

3、通知slave连接到master并从master复制数据

CHANGE MASTER TO MASTER_HOST='master',MASTER_USER='repl',MASTER_PASSWORD='passwd',MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=; 

4、启动复制,查看状态

slave
  START SLAVE

show slave status\G

在输出信息中查看I/O线程和SQL线程的状态值(YES为正常,NO为错误)

  Slave_IO_Running: Yes

  Slave_SQL_Running: Yes

mysqld_multi

与安装单实例一样,只是要初始化多个数据目录对应相应的实例

mkdir -p /storage/data/mysql{,,}
chown -R mysql:mysql /storage/data/mysql{,,}
scripts/mysql_install_db --user=mysql --datadir=/storage/data/mysql1
scripts/mysql_install_db --user=mysql --datadir=/storage/data/mysql2
scripts/mysql_install_db --user=mysql --datadir=/storage/data/mysql3

添加多实例管理用户

GRANT SHUTDOWN ON *.* TO 'multi'@'localhost' IDENTIFIED BY 'multi'

mysqld_multi

Usage: mysqld_multi [OPTIONS] {start|stop|report} [GNR,GNR,GNR...]

my.cnf

[mysqld_multi]
mysqld = /storage/server/mysql/bin/mysqld_safe
mysqladmin = /storage/server/mysql/bin/mysqladmin
user = multi
password = multi
log = /storage/data/mysqld_multi.log [mysqld1]
# mysql1
port =
socket = /tmp/mysql3306.sock
basedir = /storage/server/mysql
datadir = /storage/data/mysql1
character-set-server=utf8
collation-server=utf8_unicode_ci
server-id =
expire-logs-days =
max-relay-log-size = 512M
relay-log = mysql1-relay-bin
relay_log_recovery =
replicate_wild_ignore_table=mysql.% [mysqld2]
# mysql2
port =
socket = /tmp/mysql3307.sock
basedir = /storage/server/mysql
datadir = /storage/data/mysql2
character-set-server=utf8
collation-server=utf8_unicode_ci
server-id =
expire-logs-days =
max-relay-log-size = 512M
relay-log = mysql2-relay-bin
relay_log_recovery =
replicate_wild_ignore_table=mysql.% [mysqld3]
# mysql3
port =
socket = /tmp/mysql3308.sock
basedir = /storage/server/mysql
datadir = /storage/data/mysql3
character-set-server=utf8
collation-server=utf8_unicode_ci
server-id =
expire-logs-days =
max-relay-log-size = 512M
relay-log = mysql3-relay-bin
relay_log_recovery =
replicate_wild_ignore_table=mysql.%

mysql主从常见错误

error 1062

错误原因:主键冲突 出现这种情况就是从库出现插入操作 主库又重新来了一遍 iothread没问题 sqlthread出错

解决方案:从库

mysql> stop slave;
mysql> set global sql_slave_skip_counter=;
mysql> start slave;

最新文章

  1. Azure Application Gateway (3) 设置URL路由
  2. 《The Elder Scrolls V: Skyrim》百般冷门却强力职业
  3. [ARM] Cortex-M Startup.s启动文件相关代码解释
  4. css实现元素居中
  5. N皇后问题--回溯法
  6. Spring 定时任务的实现<转>
  7. C++多态性的理解
  8. 认识div(division)在排版中的作用
  9. PHP从数据库获取的下拉树
  10. 使用weinre远程调试
  11. Errors are values
  12. 使用 ServiceAnt 更好地解耦你的程序
  13. 《MySQL必知必会》读书笔记_2
  14. 【git】git hello world
  15. spring学习总结——高级装配学习三(Bean的作用域)
  16. 老K漫谈区块链的共识(3)——分布式系统和区块链共识
  17. 在Java中调用Python
  18. HDFS核心设计
  19. css hack整理 (摘)
  20. 二叉树的先序、中序、后序和中序遍历——Java实现

热门文章

  1. Git的冲突解决过程
  2. SQL SERVER 2014 Agent服务异常停止案例
  3. VS 中關於附加到進程中調試 的問題。
  4. android radiogroup样式(设置切换背景与文字颜色)
  5. Nginx服务安装配置
  6. 好压(HaoZip)的命令行模式用法介绍
  7. Windows Live Writer测试
  8. Caffe源码解析6:Neuron_Layer
  9. javascript详解系列-函数表达式
  10. php 单双引号的区别