数据库教程:mysql主从复制的实现步骤

目录mysql主从复制mysql主从复制的方式mysql主从复制的原理mysql的主从配置的具体实现方式1、 master配置 2、 slave配置 mysql主从复制本来是在做sharding的,可

目录
  • 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 statusg;  # 查看主从线程状态  mysql> show processlistg;

mysql主从复制的实现步骤 

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

  • slave_io_state: waiting for master to send event
  • slave_io_running: yes
  • slave_sql_running: yes

到此这篇关于mysql主从复制的实现步骤的文章就介绍到这了,更多相关mysql主从复制内容请搜索<计算机技术网(www.ctvol.com)!!>以前的文章或继续浏览下面的相关文章希望大家以后多多支持<计算机技术网(www.ctvol.com)!!>!

需要了解更多数据库技术:mysql主从复制的实现步骤,都可以关注数据库技术分享栏目—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/dtteaching/887875.html

(0)
上一篇 2021年10月24日
下一篇 2021年10月24日

精彩推荐