环境:

系统硬件:vmware vsphere (CPU:2*4核,内存2G,双网卡)

系统版本:CentOS-7-x86_64-Minimal-1611.iso

数据库版本信息 : 10.1.20-MariaDB Source distribution

主服务器的IP:192.168.1.14

从服务器的IP:192.168.1.15

从服务器的IP:192.168.1.16

步骤:

1.准备

三台服务器安装好MariaDB

(安装办法可以参考http://www.cnblogs.com/vicowong/p/5024792.html,第二部分 2.安装mariadb)

2.主服务器设置

2.1.修改主机名称

[root@centos ~]# hostnamectl --static set-hostname dbmaster

[root@centos ~]# systemctl restart network

2.2 修改IP地址

[root@centos ~]# vi /etc/sysconfig/network-scripts/ifcfg-eno16780032

找到BOOTPROTO,并且修改(设为静态网址)

BOOTPROTO="static"

在最后添加三行内容(添加本机IP,子网掩码,网关)

IPADDR="192.168.1.14"
NETMASK="255.255.255.0"
GATEWAY="192.168.1.1"

:wq 保存退出

2.3 重启

[root@centos ~]# shutdown -r now

2.4 配置主数据库

[root@dbmaster ~]# vim /etc/my.cnf

查找 log-bin=mysql-bin 行,确保此行生效,并且增加以下内容

log-bin=mysql-bin

log-bin-index = mysql-bin.index

查找 Server-id行,设置好ID(这里设置为1014,可以随意设置,只要唯一即可)

server-id   = 1014

:wq 保存退出

重启数据库服务,查看是否正常运行

[root@dbmaster ~]# systemctl restart mysql

[root@dbmaster ~]# systemctl status mysql -l

2.5 添加主从同步用户

[root@dbmaster ~]#  mysql -u root -p

输入密码,进入数据库命令行。主服务器上建立同步帐号 (运行环境不要将密码设置过于简单)

MariaDB [(none)]> GRANT REPLICATION SLAVE ON *.* to 'mysync'@'%' identified by 'q123456';

MariaDB [(none)]> FLUSH PRIVILEGES;

增加三个测试数据库 t1 t2 t3

MariaDB [(none)]> show databases;

MariaDB [(none)]> create database t1;

MariaDB [(none)]> create database t2;

MariaDB [(none)]> create database t3;

MariaDB [(none)]> show databases;

查看主服务器状态

MariaDB [(none)]> show master status;

+------------------+----------+--------------+------------------+
| File       | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000027 | 460   |        |          |
+------------------+----------+--------------+------------------+

3.从服务器01设置

3.1.修改主机名称

[root@centos ~]# hostnamectl --static set-hostname dbslave01

[root@centos ~]# systemctl restart network

3.2 修改IP地址

[root@centos ~]# vi /etc/sysconfig/network-scripts/ifcfg-eno16780032

找到BOOTPROTO,并且修改(设为静态网址)

BOOTPROTO="static"

在最后添加三行内容(添加本机IP,子网掩码,网关)

IPADDR="192.168.1.15"
NETMASK="255.255.255.0"
GATEWAY="192.168.1.1"

:wq 保存退出

3.3 重启

[root@centos ~]# shutdown -r now

3.4 配置从数据库01

[root@dbslave01 ~]# vim /etc/my.cnf

查找 log-bin行,禁止日志文件生成

#log-bin=mysql-bin

查找以下 binlog_format=mixed ,在下面添加以下内容

relay-log = relay-log
relay-log-index = relay-log.index

查找 Server-id行,设置好ID(这里设置为1015,可以随意设置,只要唯一即可)

server-id   = 1015

在此行下,添加以下内容

replicate-wild-ignore-table=mysql.%
log-slave-updates
read-only = ON

:wq 保存退出

重启数据库服务,查看是否正常运行

[root@dbslave01 ~]# systemctl restart mysql

[root@dbslave01 ~]# systemctl status mysql -l

3.5 查看从数据库状态

[root@dbslave01 ~]#  mysql -u root -p

输入密码,进入数据库命令行。查看数据只否处于只读状态

MariaDB [(none)]> show global variables like 'read%';

+----------------------+---------+
| Variable_name | Value |
+----------------------+---------+
| read_buffer_size | 1048576 |
| read_only | ON |
| read_rnd_buffer_size | 4194304 |
+----------------------+---------+

*** 如有需要,可以临时设置数据库可写

MariaDB [(none)]> set global read_only=1; 

3.6 将主数据库的现有表,全部复制到从数据库

3.6.1 进入主数据库,如果需要可以为mysqldump增加软连接

[root@dbmaster ~]# ll /opt/mysql/bin/mysqldump

[root@dbmaster ~]# ln -s /opt/mysql/bin/mysqldump /bin

3.6.2 在主服务器生成一个快照版本(生成之后,不要再进行数据库改动,否则同步不上)

查看InnoDB所有的数据都同步到磁盘

[root@dbmaster ~] mysql -u root -p

MariaDB [(none)]> show engine innodb status;

[root@dbmaster ~] cd /data

如果只有INNODB,就用如下命令生成快照:

[root@dbmaster ~]# mysqldump -uroot -p --events --triggers --routines --flush-logs --master-data=2 --lock-all-tables --databases t1 t2 t3> dbbackup.sql

--single-transaction 这个参数只对innodb适用,实现热备InnoDB表;因此,不需要同时使用--lock-all-tables;
--databases 后面跟除mysql以后的其他所有数据库的库名 (测试库上只有 t1 t2 t3 三个库)
--master-data 参数会记录导出快照时候的mysql二进制日志位置,一会会用到。
--lock-all-tables 为所有表加读锁

*** 如果有MYISAM或者既有MYISAM又有INNODB,就用如下命令生成快照

mysqldump -uroot -p --events --triggers --routines --flush-logs --master-data=2 --lock-tables --databases test > dbbackup.sql

查看主服务器状态

[root@dbmaster ~]#  mysql -u root -p

MariaDB [(none)]> show master status;

+------------------+----------+--------------+------------------+
| File       | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000027 | 460   |        |          |
+------------------+----------+--------------+------------------+

3.6.3   将主数据库的快照版本还原到从服务器01上

[root@dbmaster ~]# scp /data/dbbackup.sql root@192.168.1.15:/data

3.6.4 打开从服务器01,查看是否已经上传成功

[root@dbslave01 ~]#  cd /data

[root@dbslave01 ~]#  ll

使用grep命令查找到二进制日志的名称以及位置(显示的信息,应该必须和主服务器当前的 show master status 的一致)

[root@dbslave01 ~]#  grep -i "change master" dbbackup.sql

-- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000027', MASTER_LOG_POS=460;

[root@dbslave01 ~]#  mysql -u root -p

输入密码,进入数据库命令行。将主数据库快照恢复数据从数据库01中

[root@dbslave01 ~]#  show databases;

[root@dbslave01 ~]#  source /data/dbbackup.sql

[root@dbslave01 ~]#  show databases;

设置从服务器01,同步主服务器

[root@dbslave01 ~]#  change master to master_host='192.168.1.14',master_user='mysync',master_password='q123456',master_log_file='mysql-bin.000027',master_log_pos=460;

说明:

master_host 指定主服务器IP地址

master_user 主服务器专用于同步的用户名称(之前在主服务器上设置的)

master_password 主服务器专用于同步的用户密码

master_log_file 主服务器当前日志文件名称(必须对应)

master_log_pos 主服务器当前日志位置(必须对应)

启用从服务器01的同步
[root@dbslave01 ~]#  start slave;

查看状态
[root@dbslave01 ~]#  show slave status\G:

查看Slave_IO_Running和Slave_SQL_Running的状态,如果都为Yes,那么就成功了。

*** 如果设置错误,可以先停止同步状态,然后清空同步状态 ,再做一次

停止同步状态

[root@dbslave01 ~]#  stop slave;

清空同步状态(清空后,同步的日志名称、日志位置都会为空,要注意)

[root@dbslave01 ~]#  reset slave;

****************

4 测试主服务,从服务器01的数据库同步

4.1 打开主服务器

[root@dbmaster ~]#  mysql -u root -p

删除 t1 数据库,增加 t4 数据库

MariaDB [(none)]> show databases;

MariaDB [(none)]> drop database t1;

MariaDB [(none)]> create database t4;

MariaDB [(none)]> show databases;

查看主服务器状态(注意当前日志文件名称,日志位置)

MariaDB [(none)]> show master status;

4.2 打开从服务器

[root@dbslave01 ~]#  mysql -u root -p

查看从服务器01上的数据库

MariaDB [(none)]> show databases;

查看从服务器状态

MariaDB [(none)]> show slave status \G;

特别留意下面两行,是否对应主服务器当前的名称和位置 (另外需要注意,是否有额外错误行信息,如果一切正常,将不会有错误信息)

Master_Log_File: mysql-bin.000027

Read_Master_Log_Pos: 460

5.从服务器02设置

5.1.修改主机名称

[root@centos ~]# hostnamectl --static set-hostname dbslave02

[root@centos ~]# systemctl restart network

5.2 修改IP地址

[root@centos ~]# vi /etc/sysconfig/network-scripts/ifcfg-eno16780032

找到BOOTPROTO,并且修改(设为静态网址)

BOOTPROTO="static"

在最后添加三行内容(添加本机IP,子网掩码,网关)

IPADDR="192.168.1.16"
NETMASK="255.255.255.0"
GATEWAY="192.168.1.1"

:wq 保存退出

5.3 重启

[root@centos ~]# shutdown -r now

5.4 配置从数据库02

[root@dbslave02 ~]# vim /etc/my.cnf

查找 log-bin行,禁止日志文件生成

#log-bin=mysql-bin

查找以下 binlog_format=mixed ,在下面添加以下内容

relay-log = relay-log
relay-log-index = relay-log.index

查找 Server-id行,设置好ID(这里设置为1016,可以随意设置,只要唯一即可)

server-id   = 1016

在此行下,添加以下内容

replicate-wild-ignore-table=mysql.%
log-slave-updates
read-only = ON

:wq 保存退出

重启数据库服务,查看是否正常运行

[root@dbslave02 ~]# systemctl restart mysql

[root@dbslave02 ~]# systemctl status mysql -l

5.5 查看从数据库状态

[root@dbslave02 ~]#  mysql -u root -p

输入密码,进入数据库命令行。查看数据只否处于只读状态

MariaDB [(none)]> show global variables like 'read%';

+----------------------+---------+
| Variable_name | Value |
+----------------------+---------+
| read_buffer_size | 1048576 |
| read_only | ON |
| read_rnd_buffer_size | 4194304 |
+----------------------+---------+ 

5.6 将主数据库的现有表,全部复制到从数据库

5.6.1 删除原来备份(数据库有更改,必须重新生成快照备份)

[root@dbmaster ~] cd /data

[root@dbmaster ~] rm -rf dbbackup.sql

5.6.2 在主服务器生成一个快照版本(生成之后,不要再进行数据库改动,否则同步不上)

[root@dbmaster ~] mysql -u root -p

MariaDB [(none)]> show engine innodb status;

[root@dbmaster ~]# mysqldump -uroot -p --events --triggers --routines --flush-logs --master-data=2 -lock-all-tables --databases t2 t3 t4> dbbackup.sql

查看主服务器状态

[root@dbmaster ~]# mysql -u root -p

MariaDB [(none)]> show master status;

+------------------+----------+--------------+------------------+
| File       | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000029 | 382   |        |          |
+------------------+----------+--------------+------------------+

5.6.3   将主数据库的快照版本还原到从服务器02上

[root@dbmaster ~]# scp /data/dbbackup.sql root@192.168.1.16:/data

5.6.4 打开从服务器02,查看是否已经上传成功

[root@dbslave02 ~]#  cd /data

[root@dbslave02 ~]#  ll

使用grep命令查找到二进制日志的名称以及位置(显示信息,应该必须和主服务器当前的 show master status 的一致)

[root@dbslave02 ~]#  grep -i "change master" dbbackup.sql

-- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000029', MASTER_LOG_POS=382;

[root@dbslave02 ~]#  mysql -u root -p

输入密码,进入数据库命令行。将主数据库快照恢复数据从数据库01中

[root@dbslave02 ~]#  show databases;

[root@dbslave02 ~]#  source /data/dbbackup.sql

[root@dbslave02 ~]#  show databases;

设置从服务器02,同步主服务器

[root@dbslave01 ~]#  change master to master_host='192.168.1.14',master_user='mysync',master_password='q123456',master_log_file='mysql-bin.000029',master_log_pos=382;

说明:

master_host 指定主服务器IP地址

master_user 主服务器专用于同步的用户名称(之前在主服务器上设置的)

master_password 主服务器专用于同步的用户密码

master_log_file 主服务器当前日志文件名称(必须对应)

master_log_pos 主服务器当前日志位置(必须对应)

启用从服务器02的同步
[root@dbslave02 ~]#  start slave;

查看状态
[root@dbslave02 ~]#  show slave status\G:

查看Slave_IO_Running和Slave_SQL_Running的状态,如果都为Yes,那么就成功了。

6 测试主服务,从服务器01、从服务器02的数据库同步

6.1 打开主服务器

[root@dbmaster ~]#  mysql -u root -p

删除 t2 数据库,增加 t5 数据库

MariaDB [(none)]> show databases;

MariaDB [(none)]> drop database t2;

MariaDB [(none)]> create database t5;

MariaDB [(none)]> show databases;

查看主服务器状态(注意当前日志文件名称,日志位置)

MariaDB [(none)]> show master status;

6.2 打开从服务器01

[root@dbslave01 ~]#  mysql -u root -p

查看从服务器01上的数据库

MariaDB [(none)]> show databases;

查看从服务器状态

MariaDB [(none)]> show slave status \G;

特别留意下面两行,是否对应主服务器当前的名称和位置 (另外需要注意,是否有额外错误行信息,如果一切正常,将不会有错误信息)

Master_Log_File: mysql-bin.000029

Read_Master_Log_Pos: 460

6.3 打开从服务器02

[root@dbslave02 ~]#  mysql -u root -p

查看从服务器02上的数据库

MariaDB [(none)]> show databases;

查看从服务器状态

MariaDB [(none)]> show slave status \G;

特别留意下面两行,是否对应主服务器当前的名称和位置 (另外需要注意,是否有额外错误行信息,如果一切正常,将不会有错误信息)

Master_Log_File: mysql-bin.000029

Read_Master_Log_Pos: 460

***

同步查看要点,查看主数据库的show master status 以及各从服务器 show slave status\G,相对应的当前日志文件名称和位置是否对应,各从服务器show slave status\G是否有错误信息。

有可能出现同步错误的地方,主数据器和从服务器的安装始数据不一致(包括数据库,表,行数据等)。(例如同步情况下,主数据删除表,此表在从数据库中不存在,则会出现错误)

一旦 show slave status\G,出现错误信息。可以按以下操作执行。

1.主数据库设置为只读。

2.生成主服务器的数据库快照,并上传到从服务器

3.从服务器的数据库停止同步状态,并进行同步状态重设

4.将主数据库快照,恢复到从服务器上

5.重新设置从服务器的数据库同步

6.启动从服务器的同步

7.查看各服务器状态是否正常

Mariadb数据库设置及操作 一主多从 备份还原(实测笔记)的更多相关文章

  1. MariaDB数据库设置用户密码

    SET PASSWORD [FOR user] = { PASSWORD('some password') | OLD_PASSWORD('some password') | 'encrypted p ...

  2. SQL serve 数据库--视图、事物、分离附加、备份还原

    视图是数据库中的一种虚拟表,与真实的表一样,视图包含一系列带有名称的行和列数据.行和列数据用来自定义视图的查询所引用的表,并且在引用视图时动态生成.  视图只能用来查询,不能增删改:不允许出现重复列 ...

  3. Centos 7 安装 设置 IP地址,DNS,主机名,防火墙,端口,SELinux (实测+笔记)

    环境: 系统硬件:vmware vsphere (CPU:2*4核,内存2G,双网卡) 系统版本:CentOS-7.0-1406-x86_64-DVD.iso 安装步骤: 1.虚拟系统安装 1.1 使 ...

  4. [原创]MySQL数据库查询和LVM备份还原学习笔记记录

    一.查询语句类型: 1)简单查询 2)多表查询 3)子查询 4)联合查询 1)简单查询: SELECT * FROM tb_name; SELECT field1,field2 FROM tb_nam ...

  5. MyBatis返回主键,MyBatis Insert操作返回主键

    MyBatis返回主键,MyBatis Insert操作返回主键 >>>>>>>>>>>>>>>>> ...

  6. MyBatis学习 之 六、insert操作返回主键

       数据库操作怎能少了INSERT操作呢?下面记录MyBatis关于INSERT操作的笔记,以便日后查阅. 二. insert元素 属性详解   其属性如下: parameterType ,入参的全 ...

  7. MyBatis insert操作返回主键

    在使用MyBatis做持久层时,insert语句默认是不返回记录的主键值,而是返回插入的记录条数: Dao.java @Override public int insert(T record) { f ...

  8. MySQL/MariaDB数据库的主主复制

      MySQL/MariaDB数据库的主主复制 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.主主复制概述 1>.什么是主主复制 所谓的主主复制,说白了就是两台节点互为 ...

  9. MySQL/MariaDB数据库的多表查询操作

    MySQL/MariaDB数据库的多表查询操作 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.单表查询小试牛刀 [root@node105.yinzhengjie.org.cn ...

随机推荐

  1. Winform Textbox控件字体垂直居中

    项目中遇到要求Textbox内的字体垂直居中的问题,在网上找一直没有理想的解决方案.后来发现可以通过设置控件的字体来达到预期的效果. 默认的Textbox的Font属性为 “宋体, 9pt”,效果如下 ...

  2. mysql事务

    1. 事务并不专属于mysql 2. 事务的ACID特性 1)原子性(atomicity) 一个事务必须被视为一个不可分割的最小工作单元,整个事务中得所有操作要么全部提交成功,要么全部失败回滚,对于一 ...

  3. 前端工具gulp使用

    一.构建gulp环境 1.下载nodejs gulp基于node.js,要通过nodejs的npm安装gulp,所以要先安装node.js环境.(英文官网/中文官网链接). 通过cmd命令窗口确定安装 ...

  4. hdu 2222 Keywords Search

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=2222 思路:裸AC自动机,直接贴代码做模板 #include<stdio.h> #includ ...

  5. thinkphp 3.2.3 session 丟失問題

    之前做的几个 站session在跨页时也不会丢失(都在同一台服务器,所以我排除了服务器配置问题),这次居然很奇怪的发生的,在火狐上有,在ie, 谷哥上没有session,看了很多网上的贴子 其中有一个 ...

  6. 【Java EE 学习 82 下】【MAVEN整合Eclipse】【MAVEN的一些高级概念】

    一.MAVEN整合Eclipse MAVEN是非常优秀,但是总是要开命令行敲命令是比较不爽的,我们已经习惯了使用IDE,所以还有一种将MAVEN整合到Eclipse的方法. 详情查看:http://w ...

  7. 【Java EE 学习 54】【OA项目第一天】【SSH事务管理不能回滚问题解决】【struts2流程回顾】

    一.SSH整合之后事务问题和总结 1.引入问题:DAO层测试 假设将User对象设置为懒加载模式,在dao层使用load方法. 注意,注释不要放开. 使用如下的代码块进行测试: 会报错:no sess ...

  8. ORACLE序列号

    select MAXSYSACCEPT.nextval from dual; (序列号检索 增1)alter sequence MAXSYSACCEPT increment by 1 cache 20 ...

  9. Chrome 中的彩蛋,一款小游戏,你知道吗?

    今天看到一篇文章,介绍chrome中的彩蛋,带着好奇心进去看了一眼,没想到发现了一款小游戏,个人觉得还不错,偶尔可以玩一下,放松放松心情!^_^ 当 Chrome 无法连接到互联网时, 或者上着网突然 ...

  10. java io流 图片和字符串之间的转换

    package com.yundongsports.arena.controller.basketballsite;import com.yundongsports.arena.ResponseVo. ...