mysql数据库实现主从复制

服务器准备

主服务器:192.168.93.103
从服务器:192.168.93.102

主服务器操作

修改配置文件

[[email protected] ~]#vim /etc/my.cnf

[mysqld]
server_id=103                               //指定一个服务id,如果不写这里默认为1
log_bin=/data/mysql/bin/mysql-bin           //必须启动二进制日志
binlog_format=row                           //建议使用行row记录日志
innodb_file_per_table
datadir=/var/lib/mysql

创建主从复制用户

MariaDB [(none)]> grant replication slave on *.* to [email protected]‘192.168.93.%‘identified by ‘centos‘;

查看主服务器的二进制日志,记录要复制的位置

[[email protected] ~]#mysql -e ‘show master logs‘;
+------------------+-----------+
| Log_name         | File_size |
+------------------+-----------+
| mysql-bin.000002 |       288 |
| mysql-bin.000003 |       288 |
| mysql-bin.000004 |       442 |
| mysql-bin.000005 |       245 |
+------------------+-----------+

如何解决主从复制一台已存在大量数据的mysql服务器?

问题描述:如果一台mysql主服务器已经运行了一段时间,主服务器的数据量非常大,而主从复制时间会很长,对主服务器压力过大

解决办法:先在主服务器上创建完全备份,还原到从服务器上后,再做主从复制

完全备份数据库

[[email protected] ~]#mysqldump -A --single-transaction -F --master-data=1 > /data/backup/all.sql

查看记录二进制日志中要复制的位置信息

[[email protected] ~]#vim /data/backup/all.sql 

CHANGE MASTER TO MASTER_LOG_FILE=‘mysql-bin.000018‘, MASTER_LOG_POS=245;

在从服务器需要做的操作:
修改配置文件
将主服务器完全备份的数据库文件all.sql拷贝至从服务器

[[email protected] ~]#scp 192.168.93.102:/data/backup/all.sql  /data/backup

修改/data/backup/all.sql文件里完全备份位置语句:
CHANGE MASTER TO MASTER_LOG_FILE=‘mysql-bin.000018‘,MASTER_LOG_POS=245;
修改为:

vim /data/backup/all.sql

CHANGE MASTER TO
MASTER_HOST=‘192.168.93.103‘,
MASTER_USER=‘repluser‘,
MASTER_PASSWORD=‘centos‘,
MASTER_PORT=3306,
MASTER_LOG_FILE=‘mysql-bin.000018‘,
MASTER_LOG_POS=245;

然后导入all.sql文件

[[email protected] ~]# mysql < all.sql

启动主从同步线程

MariaDB [(none)]> start slave;

从服务器操作

修改配置文件

[[email protected] ~]# vim /etc/my.cnf

[mysqld]
server_id=102    //指定从服务器的服务id,不能不写,默认为1,此id不能与其他服务器冲突
read_only=ON        //设置数据库只读

使用有复制权限的用户账号连接至主服务器,配置同步信息

MariaDB [(none)]> CHANGE MASTER TO
MASTER_HOST=‘192.168.93.103‘,  //远程主服务器IP
MASTER_USER=‘repluser‘,             //主从复制的用户名
MASTER_PASSWORD=’centos’,         //密码
MASTER_PORT=3306,                 //端口号
MASTER_LOG_FILE=‘mysql-bin.000017‘,  //要复制的主服务器的二进制文件名
MASTER_LOG_POS=245;           //要开始复制的位置

启动复制线程

MariaDB [(none)]> start  slave;
Query OK, 0 rows affected (0.00 sec)

显示线程列表

MariaDB [(none)]> show processlist;
+----+-------------+-----------+------+---------+--------+-----------------------------------------------------------------------------+------------------+----------+
| Id | User        | Host      | db   | Command | Time   | State                                                                       | Info             | Progress |
+----+-------------+-----------+------+---------+--------+-----------------------------------------------------------------------------+------------------+----------+
|  3 | root        | localhost | NULL | Query   |      0 | NULL                                                                        | show processlist |    0.000 |
|  6 | system user |           | NULL | Connect |    264 | Waiting for master to send event                                            | NULL             |    0.000 |
|  7 | system user |           | NULL | Connect | -27302 | Slave has read all relay log; waiting for the slave I/O thread to update it | NULL             |    0.000 |
+----+-------------+-----------+------+---------+--------+-----------------------------------------------------------------------------+------------------+----------+
3 rows in set (0.00 sec)

显示主服务器的状态信息


MariaDB [(none)]> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.93.103
                  Master_User: repluser
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000017
          Read_Master_Log_Pos: 399
               Relay_Log_File: mariadb-relay-bin.000002
                Relay_Log_Pos: 683
        Relay_Master_Log_File: mysql-bin.000017
             Slave_IO_Running: Yes   //主从复制的线程IO
            Slave_SQL_Running: Yes   //主从复制的线程SQL
              Replicate_Do_DB:
          Replicate_Ignore_DB:
           Replicate_Do_Table:
       Replicate_Ignore_Table:
      Replicate_Wild_Do_Table:
  Replicate_Wild_Ignore_Table:
                   Last_Errno: 0
                   Last_Error:
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 399
              Relay_Log_Space: 979
              Until_Condition: None
               Until_Log_File:
                Until_Log_Pos: 0
           Master_SSL_Allowed: No
           Master_SSL_CA_File:
           Master_SSL_CA_Path:
              Master_SSL_Cert:
            Master_SSL_Cipher:
               Master_SSL_Key:
        Seconds_Behind_Master: 0         //主从复制的时间差
Master_SSL_Verify_Server_Cert: No
                Last_IO_Errno: 0
                Last_IO_Error:
               Last_SQL_Errno: 0
               Last_SQL_Error:
  Replicate_Ignore_Server_Ids:
             Master_Server_Id: 103
1 row in set (0.00 sec)

ERROR: No query specified

原文地址:https://blog.51cto.com/14233815/2390068

时间: 2024-11-13 08:50:52

mysql数据库实现主从复制的相关文章

MySQL数据库ab主从复制出错及解决过程

MySQL数据库ab主从复制出错及解决过程 一.mysql主从服务器报错描述:Slave_IO_Running=NO,Slave_SQL_Running=YES,Last_Errno=0 mysql slave stop ; mysql slave start; mysql show slave status ; 如果Slave_IO_Running=YES ...解决过程 :1 如果:Slave_IO_Running=NO,Slave_SQL_Running=YES,Last_Errno=0m

Mysql数据库的主从复制

怎么安装mysql数据库,这里不说了,只说它的主从复制,步骤如下: 1.主从服务器分别作以下操作:  1.1.版本一致  1.2.初始化表,并在后台启动mysql  1.3.修改root的密码 2.修改主服务器master:   #vi /etc/my.cnf       [mysqld]       log-bin=mysql-bin   //[必须]启用二进制日志       server-id=222      //[必须]服务器唯一ID,默认是1,一般取IP最后一段 3.修改从服务器sl

linux centos下mysql数据库的主从复制环境搭建

有两台MySQL数据库服务器Master和slave,Master为主服务器,slave为从服务器,初始状态时,Master和slave中的数据信息相同,当Master中的数据发生变化时,slave也跟着发生相应的变化,使得master和slave的数据信息同步,达到备份的目的. 原理图如下: 简单来说,mysql的主从复制的原理就是slave把master上面执行的 update,insert这些会使数据发生改变的sql语句从master上面同步过来,然后在自己的机器上再执行一遍,那么这两台数

MySQL 数据库的主从复制与读写分离

在实际生产环境中,如果对数据库的读和写都在同一个数据库服务器中操作,无论是安全性.高可用性,还是高并发等各个方面都是完全不能满足实际需求的,因此,一般来说都是通过主从复制(Master-Slave)的方式来同步数据,再通过读写分离来提升数据库的并发负载能力这样的方案来进行部署与实施. MySQL 的主从复制和读写分离两者有着紧密关联,首先要部署主从复制,才能在此基础上进行数据的读写分离. MySQL 主从复制的复制类型1) 基于语句的数据.在主服务器上执行的 SQL 语句,在从服务器上执行同样的

mysql 数据库的主从复制及备份、恢复

##远程登录MySql mysql -h62.234.124.229 -P31306 -ucrab -p123456 mysql --host=62.234.124.229 --user=yq --password=123456 ##给远程登录的用户授权: grant all on *.* to [email protected]'114.248.166.196' identified by '123456'; grant select,update,delete on *.* to [emai

mysql数据库的主从复制搭建与配置

环境: vmwareworkstation 10下布署两台Linux虚拟机作主,从服务器主机:主服务器:centos 7.6 mysql 5.6.45-log IP:10.11.18.190 从服务器:centos 7.6 mysql 5.6.45-log IP:10.11.18.193主服务器test数据库一:配置主服务器: 1:创建一个复制用户,具有replication slave 权限.Mysql>grant replication slave on . to 'slaveuser'@'

mysql(mariadb)数据库的主从复制

MySQL数据库的主从复制方案,是其自带的功能,并且主从复制并不是复制磁盘上的数据库文件,而是通过binlog日志复制到需要同步的从服务器上. MySQL数据库支持单向.双向.链式级联,等不同业务场景的复制.在复制的过程中,一台服务器充当主服务器(Master),接收来自用户的内容更新,而一个或多个其他的服务器充当从服务器(slave),接收来自Master上binlog文件的日志内容,解析出SQL,重新更新到Slave,使得主从服务器数据达到一致. 主从机制实现原理 (1) master将改变

Linux系统中MySQL数据库“主从”配置

MySQL数据库"主从"配置 一.配置概述: 在Linux操作系统中配置MySQL数据库的主从复制是很重要的,为什么这样说呢!是因为在你搭建一个服务器以后你配置了2台数据库,一主一从.2台数据库配置好以后,当其中一台数据库被攻击以后,你被攻击的这台数据库的数据会被自动的备份到另一台数据库中去.即使被攻击了数据也不会丢失.配置主从就是为了让web网站或其他的软件可以正常运转,确保数据的存在. 二.配置步骤: <配置具备的条件> 1.需要在虚拟机上安装好两台主机,同时安装好同一

Mysql数据库AB复制简单实现

Mysql 主 从 复 制 在实际企业应用环境当中,单台mysql数据库是不足以满足日后业务需求的.譬如服务器发生故障,没有备份服务器来提供服务的话,业务就得停止.介于这种情况,我们可以对mysql数据库进行主从复制,mysql直接的主从复制需版本相同,可以跨平台进行主从复制操作. 一.使用mysql主从复制的好处有: 1.采用主从服务器这种架构,稳定性得以提升.如果主服务器发生故障,我们可以使用从服务器来提供服务. 2.在主从服务器上分开处理用户的请求,可以提升数据处理效率. 3.将主服务器上