栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

数据库基础:mysql主从集群搭建

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

数据库基础:mysql主从集群搭建

(4)查看一下主库的状态

show master statusG;

需要注意的是:如果没有上面第3步操作,执行show master status G;会报错,如下图:

file:表示同步的bin-log信息从哪个文件开始;

position:表示从file的哪个位置开始;

binlog_do_db:表示同步哪一个库

在后面的slave配置中,这三个结果都需要使用到。

4.Slave(6.85)节点配置

配置从库

(1)修改my.cnf文件,在[mysqld]加入下面的内容:

# 服务的唯一编号

server-id = 2

# 开启mysql binlog功能

log-bin = mysql-bin

# binlog记录内容的方式,记录被操作的每一行

binlog_format = ROW

# 减少记录日志的内容,只记录受影响的列

binlog_row_image = minimal

# 指定需要复制的数据库名为test

replicate-do-db = test

(2)修改好配置文件,重启mysql服务

service mysql restart

(3)执行同步命令

给从设置主服务器ip,同步账号密码,同步位置

mysql的终端执行:

change master to master_host='192.168.6.84',master_port=3306,master_user='replicate',master_password='replicate',master_log_file='mysql-bin.000001',master_log_pos=749;

命令需要特别注意:master_log_file 和master_log_pos 2个属性内容,这2个属性是刚才主服务器上执行show master statusG;查询出来的内容。

(3) 开启从机角色的

start slave;

(4)查看从库的状态

mysql的终端执行:

show slave statusG;

返回信息为

当:Slave_IO_Running和Slave_SQL_Running的状态都为Yes时,说明从库配置成功。

4.测试验证

首先在主库上创建test库:

create database test character set 'utf8';

依次执行:

use test;

show tables;

主库此时仍然没有表,查看从库

依次执行上述3条命令:

show databases;

use test;

show tables;

查询可知:slave节点的test库同样为空。

此时可以证明,主库的修改(创建了test)成功同步到从库中了。

接着在master节点上创建表people。

create table people(id int ,name varchar(20)) character set 'utf8';

show tables;

接着在slave上验证:

发现数据已经进行了同步。

至此,mysql的主备已经搭建完毕。

6、扩展

问题1:上述介绍的是备份某个库的操作,如果需要备份多个库则直接在master的my.cnf中添加新的一行binlog-do-db=test_2等等即可。这行代码的意思是指:同步该库(test_2)的bin-log信息。

问题2:这种直接修改master节点的my.cnf文件去同步某个库,需要重启master才能让整个mysql集群工作,有没有一种方法可以搭建备库,但是不需要重启master?

显然是可以的,不过这次备份的库是master的全部库了(因为没有指定具体库的bin-log), 所以默认就把全部的bin-log都同步了。可以参考如下的步骤:

step 1:导出Master节点中所有的数据库

mysqldump -uroot -A --routines --single-transaction --master-data=2 > /data1/mysqldump/alldatabases.sql

参数注释:

-A:导出所有库的数据

--routines Dump stored routines (procedures and functions) from dumped databases

--single-transaction Issue a BEGIN SQL statement before dumping data from server

--master-data Write the binary log file name and position to the output

这里添加option:--master-data之后,就可以不再使用show master statusG;去查看bin-log的file和position了。

step 2:

将上述的sql文件导入到备库中。

step 3:

其余步骤同上述内容【在master上创建一个用户,并授权,然后刷新】;在slave上执行change操作。

以上为全部内容。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/642740.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号