MariaDB 主从配置

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

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 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    951 引用 • 943 回帖

相关帖子

欢迎来到这里!

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

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