MariaDB 主从配置

本贴最后更新于 2386 天前,其中的信息可能已经渤澥桑田

MariaDB 主从配置

MariaDB 数据库配置请查看 MariaDB 10.3 安装配置


MariaDB 的主从的配置是整个读,写分离的核心机制所在,所以现在建立了两台新的虚拟机:server-master,server-slave 关系就是 slave 同步 master 主机,本次使用的主机列表如下:

No. 主机名称 IP 地址 描述
1 server-master 192.168.31.128 MariaDB 服务(master)
2 server-slave 192.168.31.129 MariaDB 服务(slave)

1.【server-*】一定要保证两台服务的时间是同步的,如果不同步无法实现主从配置。

2.【server-master】修改 MariaDB 的配置文件:

vim /etc/my.cnf.d/server.cnf

#在 [mysqld] 下面添加
server-id=129   #主节点标识,唯一
log-bin=master-bin-1
  • "log_bin=master-bin-1":表示配置同步 bin 的文件名称,不同的主从关系组,名称不同;
  • "server_id=129":定义的是 MySql 服务的编号,这个编号一般取 IP 的最后一位;
  • 保存退出后可以之即启动 mysql 服务:
service mysql restart  #重起服务
  • 登录到 mysql 数据库之中:
 mysql -uroot -phahaha
  • 查看 master 状态:
show master status;

"File(server-bin-1.000001)",是从主机必须设置的名称;
"Position(331):同步的节点位置;

MariaDB [(none)]> show master status ;
+---------------------+----------+--------------+------------------+
| File                | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+---------------------+----------+--------------+------------------+
| server-bin-1.000001 |      331 |              |                  |
+---------------------+----------+--------------+------------------+

-------------------------------------若没有问题 该部分结束-----------------------

3.【server-master】考虑到与服务器同步的安全性问题,建议建立一个新的的用户:miim

MariaDB [(none)]> GRANT REPLICATION SLAVE ON *.* TO 'miim'@'%' IDENTIFIED BY 'zsl01';
MariaDB [mysql]> FLUSH PRIVILEGES;

4.【server-slave】从节点修改配置文件:

vim  /etc/my.cnf.d/server.cnf


log-bin=salve-bin
server-id=129
relay-log=relay-bin
log-slave-updates=1
read-only=1
  • 重启服务
service mysql restart  #重起服务

5.从配置

mysql -uroot -phahaha

MariaDB [mysql]> change master to master_host='192.168.31.128',master_user='miim',master_password='zsl01',master_log_file='server-bin-1.000001',master_log_pos=331;
MariaDB [mysql]> show slave status\G;    #查看从同步状态
*************************** 1. row ***************************
               Slave_IO_State: 
                  Master_Host: 192.168.31.128
                  Master_User: miim
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: server-bin-1.000001
          Read_Master_Log_Pos: 331
               Relay_Log_File: relay-bin.000001
                Relay_Log_Pos: 4
        Relay_Master_Log_File: server-bin-1.000001
             Slave_IO_Running: No   #  NO未开启同步
            Slave_SQL_Running: No
         
  • MariaDB [mysql]>start slave; #开启复制
MariaDB [mysql]> show slave status\G;    #查看从同步状态
*************************** 1. row ***************************
               Slave_IO_State: 
                  Master_Host: 192.168.31.128
                  Master_User: miim
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: server-bin-1.000001
          Read_Master_Log_Pos: 331
               Relay_Log_File: relay-bin.000001
                Relay_Log_Pos: 4
        Relay_Master_Log_File: server-bin-1.000001
             Slave_IO_Running: Yes   #  Yes开启同步
            Slave_SQL_Running: Yes
         

6. 测试

  • 主节点开启远程访问
DROP DATABASE IF EXISTS zsl;
CREATE DATABASE zsl CHARACTER SET UTF8 ;
USE zsl ;
CREATE TABLE member(
   MID VARCHAR(50) ,
   NAME VARCHAR(50) ,
   age INT ,
   salary DOUBLE ,
   birthday DATE ,
   note  TEXT ,
   CONSTRAINT pk_mid PRIMARY KEY(MID)
) ;
INSERT INTO member(MID,NAME,age,salary,birthday,note) VALUES ('zsl','hello',10,2000.0,'2017-11-11','very good') ;
INSERT INTO member(MID,NAME,age,salary,birthday,note) VALUES ('admin','admin',10,2000.0,'2017-11-11','very good') ;
INSERT INTO member(MID,NAME,age,salary,birthday,note) VALUES ('guest','admin',10,2000.0,'2017-11-11','very good') ;


  • 从节点
MariaDB [(none)]> show databases;

+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| zsl                |
+--------------------+

出现zsl数据库表示配置成功
  • MariaDB
    22 引用 • 15 回帖
  • Linux

    Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 Unix 的多用户、多任务、支持多线程和多 CPU 的操作系统。它能运行主要的 Unix 工具软件、应用程序和网络协议,并支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    915 引用 • 931 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...