如何进行mysql数据库主从同步中数据库同步配置
admin
2023-06-09 05:21:26
0

背景: 最近有一个mysql数据库同步的需求,我用了mysql主从同步的方法来实现。下面把步骤记录一下。

环境和拓扑

操作系统:Centos6.6 X64

mysql版本:5.1.73

Master: 10.6.1.210

Slave:  10.6.1.211

如何进行mysql数据库主从同步中数据库同步配置

需求: 实现Master上test库同步到Slave上,但是禁止同步该库下的AA表

1.配置Master上的my.cnf

#vim  /etc/my.cnf 添加内容到[mysqld]下,设定只同步test 数据库:

[mysqld]

log-bin=mysql-bin

binlog_format=mixed

binlog_do_db=test

server-id=1

2.配置Slave上的my.cnf

#vim  /etc/my.cnf

添加内容到[mysqld]下:

log-bin=mysql-bin

binlog_format=mixed

server-id=10

relay-log =relay-bin

log_slave_updates=1

replicate_ignore_table=AA(忽略同步某个表)

3.在Master中建立一个备份帐户:每个slave使用标准的MySQL用户名和密码连接Master,用户名的密码都会存储在文本文件master.info。进行复制操作的用户会授予REPLICATION   SLAVE 权限。

命令如下:

#建立一个帐户repluser,并且只能允许10.6.1.211这个主机来登陆,密码是123456。

mysql>grant  replication client,replication  slave  on  *.*   to 'repluser'@'10.6.1.211'    identified by  '123456';

QueryOK,0 rows affected(0.00sec)

mysql>flush privileges;

QueryOK,0 rows affected(0.00sec)

4.拷贝数据,保持数据库内数据一致,新安装可以忽略此步骤。

备份Master上的test库,然后复制到从服务器上.

#mysqldump -u root -p password123   test>/tmp/test.sql

将导出的数据库复制到从服务器上。

#scp /tmp/test.sql root@10.6.1.211:/tmp/

在Slave上导入新的test数据库。 登陆从后运行

#mysql -u root -p password123 test

5.重启mysql服务,主从server均要重启。

#service mysql restart

6.查看Master数据库上的bin文件以及时间点. 登录Master服务器的mysql  后执行:

mysql> show master status;
+------------------+----------+--------------+------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000015 |     2474 | test         |                  |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)

此处,bin文件为mysql-bin.000015,节点为2474。

7.启动从服务器的中继日志,登陆从服务器的mysql 后执行以下命令,标红部分为刚才在主服务器上查询到的bin  文件以及节点信息:

mysql>change master to master_host='10.6.1.210',master_user='repluser',

master_password='123456',master_log_file='mysql-bin.000015',master_log_pos=2474,

master_connect_retry=5

QueryOK,0 rows affected(0.03sec)

#开启从服务器节点的复制进程,实现主从复制;

mysql>start slave;

#查看从服务器状态,主要关注IO线程和SQL  线程的开启状况:

mysql>show slave status \G


Slave_IO_Running:Yes            #IO thread  是否运行

Slave_SQL_Running:Yes         #SQL thread是否运行

8.查看主从服务器上的线程状态

主服务器:

mysql>show processlist \G

State: Has sent all binlog to slave; waiting for binlog to be updated

从服务器

mysql>show processlist \G

State: Has read all relay log; waiting for the slave I/O thread to update it

至此,mysql数据库主从同步复制配置完成.

验证

1.  在Master上的test库下新建一个test表.   插入记录,然后看看是否同步到了Slave上。

Master上建表

mysql> CREATE TABLE `test` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(10) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ;

Master上插入记录

mysql>insert into test(id,name) values(1,'steven');

mysql> select * from test;
+----+--------+
| id | name   |
+----+--------+
|  1 | steven |
+----+--------+
1 row in set (0.00 sec)

Slave上查看是否同步过去.

mysql> select * from test;
+----+--------+
| id | name   |
+----+--------+
|  1 | steven |
+----+--------+
1 row in set (0.00 sec)

2. 在Master上的test库下新建一个AA表.   插入记录,然后看看是否同步到了Slave上。

在Master上查询AA表.

mysql> select * from AA;
+----+--------+
| id | name   |
+----+--------+
|  1 | Angelababy |
+----+--------+
1 row in set (0.00 sec)


Slave上查询AA记录是空.

mysql> select * from AA;
Empty set (0.00 sec)


相关内容

热门资讯

小米YU7 GT、小米17 M... 5月21日,小米连续发布全新小米YU7家族,新增小米YU7 GT、YU7 标准版两大车型。同场发布的...
持续深耕AI4S创新创业生态 ... 首期科学智能百团百项“科创训练营”近日在沪举办,来自近30个AI4S(AI for Science)...
特朗普:美伊协议“尚未完全谈妥... 新华社华盛顿5月24日电(记者颜亮 徐剑梅)美国总统特朗普24日说,美国和伊朗的协议“尚未完全谈妥”...
大幅升级改造!神舟二十三号飞船... 神舟二十三号飞船出征在即,作为新批次飞船的第二艘飞船,它有哪些改进?承担什么样的任务? 人机界面升...
原创 这... 在自然界,有一些动物通过模仿有毒的、有害的其它动物,来提高生存能力,也有一些动物通过模仿周围的环境来...
Windows竟然藏了一个工具... 快科技5月24日消息,据Neowin报道,Windows系统中有一个鲜为人知的“Windows To...
每天使用手机超过5小时,会发生... 刷手机这事 估计没人能逃得过 上班路上刷几条热搜 吃饭时配一段短视频 睡前躺在床上翻朋友圈、看抖音 ...
硅谷正在流行“氛围办公”:不敲... 这个春天开始,硅谷的办公室里,敲打键盘的哒哒声正在被嘀嘀咕咕的人声取代。 有风险投资人调侃,现在去硅...
抵达!神舟二十三号载人飞船与空... 据中国载人航天工程办公室消息,神舟二十三号载人飞船入轨后,于北京时间2026年5月25日2时45分,...
神舟二十三号载人飞船发射取得圆... 5月24日,搭载神舟二十三号载人飞船的长征二号F遥二十三运载火箭在酒泉卫星发射中心点火发射。神舟二十...