mysql主从复制的实现步骤

作者:AaronHao1 时间:2024-01-18 02:50:25 

目录
  • mysql主从复制

  • mysql主从复制的方式

  • mysql主从复制的原理

  • mysql的主从配置的具体实现方式

    • 1、 Master配置

    • 2、 Slave配置

mysql主从复制

本来是在做sharding的,可是做好之后发现数据库的主从复制还没有做,所以在配置好了之后做了些记录:

mysql主从复制的方式

mysql主从复制有两种方式:基于日志(binlog)、基于GTID(全局事物标示符)本博文用的是基于日志(binlog)的复制。

mysql主从复制的原理

1、Master将数据记录到二进制日志中,也就是mysql配置文件my.cnf的log-bin指定的文件,这些记录叫做二进制日志事件。
2、Slave有两个线程,一个I/O线程,一个SQL线程。I/O线程请求Master,将得到的binlog日志写到relay log(中继日志) 文件中。
3、SQL 线程,会读取relay log文件中的日志,并解析成具体操作,来实现主从的操作一致,而最终数据一致。

mysql主从复制的实现步骤

mysql的主从配置的具体实现方式

1、 Master配置

(1) 修改mysql的my.cnf配置文件,这里比较坑爹的是我用的mysql版本没有my.cnf 配置文件,连my-default.cnf都没有,一般来说my.cnf在/etc目录下, my-default.cnf在/usr/local/mysql/support-files中。最终我在网上复制了一份my.cnf文件放在了/etc中(朋友们可以自己去网上找,有很多的)。
(2) my.cnf中需要修改的配置主要有开启日志功能,设置server_id保证其唯一性(不能跟从库一样),过滤需备份的数据库。


bash-3.2# vim /etc/my.cnf
# 设置server_id,不能重复,一般可以设置为主库的IP
server_id=81
# 备份过滤:需要备份的数据库,输出binlog
binlog-do-db=demo_ds_master
# 备份过滤:不需要备份的数据库,不输出
binlog-ignore-db=mysql
# 开启二进制日志,将主库数据记录到mysql-bin开头的日志文件中(可自定义)          
log-bin=mysql-bin
# 配置每个session的内存,在事物过程中用来存储二进制日志的缓存
binlog_cache_size=1M
# 主从复制的格式(mixed,statement,row 默认的是statement)
binlog_format=mixed
# 二进制日志自动删除/过期的天数,默认为0,不自动删除
expire_logs_days=7
# 用于跳过主从复制中遇到的所有错误或指定的错误类型,避免slave端的终端
# 1062:主键冲突(具体的参数可以去网上查询)
slave_skip_errors=1062

(3) 启动/重启Master数据库服务,登录数据库,创建数据同步用户,并授权


#授权这个机器可以备份主数据库的数据
mysql> GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'root'@'192.168.31.60' identified by 'password';
#然后刷新权限
mysql> flush privileges;
#查看配置的主库信息
mysql> show master status;

mysql主从复制的实现步骤 

(4) 主库数据备份,确保主从库的数据一致性


# 临时锁住表,设置只读权限
mysql> flush tables with read lock;
# 备份数据库
bash-3.2# mysqldump -uroot -p --add-drop-table demo_ds_master_1 > /tmp/demo_ds_master_1.sql;
# 解锁表
mysql> unlock table;

2、 Slave配置

(1) 修改从数据库mysql的my.cnf配置文件,添加从数据库的中继日志配置


[root@develop etc]# vim my.cnf
# 设置server_id,不能重复,这里设置的是从库的IP
server-id=60
# 开启从数据库中继日志,将主数据库的binlog写到relay log中,中继日志以hehe-mysql-relay-bin开头(可自定义)
relay_log=hehe-mysql-relay-bin
# 设置从数据库为只读权限,防止主从数据不一致
read_only=1

(2) 如果从库需要作为另一个库的主库的话,需要加上Master上的配置信息,并且加上log_slave_updates=1将Master的binlog记录到自己的binlog日志中。

mysql主从复制的实现步骤 

(3) 重启从库数据库,同步主库数据


# 运行主数据库的备份数据库
[root@develop etc]# mysql -uroot -p demo_ds_master_1 < /tmp/demo_ds_master_1.sql
# 登录从数据库
[root@develop etc]# mysql -uroot -p
# 设置该从节点的主节点
mysql> change master to master_host='192.168.31.80', master_user='root',master_password='password',
master_port=3306,
master_log_file='mysql-bin.000001',
master_log_pos=154;
# 开启主从同步
mysql> start slave;
# 查看主从同步状态
mysql> show slave status\G;
# 查看主从线程状态
mysql> show processlist\G;

mysql主从复制的实现步骤 

图片中显示如下,说明主从复制已经配置好了,下面主库插入数据就可以实现从库自动复制主库数据了。

  • Slave_IO_State: Waiting for master to send event

  • Slave_IO_Running: Yes

  • Slave_SQL_Running: Yes

来源:https://blog.csdn.net/shijiemozujiejie/article/details/80766633

标签:mysql,主从复制
0
投稿

猜你喜欢

  • flask的orm框架SQLAlchemy查询实现解析

    2021-03-25 08:47:51
  • TensorFlow卷积神经网络AlexNet实现示例详解

    2022-06-14 21:17:30
  • python3 logging日志封装实例

    2022-05-23 08:27:52
  • python中时间模块的基本使用教程

    2021-05-15 21:24:43
  • numpy中np.dstack()、np.hstack()、np.vstack()用法

    2021-08-27 11:47:42
  • vue项目运行或打包时,频繁内存溢出情况问题

    2024-05-02 16:53:45
  • 按钮在 IE 中两边被拉伸的 BUG

    2008-11-17 20:37:00
  • JS中switch的四种写法示例

    2024-06-05 10:02:20
  • 实战手记:让百万级数据瞬间导入SQL Server

    2010-06-07 14:13:00
  • Python算法中的时间复杂度问题

    2021-03-20 04:52:50
  • Python多线程的使用详情

    2023-05-29 15:13:36
  • Python 命令行非阻塞输入的小例子

    2023-12-09 19:48:29
  • Golang使用channel实现一个优雅退出功能

    2024-04-28 09:14:28
  • SQLServer导出数据到MySQL实例介绍

    2024-01-13 08:07:17
  • Oracle9i取得建表和索引的DDL语句

    2024-01-16 22:18:31
  • Python实现查找二叉搜索树第k大的节点功能示例

    2023-12-17 04:40:09
  • js省市联动效果完整实例代码

    2024-04-18 10:15:34
  • Django框架实现分页显示内容的方法详解

    2023-05-31 17:06:38
  • python 对dataframe下面的值进行大规模赋值方法

    2022-01-08 07:04:19
  • MySQL中Order By多字段排序规则代码示例

    2024-01-22 01:10:35
  • asp之家 网络编程 m.aspxhome.com