Basis-MySQL Master-Slave

要求

  • 主服务器版本 <= 从服务器版本
  • 主从服务器初始数据一致(触发器、存储过程等无要求)
  • 主从服务器版本 > 3.2
  • 检查主从服务器是否大小写敏感,确保设置相同(Linux 默认区分大小写,Windows 默认不区分)

配置 主-从复制

主服务器

  • 创建同步账户
CREATE USER 'replicate'@'%' IDENTIFIED BY '888888';
GRANT REPLICATION SLAVE ON *.* TO 'replicate'@'%' IDENTIFIED BY '888888';
FLUSH PRIVILEGES;
  • 在从服务器上使用该账户连接从服务器,校验是否可进行主从复制
mysql -h192.168.7.36 -ureplicate -p
  • 修改 mysql 配置(/etc/my.cnf%MYSQL_HOME%/my.ini)
[mysqld]
server-id = 1 # 唯一标识主从服务器
log-bin=mysql-bin   # 打开 binlog,才可以通过 I/O 写到 slave 的 relay-log,也是进行 replication 的前提
binlog-do-db = test  #数据库名称,表示需要记录二进制日志,多个用逗号分隔,或使用多个 binlog-do-db
binlog-ignore-db = mysql # 不需要记录二进制日志的数据库,多个用逗号分隔,或使用多个 binlog-ignore-db
  • 重启 mysql 服务

  • 查看服务状态

    image

返回的参数File, Position,在后续配置从服务器时都会使用到。

在主从服务器未完成同步前,最好对主服务器进行锁表操作防止新的数据插入、更新,同步完成后在进行解锁

锁表 flush tables with read lock;
解锁 unlock tables;

从服务器

  • 修改 mysql 配置 (/etc/my.cnf%MYSQL_HOME%/my.ini)
[mysqld]
server-id = 2
log-bin=mysql-bin
replicate-do-db = test  #表示需要同步的数据库,多个用逗号分隔或配置多个
replicate-ignore-db = mysql,information_schema,performance_schema #表示不需要同步的数据库,多个用逗号分隔或配置多个
  • 重启 mysql 服务

  • 指定同步位置

    image
  • 查看服务状态

    image

注意检查标出的两项是否正常

测试

现在主从服务器已经同步了,可以在主服务器上对配置的数据库(此处为 test )进行操作,查看从服务器上对应数据库是否同步改变。

  • 在主服务器上创建表并插入一条记录
image
  • 查询从服务器
image

以上主服务器上的数据已同步到从服务器,主-从双机热备配置成功。

配置 主-主双机热备(互为主从)

  • 创建账户
    同时在主从服务器创建连接账户,该账户必须授予 REPLICATION SLAVE 权限。两台服务器互为主从。
CREATE USER 'replicate'@'%' IDENTIFIED BY '888888';
GRANT REPLICATION SLAVE ON *.* TO 'replicate'@'%' IDENTIFIED BY '888888';
FLUSH PRIVILEGES;
  • 修改 mysql 配置 (/etc/my.cnf%MYSQL_HOME%/my.ini)
    A 服务器(上一步中的主服务器)

    [mysqld]
    server-id = 1
    log-bin=mysql-bin
    binlog-do-db = test
    binlog-ignore-db = mysql
    #主-主形式需要多添加的部分
    log-slave-updates #配置从库上的更新操作是否写入二进制文件,如果这台从库,还要做其他从库的主库,那么就需要打这个参数,以便从库的从库能够进行日志同步
    sync_binlog = 1
    auto_increment_offset = 1
    auto_increment_increment = 2
    replicate-do-db = test
    replicate-ignore-db = mysql,information_schema
    

    B 服务器(上一步中的从服务器)

    [mysqld]
    server-id = 2
    log-bin=mysql-bin
    master-slave need
    replicate-do-db = test
    replicate-ignore-db = mysql,information_schema,performance_schema
    #主-主形式需要多添加的部分
    binlog-do-db = test
    binlog-ignore-db = mysql
    log-slave-updates
    sync_binlog = 1
    auto_increment_offset = 2
    auto_increment_increment = 2
    
  • 分别重启 mysql 服务

  • 分别检查主服务状态(master status)
    A 服务器

    image

    B 服务器

    image
  • 分别指定同步位置
    A 服务器

    image

    B 服务器

    image

注意B服务器之前的配置与此时的配置有差异;另外,需要停掉之前的配置,执行 stop slave

  • 分别启动服务
start slave
  • 分别查看服务状态,与之前配置主-从服务一样,检查是否配置成功
image
  • 测试主-主配置是否成功
    分别在A/B服务器操作test数据库,查看是否更新同步到另外一个服务器上。
    A 服务器创建新表并插入记录

    image

    检查 B 服务器

    image

    B 服务器创建新表并插入记录

    image

    检查 A 服务器

    image

以上数据都成功同步到另一台服务器上,主-主双机热备配置成功。

配置参数说明

  • server-id
    ID值唯一的标识主从服务器,必须各不相同。Master_id必须为1到232-1之间的整数值,slave_id值必须为2到232-1之间的整数值。

  • log-bin
    表示打开binlog,打开该选项才可以通过I/O写到Slave的relay-log,也是进行replication的前提。

  • binlog-do-db
    表示需要记录二进制日志的数据库。多个数据库用逗号分隔,或使用多个binlog-do-dg选项。

  • binglog-ingore-db
    表示不需要记录二进制日志的数据库,多个数据库用逗号分隔,或使用多binglog-ignore-db选项。

  • replicate-do-db
    表示需要同步的数据库,多个数据库用逗号分隔,或使用多个replicate-do-db选项。

  • replicate-ignore-db
    表示不需要同步的数据库,多个数据库用逗号分隔,或使用多个replicate-ignore-db选项。

  • master-connect-retry
    表示从服务器与主服务器的连接没有成功,则等待n秒(s)后再进行管理方式(默认设置是60s)。如果从服务器存在mater.info文件,它将忽略些选项。

  • log-slave-updates
    配置从库上的更新操作是否写入二进制文件,如果这台从库,还要做其他从库的主库,那么就需要打这个参数,以便从库的从库能够进行日志同步。

  • slave-skip-errors
    在复制过程,由于各种原因导致binglo中的sql出错,默认情况下,从库会停止复制,要用户介入。可以设置 slave-skip-errors 来定义错误号,如果复制过程中遇到的错误是定义的错误号,便可以路过。如果从库是用来做备份,设置这个参数会存在数据不一致,不要使用。如果是分担主库的查询压力,可以考虑。

    sync_binlog=1 Or N
    sync_binlog 的默认值是0,这种模式下,MySQL不会同步到磁盘中去。这样的话,Mysql 依赖操作系统来刷新二进制日志 binary log,就像操作系统刷新其他文件的机制一样。因此如果操作系统或机器(不仅仅是Mysql服务器)崩溃,有可能binlog中最后的语句丢失了。要想防止这种情况,可以使用sync_binlog全局变量,使binlog在每N次binlog写入后与硬盘同步。当sync_binlog变量设置为1是最安全的,因为在crash崩溃的情况下,你的二进制日志binary log只有可能丢失最多一个语句或者一个事务。但是,这也是最慢的一种方式(除非磁盘有使用带蓄电池后备电源的缓存cache,使得同步到磁盘的操作非常快)。

    即使 sync_binlog 设置为1,出现崩溃时,也有可能表内容和 binlog内容之间存在不一致性。如果使用 InnoDB 表,Mysql服务器处理COMMIT语句,它将整个事务写入binlog并将事务提交到InnoDB中。如果在两次操作之间出现崩溃,重启时,事务被InnoDB回滚,但仍然存在binlog中。可以用-innodb-safe-binlog选项来增加InnoDB表内容和binlog之间的一致性。(注释:在Mysql 5.1版本中不需要-innodb-safe-binlog;由于引入了XA事务支持,该选项作废了),该选项可以提供更大程度的安全,使每个事务的binlog(sync_binlog=1)和(默认情况为真)InnoDB日志与硬盘同步,该选项的效果是崩溃后重启时,在滚回事务后,Mysql服务器从binlog剪切回滚的InnoDB事务。这样可以确保binlog反馈InnoDB表的确切数据等,并使从服务器保持与主服务器保持同步(不接收回滚的语句)。

  • auto_increment_offset 和 auto_increment_increment
    auto_increment_incremen t和 auto_increment_offset 用于主-主服务器(master-to-master)复制,并可以用来控制 AUTO_INCREMENT 列的操作。两个变量均可以设置为全局或局部变量,并且假定每个值都可以为1到 65,535 之间的整数值。将其中一个变量设置为0会使该变量为1。

    这两个变量影响AUTO_INCREMENT列的方式:auto_increment_increment 控制列中的值的增量值,auto_increment_offset 确定 AUTO_INCREMENT 列值的起点。

    如果 auto_increment_offset 的值大于 auto_increment_increment 的值,则 auto_increment_offset 的值被忽略。例如:表内已有一些数据,就会用现在已有的最大自增值做为初始值。

错误处理

  • 大小写敏感导致无法同步
    当 Windows 和 Linux 系统做双机热备时,可能出现 Linux 可同步到 Windows,但反过来却不能同步的情况,通过 show slave 命令,可以看到, Linux 上的同步命令无法执行,因为 Linux 上 MySQL 表面默认区分大小写,此时需要修改默认配置,重启后生效:
[mysqld]
#1=on,0=off
lower_case_table_names=1
  • master 同步位置配置错误导致无法同步
    出现错误时仔细检查主从服务器的 master 同步位置配置,确保配置无误
    A 服务器

    image

    B 服务器

    image
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351

推荐阅读更多精彩内容