`
tiandirensoon
  • 浏览: 610732 次
文章分类
社区版块
存档分类
最新评论

配置MySQL主从复制

 
阅读更多

MySQL支持单向、异步复制,复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器。主服务器将更新写入二进制日志文件,并维护日志文件的一个索引以跟踪日志循环。当一个从服务器连接到主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置。从服务器接收从那时起发生的任何更新,然后封锁并等待主服务器通知下一次更新。

<wbr></wbr>

为什么使用主从复制?

1、主服务器/从服务器设置增加了健壮性。主服务器出现问题时,你可以切换到从服务器作为备份。

2、通过在主服务器和从服务器之间切分处理客户查询的负荷,可以得到更好的客户响应时间。但是不要同时在主从服务器上进行更新,这样可能引起冲突。

3、使用复制的另一个好处是可以使用一个从服务器执行备份,而不会干扰主服务器。在备份过程中主服务器可以继续处理更新。

<wbr></wbr>

MySQL使用3个线程来执行复制功能(其中1个在主服务器上,另两个在从服务器上。当发出START SLAVE时,从服务器创建一个I/O线程,以连接主服务器并让主服务器发送二进制日志。主服务器创建一个线程将二进制日志中的内容发送到从服务器。从服务器I/O线程读取主服务器Binlog Dump线程发送的内容并将该数据拷贝到从服务器数据目录中的本地文件中,即中继日志。第3个线程是SQL线程,从服务器使用此线程读取中继日志并执行日志中包含的更新。SHOW PROCESSLIST语句可以查询在主服务器上和从服务器上发生的关于复制的信息。

<wbr></wbr>

默认中继日志使用host_name-relay-bin.nnnnnn形式的文件名,其中host_name是从服务器主机名,nnnnnn是序列号。用连续序列号来创建连续中继日志文件,从000001开始。从服务器跟踪中继日志索引文件来识别目前正使用的中继日志。默认中继日志索引文件名为host_name-relay-bin.index。在默认情况,这些文件在从服务器的数据目录中被创建。中继日志与二进制日志的格式相同,并且可以用mysqlbinlog读取。当SQL线程执行完中继日志中的所有事件后,中继日志将会被自动删除。

<wbr></wbr>

从服务器在数据目录中另外创建两个状态文件--master.info和relay-log.info。状态文件保存在硬盘上,从服务器关闭时不会丢失。下次从服务器启动时,读取这些文件以确定它已经从主服务器读取了多少二进制日志,以及处理自己的中继日志的程度。

<wbr></wbr>

设置主从复制:

<wbr></wbr>

1、确保在主服务器和从服务器上安装的MySQL版本相同,并且最好是MySQL的最新稳定版本。

2、在主服务器上为复制设置一个连接账户。该账户必须授予REPLICATION SLAVE权限。如果账户仅用于复制(推荐这样做),则不需要再授予任何其它权限。

mysql> GRANT REPLICATION SLAVE ON *.*

<wbr><wbr><wbr> -&gt; <strong>TO 'replication'@'%.yourdomain.com' IDENTIFIED BY 'slavepass';</strong></wbr></wbr></wbr>

3、执行FLUSH TABLES WITH READ LOCK语句清空所有表和块写入语句:

mysql> FLUSH TABLES WITH READ LOCK;

保持mysql客户端程序不要退出。开启另一个终端对主服务器数据目录做快照。

shell> cd /usr/local/mysql/

shell> tar -cvf /tmp/mysql-snapshot.tar ./data

如果从服务器的用户账户与主服务器的不同,你可能不想复制mysql数据库。在这种情况下,应从归档中排除该数据库。你也不需要在归档中包括任何日志文件或者master.info或relay-log.info文件。

当FLUSH TABLES WITH READ LOCK所置读锁定有效时(即mysql客户端程序不退出),读取主服务器上当前的二进制日志名和偏移量值:

mysql > SHOW MASTER STATUS;

+---------------+----------+--------------+------------------+

| File<wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr> | Position | Binlog_Do_DB | Binlog_Ignore_DB |</wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

+---------------+----------+--------------+------------------+

| mysql-bin.003<wbr>| 73<wbr><wbr><wbr><wbr><wbr><wbr>| test<wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr> | manual,mysql <wbr><wbr><wbr> |</wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

+---------------+----------+--------------+------------------+

File列显示日志名,而Position显示偏移量。在该例子中,二进制日志值为mysql-bin.003,偏移量为73。记录该值。以后设置从服务器时需要使用这些值。它们表示复制坐标,从服务器应从该点开始从主服务器上进行新的更新。

如果主服务器运行时没有启用--logs-bin,SHOW MASTER STATUS显示的日志名和位置值为空。在这种情况下,当以后指定从服务器的日志文件和位置时需要使用的值为空字符串('')和4.

取得快照并记录日志名和偏移量后,回到前一中端重新启用写活动:

mysql> UNLOCK TABLES;

4、确保主服务器主机上my.cnf文件的[mysqld]部分包括一个log-bin选项。该部分还应有一个server-id=Master_id选项,其中master_id必须为1到232–1之间的一个正整数值。例如:

[mysqld]

log-bin

server-id=1

如果没有提供那些选项,应添加它们并重启服务器。

5、停止从服务器上的mysqld服务并在其my.cnf文件中添加下面的行:

[mysqld]

server-id=2

slave_id值同Master_id值一样,必须为1到232–1之间的一个正整数值。并且,从服务器的ID必须与主服务器的ID不相同。

6、将数据备据目录中。确保对这些文件和目录的权限正确。服务器 MySQL运行的用户必须能够读写文件,如同在主服务器上一样。

Shell> chown -R mysql:mysql /usr/local/mysql/data

7、启动从服务器。在从服务器上执行下面的语句,用你的系统的实际值替换选项值:

<wbr></wbr>

<wbr><wbr><wbr><wbr><wbr><wbr><wbr> mysql&gt; <strong> CHANGE MASTER TO</strong></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

<wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr> -&gt;<wbr><strong>MASTER_HOST='master_host_name',</strong></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

<wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>-&gt;<wbr><strong>MASTER_USER='replication_user_name',</strong></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

<wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr> -&gt;<wbr><strong>MASTER_PASSWORD='replication_password',</strong></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

<wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr> -&gt;<wbr><strong>MASTER_LOG_FILE='recorded_log_file_name',</strong></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

<wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr> -&gt;<wbr><strong>MASTER_LOG_POS=recorded_log_position;</strong></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

8、启动从服务器线程:

<wbr><wbr><wbr><wbr><wbr><wbr><wbr> mysql&gt; <strong> START SLAVE;</strong></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

执行这些程序后,从服务器应连接主服务器,并补充自从快照以来发生的任何更新。

9、如果出现复制错误,从服务器的错误日志(HOSTNAME.err)中也会出现错误消息。

10、从服务器复制时,会在其数据目录中发现文件master.info和HOSTNAME-relay-log.info。从服务器使用这两个文件跟踪已经处理了多少主服务器的二进制日志。不要移除或编辑这些文件,除非你确切知你正在做什么并完全理解其意义。即使这样,最好是使用CHANGE MASTER TO语句。

分享到:
评论

相关推荐

    docker配置mysql主从复制.docx

    以下是在Docker中配置MySQL主从复制的详细步骤: 1. **创建主服务器所需目录和配置**: - 创建目录 `/usr/local/mysqlData/master/cnfm` 和 `/usr/local/mysqlData/master/data`,分别用于存放配置文件和数据库...

    LNH_MySQL 08-不停主库一键批量配置MySQL主从复制方案.mp4

    LNH_MySQL 08-不停主库一键批量配置MySQL主从复制方案.mp4

    MySQL主从复制模式全面实践

    配置MySQL主从复制涉及以下几个关键步骤: 1. 启用主节点的二进制日志功能。 2. 设置从节点的连接信息,如主机名、用户名和密码。 3. 在主节点上创建一个用于复制的专用用户。 4. 在从节点上配置复制,使用`CHANGE ...

    mysql主从复制安装配置进阶.pptx

    MySQL 主从复制安装配置进阶 MySQL 主从复制是指将一个 MySQL 服务器(主服务器)中的数据实时同步到另一个 MySQL 服务器(从服务器)中,以提高数据库的高可用性和读写性能。在本文中,我们将详细介绍 MySQL 主从...

    配置MySQL主从复制.doc

    ### MySQL主从复制配置详解 #### 一、MySQL主从复制概述 MySQL主从复制是一种数据复制机制,通过该机制可以实现数据从一个MySQL服务器(主服务器)到另一个或多个MySQL服务器(从服务器)的数据同步。主从复制不仅...

    MySQL主从复制与读写分离

    3. **复制配置**: 配置MySQL主从复制涉及创建复制用户、设置binlog格式、启动复制线程等步骤。配置完成后,主库会生成一个初始同步点,如使用`CHANGE MASTER TO`命令指定。 4. **故障转移**: 如果主库出现故障,...

    MySQL主从复制与读写分离.docx

    1. 实现 MySQL 主从复制:打开三台 MySQL 服务器,配置相应 IP,实现时间同步。 2. 配置主服务器:配置主服务器的配置文件,添加授权用户,查看日志信息。 3. 配置从服务器:配置从服务器的配置文件,在从服务器中...

    mysql主从复制安装配置.pptx

    MySQL 主从复制安装配置 MySQL 主从复制是一种常用的数据库架构设计,旨在提高数据库的可用性、性能和安全性。在本文中,我们将详细介绍 MySQL 主从复制的安装配置过程。 MySQL 主从复制简介 MySQL 主从复制是...

    MySQL高级 主从复制——个人总结

    配置MySQL主从复制,需要按照以下步骤操作: - 配置master服务器: - 编辑my.ini配置文件(在Linux系统中是***f),确保开启binlog记录并设置server-id为唯一值。 - 重启MySQL服务使配置生效。 - 在master上创建...

    mysql 主从复制环境搭建

    在 Windows 环境下,搭建 MySQL 主从复制功能需要准备系统环境、安装 MySQL 服务、配置主从复制等步骤。 步骤一:准备系统环境 1. 准备一台 PC,安装 Windows XP 32 位操作系统。 2. 安装 MySQL 5.0。 步骤二...

    MySQL 主从复制模式全面实践

    MySQL主从复制模式是数据库领域内一种重要的数据同步机制,它能够让一台主数据库服务器(master)的数据实时复制到一个或多个从数据库服务器(slave)上。这种机制在数据库的高可用性、数据备份、读写分离以及负载...

    MySQL主从复制的常见拓扑、原理分析以及如何提高主从复制的效率总结

    - **命令简介**:`mysqlreplicate`是一个用于快速配置MySQL主从复制的工具,可以通过简单的命令行参数指定主服务器和从服务器的信息,实现快速部署。更多关于`mysqlreplicate`命令的使用细节,请参考[此链接]...

    MySQL主从复制搭建从入门到掌握

    ### MySQL主从复制搭建知识点详解 #### 一、MySQL主从复制概述 MySQL主从复制是一种数据同步机制,它能够将一个MySQL服务器(主服务器)的数据自动同步到一个或多个MySQL服务器(从服务器)。这种机制不仅可以提高...

    SpringBoot第 12 讲:SpringBoot+MySQL主从复制、读写分离

    总的来说,SpringBoot与MySQL的主从复制和读写分离是企业级应用中常见的数据库架构设计,通过合理配置和优化,可以显著提高系统的稳定性和响应速度。通过学习和实践这些知识,开发者能够更好地构建可扩展、高可用的...

    linux运维学习笔记:MySQL主从复制原理和实战.pdf

    在具体配置MySQL主从复制时,首先需要修改***f配置文件,设置log-bin来启用二进制日志记录,设置server-id来唯一标识每个MySQL服务器。接着,在主服务器上创建模拟数据,用于测试复制功能。然后,在从服务器上执行...

    MySQL主从复制.docx

    MySQL 主从复制是指在一个 MySQL 数据库集群中,通过配置将一台或多台 MySQL 服务器定义为主服务器(Master),其余服务器定义为从服务器(Slave)。主服务器负责接收客户端的写入请求,而从服务器则主要负责处理...

    MySQL主从配置详解.pdf

    配置MySQL主从复制可以带来许多好处,如分散查询负载、提升查询效率、数据备份和读写分离等,但同时也需要注意配置过程中的细节和可能出现的问题。掌握MySQL主从配置的知识对于维护高效、稳定和安全的数据库环境至关...

Global site tag (gtag.js) - Google Analytics