Home Database Mysql Tutorial MySQL 数据库双主改造

MySQL 数据库双主改造

Jun 07, 2016 pm 03:46 PM
mysql use Transformation database

对于使用中的已有了一些数据库的 MySQL, 如何改造成双主呢? 这里写一篇文章, 详细记录操作步骤. 听取各位的意见. 这里假设有两台服务器: A 和 B. 要让他们互为主, 但实际使用时, 不同的服务器只服务不同的 db, 避免出现数据冲突. 1. 修改 nginx 配置, 挂维护

对于使用中的已有了一些数据库的 MySQL, 如何改造成双主呢? 这里写一篇文章, 详细记录操作步骤. 听取各位的意见.

这里假设有两台服务器: A 和 B. 要让他们互为主, 但实际使用时, 不同的服务器只服务不同的 db, 避免出现数据冲突.

1. 修改 nginx 配置, 挂维护页

这一步很重要. 你需要告诉你的用户, 你的网站在维护, 同时要确保不会再出现数据库写操作.

另外, 还要停止 crontab 任务.

2. 备份数据库

Server A:

<span>mysqldump </span><span>-</span><span>uroot </span><span>-</span><span>p </span><span>--</span><span>all</span><span>-</span><span>databases </span><span>></span><span> a_dbdump_all</span><span>.</span><span>sql
gzip a_dbdump_all</span><span>.</span><span>sql</span>
Copy after login

Server B:

<span>mysqldump </span><span>-</span><span>uroot </span><span>-</span><span>p </span><span>--</span><span>all</span><span>-</span><span>databases </span><span>></span><span> b_dbdump_all</span><span>.</span><span>sql
gzip b_dbdump_all</span><span>.</span><span>sql</span>
Copy after login

把线上数据库备份到本地

<span>scp test@server_a</span><span>:~/</span><span>a_dbdump_all</span><span>.</span><span>sql</span><span>.</span><span>gz </span><span>.</span><span>
scp test@server_b</span><span>:~/</span><span>b_dbdump_all</span><span>.</span><span>sql</span><span>.</span><span>gz </span><span>.</span>
Copy after login

3. 新建数据库同步账号

Server A:

<span>GRANT REPLICATION SLAVE ON </span><span>*.*</span><span> TO </span><span>'userx'</span><span>@</span><span>'server_b'</span><span> IDENTIFIED BY </span><span>'xxxxx'</span><span>;</span>
Copy after login

Server B:

<span>GRANT REPLICATION SLAVE ON </span><span>*.*</span><span> TO </span><span>'userx'</span><span>@</span><span>'server_a'</span><span> IDENTIFIED BY </span><span>'xxxxx'</span><span>;</span>
Copy after login

4. 导数据

这一步是手工将两台服务器数据库(基准数据)同步.

Server A:

<span>mysqldump </span><span>-</span><span>uroot </span><span>-</span><span>p </span><span>--</span><span>databases db1 </span><span>></span><span> a_dbdump</span><span>.</span><span>sql
scp a_dbdump</span><span>.</span><span>sql test@server_b</span><span>:~</span>
Copy after login

Server B:

<span>mysqldump </span><span>-</span><span>uroot </span><span>-</span><span>p </span><span>--</span><span>databases db2 </span><span>></span><span> b_dbdump</span><span>.</span><span>sql
scp b_dbdump</span><span>.</span><span>sql test@server_a</span><span>:~</span>
Copy after login

Server A:

<span>source b_dbdump</span><span>.</span><span>sql</span>
Copy after login

Server B:

<span>source a_dbdump</span><span>.</span><span>sql</span>
Copy after login

5. 修改 mysql 配置

Server A:

<span>[</span><span>mysqld</span><span>]</span><span>
server</span><span>-</span><span>id</span><span>=</span><span>1</span><span>
log</span><span>-</span><span>bin</span><span>=</span><span>mysql</span><span>-</span><span>bin
log</span><span>-</span><span>slave</span><span>-</span><span>updates
binlog</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>mysql
binlog</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>test
binlog</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>information_schema
binlog</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>performance_schema
replicate</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>mysql
replicate</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>test
replicate</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>information_schema
replicate</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>performance_schema
master</span><span>-</span><span>connect</span><span>-</span><span>retry</span><span>=</span><span>10</span><span>Server</span><span> B</span><span>:</span><span>[</span><span>mysqld</span><span>]</span><span>
server</span><span>-</span><span>id</span><span>=</span><span>2</span><span>
log</span><span>-</span><span>bin</span><span>=</span><span>mysql</span><span>-</span><span>bin
log</span><span>-</span><span>slave</span><span>-</span><span>updates
binlog</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>mysql
binlog</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>test
binlog</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>information_schema
binlog</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>performance_schema
replicate</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>mysql
replicate</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>test
replicate</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>information_schema
replicate</span><span>-</span><span>ignore</span><span>-</span><span>db</span><span>=</span><span>performance_schema
master</span><span>-</span><span>connect</span><span>-</span><span>retry</span><span>=</span><span>10</span>
Copy after login

注意, 他们的 server-id 不相同.

6. 重启 MySQL, 测试同步账号可用

重启 MySQL.

Server A:

<span>mysql </span><span>-</span><span>hserver_b </span><span>-</span><span>uuserx </span><span>-</span><span>pxxxxx</span>
Copy after login

Server B:

<span>mysql </span><span>-</span><span>hserver_a </span><span>-</span><span>uuserx </span><span>-</span><span>pxxxxx</span>
Copy after login

7. 启动 Slave 线程

Server A:

<span>FLUSH TABLES</span><span>;</span><span>
show master status</span><span>;</span>
Copy after login

会显示这样的信息.

<span>***************************</span><span>1.</span><span> row </span><span>***************************</span><span>File</span><span>:</span><span> mysql</span><span>-</span><span>bin</span><span>.</span><span>000001</span><span>Position</span><span>:</span><span>106</span><span>Binlog_Do_DB</span><span>:</span><span>Binlog_Ignore_DB</span><span>:</span><span> mysql</span><span>,</span><span>test</span><span>,</span><span>information_schema</span><span>,</span><span>performance_schema
</span><span>1</span><span> row </span><span>in</span><span>set</span><span>(</span><span>0.00</span><span> sec</span><span>)</span>
Copy after login

记录 File 和 Position, 这时 binlog 的当前位置, 因为 Slave 要从这个位置开始同步数据.

Server B:

<span>CHANGE MASTER TO MASTER_HOST</span><span>=</span><span>'server_a'</span><span>;</span><span>
CHANGE MASTER TO MASTER_USER</span><span>=</span><span>'userx'</span><span>;</span><span>
CHANGE MASTER TO MASTER_PASSWORD</span><span>=</span><span>'xxxxx'</span><span>;</span><span>
CHANGE MASTER TO MASTER_LOG_FILE</span><span>=</span><span>'mysql-bin.000001'</span><span>,</span><span> MASTER_LOG_POS</span><span>=</span><span>106</span><span>;</span><span>
start slave</span><span>;</span><span>
show slave status\G</span>
Copy after login

同样的, 在 Server A 上也启动同步 Slave 进程.

因为我们确保了没有数据库写操作, 所以不需要 FLUSH TABLES WITH READ LOCK;.

8. 验证

在不同的数据库上执行一些更新数据的操作, 看看数据是否同步过去了.

9. 完成

恢复 crontab 任务
修改 nginx, 撤下维护网页, 恢复服务
如果你有什么问题, 或者发现里这些步骤的不足, 欢迎评论!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Repo: How To Revive Teammates
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to optimize MySQL query performance in PHP? How to optimize MySQL query performance in PHP? Jun 03, 2024 pm 08:11 PM

MySQL query performance can be optimized by building indexes that reduce lookup time from linear complexity to logarithmic complexity. Use PreparedStatements to prevent SQL injection and improve query performance. Limit query results and reduce the amount of data processed by the server. Optimize join queries, including using appropriate join types, creating indexes, and considering using subqueries. Analyze queries to identify bottlenecks; use caching to reduce database load; optimize PHP code to minimize overhead.

How to use MySQL backup and restore in PHP? How to use MySQL backup and restore in PHP? Jun 03, 2024 pm 12:19 PM

Backing up and restoring a MySQL database in PHP can be achieved by following these steps: Back up the database: Use the mysqldump command to dump the database into a SQL file. Restore database: Use the mysql command to restore the database from SQL files.

How to insert data into a MySQL table using PHP? How to insert data into a MySQL table using PHP? Jun 02, 2024 pm 02:26 PM

How to insert data into MySQL table? Connect to the database: Use mysqli to establish a connection to the database. Prepare the SQL query: Write an INSERT statement to specify the columns and values ​​to be inserted. Execute query: Use the query() method to execute the insertion query. If successful, a confirmation message will be output.

How to use MySQL stored procedures in PHP? How to use MySQL stored procedures in PHP? Jun 02, 2024 pm 02:13 PM

To use MySQL stored procedures in PHP: Use PDO or the MySQLi extension to connect to a MySQL database. Prepare the statement to call the stored procedure. Execute the stored procedure. Process the result set (if the stored procedure returns results). Close the database connection.

How to create a MySQL table using PHP? How to create a MySQL table using PHP? Jun 04, 2024 pm 01:57 PM

Creating a MySQL table using PHP requires the following steps: Connect to the database. Create the database if it does not exist. Select a database. Create table. Execute the query. Close the connection.

How to fix mysql_native_password not loaded errors on MySQL 8.4 How to fix mysql_native_password not loaded errors on MySQL 8.4 Dec 09, 2024 am 11:42 AM

One of the major changes introduced in MySQL 8.4 (the latest LTS release as of 2024) is that the &quot;MySQL Native Password&quot; plugin is no longer enabled by default. Further, MySQL 9.0 removes this plugin completely. This change affects PHP and other app

iOS 18 adds a new 'Recovered' album function to retrieve lost or damaged photos iOS 18 adds a new 'Recovered' album function to retrieve lost or damaged photos Jul 18, 2024 am 05:48 AM

Apple's latest releases of iOS18, iPadOS18 and macOS Sequoia systems have added an important feature to the Photos application, designed to help users easily recover photos and videos lost or damaged due to various reasons. The new feature introduces an album called "Recovered" in the Tools section of the Photos app that will automatically appear when a user has pictures or videos on their device that are not part of their photo library. The emergence of the "Recovered" album provides a solution for photos and videos lost due to database corruption, the camera application not saving to the photo library correctly, or a third-party application managing the photo library. Users only need a few simple steps

Detailed tutorial on establishing a database connection using MySQLi in PHP Detailed tutorial on establishing a database connection using MySQLi in PHP Jun 04, 2024 pm 01:42 PM

How to use MySQLi to establish a database connection in PHP: Include MySQLi extension (require_once) Create connection function (functionconnect_to_db) Call connection function ($conn=connect_to_db()) Execute query ($result=$conn->query()) Close connection ( $conn->close())

See all articles