MySQL主从复制

一.无数据情况下:

准备工作,准备两台虚拟机

1.关闭防火墙,selinux

2.时间同步,修改时区:timedatectl  set-timezone   Asia/Shanghai

3.同步网络时间:ntpdate time.windows.com

4.修改主机名并做本地解析:hostnamectl set-hostname master(主服务器)

                                              hostnamectl set-hostname slave(从服务器)

                             本地解析:vi /etc/hosts       192.168.203.163   master

                                                                         192.168.203.164   slave

5.nat模式下 固定IP  /etc/sysconfig/network-scripts/ifcfg-ens33

清理环境【两台机器】

[root@slave ~]# yum -y erase `rpm -qa |  grep -E "mysql|mariadb"`
[root@slave ~]# rm -rf /etc/my*  /var/lib/mysql* /var/log/mysql*
#检查一下
[root@slave ~]# [[ ! -f /etc/my.cnf ]] && [[ ! -d /var/lib/mysql ]] && [[ ! -f /usr/bin/mysql ]] && echo "数据库已清除" || echo "数据库未清理"

安装MySQL

初始化数据库:systemctl start mysql

修改初始密码:mysqladmin -p"`awk '/temporary password/{p=$NF}END{print p}' /var/log/mysqld.log`" password '123'

(查找初始密码:`awk '/temporary password/{p=$NF}END{print p}' /var/log/mysqld.log)

配置MySQL主从

主库

1.创建binlog日志存放路径

[root@master ~]# mkdir -p /data/binlog

2.修改权限

[root@master ~]# chown -R mysql.mysql /data/binlog

3.修改MySQL配置文件

[root@master ~]# vim /etc/my.cnf
[mysqld]
server-id = 163
log-bin=/data/binlog/mysql-bin

4.重启mysql
[root@master ~]# systemctl restart mysqld


查询master状态

mysql> show master status\G

*************************** 1. row ***************************
             File: mysql-bin.000001
         Position: 596
     Binlog_Do_DB: 
 Binlog_Ignore_DB: 
Executed_Gtid_Set: 
1 row in set (0.01 sec)

授权账号:mysql> grant replication slave on *.* to 'replication'@'%' identified by"123";
刷新:mysql> flush privileges;

从库

1.修改MySQL配置文件

[mysqld]
server-id = 164   

2.重启mysql:[root@slave ~]# systemctl restart mysqld   

3.配置从库:

 mysql> change master to 
         -> master_host='master',
         -> master_port=3306,
         -> master_user='replication',
         -> master_password='Qianfeng@123456',
         -> master_log_file='mysql-bin.000001',
         -> master_log_pos=596;

4.启动slave: mysql> start slave;

? change master to 查看配置主库连接信息

5.查看slave状态:

mysql> show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: master
                  Master_User: replication
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000001
          Read_Master_Log_Pos: 596
               Relay_Log_File: slave-relay-bin.000002
                Relay_Log_Pos: 320
        Relay_Master_Log_File: mysql-bin.000001
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes

在此刻 Slave_IO_Running: Yes ,Slave_SQL_Running: Yes 都为yes则证明连接正常。                 

重新配置主从:mysql> stop slave;

                         mysql> reset slave;

二.有数据情况下:清理环境,重新初始化

主库

1.创建binlog日志存放路径:[root@master ~]# mkdir -p /data/binlog

2.修改权限:[root@master ~]# chown -R mysql.mysql /data/binlog

3.修改mysql配置文件:  [root@master ~]# vim /etc/my.cnf
                                        [mysqld]
                                        server-id = 163
                                        log-bin=/data/binlog/mysql-bin 

4.重启mysql:[root@master ~]# systemctl restart mysqld

从库

1.修改mysql配置文件:[root@slave ~]#  vim /etc/my.cnf
                                      [mysqld]
                                      server-id = 164 

2.重启mysql:[root@slave ~]#  systemctl restart mysqld  

主库:锁表备份,新开一个窗口去备份数据,备份完成以后解锁,添加复制账户

mysql> flush tables with read lock; 锁表

新开窗口备份操作

mysqldump -uroot -pQianfeng@123 -A --master-data > all.sql
mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%' identified by '123';

备份完成以后解锁


mysql> show master status\G
*************************** 1. row ***************************
             File: mysql-bin.000004
         Position: 589
     Binlog_Do_DB: 
 Binlog_Ignore_DB: 
Executed_Gtid_Set: 
mysql> unlock tables;

从库配置主从:导入主备份sql保证数据一致性

mysql> CHANGE MASTER TO
    -> MASTER_HOST='master',
    -> MASTER_USER='repl',
    -> MASTER_PASSWORD='123',
    -> MASTER_log_file=mysql-bin.000004,
    -> MASTER_log_pos=589;
mysql> show slave status\G

*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: master
                  Master_User: repl
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000004
          Read_Master_Log_Pos: 589
               Relay_Log_File: slave-relay-bin.000002
                Relay_Log_Pos: 802
        Relay_Master_Log_File: mysql-bin.000004
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL主从复制MySQL内建的复制功能,用于构建基于MySQL的大规模、高性能应用。它的主要目的是实现高性能、高可用性、可扩展性、灾难恢复、备份以及数据仓库等功能。主从复制的常见用途包括以下几种: 1. 数据备份和灾难恢复:通过将主服务器上的数据复制到一个或多个从服务器上,可以实现数据的备份和灾难恢复。当主服务器发生故障时,可以快速切换到从服务器来保证系统的可用性。 2. 负载均衡:通过将读操作分发到多个从服务器上,可以减轻主服务器的负载,提高系统的性能和可扩展性。 3. 数据分析和报表生成:通过将主服务器上的数据复制到一个或多个从服务器上,可以在从服务器上进行数据分析和报表生成,而不会影响主服务器的性能。 4. 数据分发:通过将主服务器上的数据复制到多个从服务器上,可以将数据分发到不同的地理位置或不同的应用程序中,以满足不同的需求。 在MySQL主从复制中,可以使用一些工具来简化配置和管理,比如MySQL-Proxy。MySQL-Proxy是MySQL官方开源项目,通过其自带的lua脚本进行SQL判断,但MySQL官方并不建议将MySQL-Proxy用于生产环境。此外,还需要在主服务器和从服务器上进行一些配置,如设置server-id、开启二进制日志、允许从服务器更新二进制日志等。还需要为从服务器授权复制权限,并通过show master status命令查看主服务器的状态信息。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [MySQL主从复制详细介绍](https://blog.csdn.net/qq_44590469/article/details/126340217)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [MySQL主从复制](https://blog.csdn.net/m0_62473957/article/details/124140928)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值