目次
、主库开启bin-log功能,配置server-id" >1、主库开启bin-log功能,配置server-id
、从库开启bin-log功能,配置server-id" >7、从库开启bin-log功能,配置server-id

Mysql主主同步详细操作过程

Jun 07, 2016 pm 02:53 PM
mysql 会社 同期する 操作する 詳しい プロセス

此处是在公司线上部署mysql双主时所记录的文档,为安全,IP都改为内网IP。 版本信息: # mysql -V mysql Ver 14.14 Distrib 5.5.37, fordebian-linux-gnu (x86_64) using readline 6.2 1 、主库开启 bin-log 功能,配置 server-id 修改my.cf配置文件,开启bi

 

此处是在公司线上部署mysql双主时所记录的文档,为安全,IP都改为内网IP。

版本信息:

#mysql -V

mysql  Ver 14.14 Distrib 5.5.37, fordebian-linux-gnu (x86_64) using readline 6.2

 

1、主库开启bin-log功能,配置server-id

修改my.cf配置文件,开启bin-log功能,配置server-id。

#cat /etc/mysql/my.cnf

[myqld]

server-id               = 1

log_bin                 =/var/log/mysql/

slave-net-timeout       = 60   

#salve-net-timeout默认是3600秒,缩短时间是为了防止双YES的假象

#(事实上我已遇到,参考地址:http://www.cnblogs.com/billyxp/p/3470376.html


如果要指定同步或不同步哪些库,可使用如下参数

#binlog-do-db=osyunweidb   #需要同步的数据库名,如果有多个数据库,可重复此参数,每个数据库一行
#binlog-ignore-db=mysql    #不同步mysql系统数据库

 

2、确认bin-logserver-id是否开启:

查看命令 show variables like 'log_bin'; show variables like 'server_id';

mysql> show variables like 'log_bin';

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

|Variable_name | Value |

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

|log_bin       | ON   |

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

1 rowin set (0.00 sec)

mysql>show variables like 'server_id';

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

|Variable_name | Value |

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

|server_id     | 1     |

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

1 rowin set (0.00 sec)

 

3、创建复制授权用户

mysql> grant replication slave on *.* to replication@'%'identified by '123456'; #授权该用户对所有表都能进行复制

mysql>flush privileges;  #刷新权限

 

4、锁表,记录log-bin文件名和位置

mysql>flush tables with read lock;     #锁定所有表,此时数据库不能写入数据

QueryOK, 0 rows affected (0.05 sec)

 

mysql>show master status;      #查看最新bin-log文件及位置

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

|File                   | Position   | Binlog_Do_DB      | Binlog_Ignore_DB        |

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

|mysql-bin.000001       |  26314    |                   |                        |

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

1row in set (0.00 sec)

 

5、锁表状态全备mysql数据

由于退出当前mysql登陆窗口,锁表功能就失效,需克隆一个会话进行全备。

#mysqldump-uroot -p -A -B >/tmp/mysql_bak_2014_10_30.sql.gz

 

看下备份数据大小,确认备份成功。

#ls  -l /tmp/mysql_bak_2014_10_30.sql.gz

-rw-r--r--1 root root 339222 10月 3011:01 /tmp/mysql_bak_2014_10_30.sql.gz

 

6、解除锁表

mysql>unlock tables;

或直接quit退出即可。

 

7、从库开启bin-log功能,配置server-id

从库开启bin-log功能后,待会在主上在配置同步,互为主从就完成了。

#cat /etc/mysql/my.cnf

[myqld]

server-id               = 2

log_bin                 =/var/log/mysql/mysql-bin.log

slave-net-timeout       = 60   

#salve-net-timeout默认是3600秒,缩短时间是为了防止双YES的假象

#(参考地址:http://www.cnblogs.com/billyxp/p/3470376.html


#/etc/init.d/mysqlrestart

 

8、确认从库bin-logserver-id是否开启

查看命令 show variables like 'log_bin'; show variables like 'server_id';

mysql>show variables like 'log_bin';

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

|Variable_name | Value |

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

|log_bin       | ON    |

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

1row in set (0.00 sec)

mysql>show variables like 'server_id';

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

|Variable_name | Value |

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

|server_id     | 2     |

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

1row in set (0.00 sec)

 

9、从库导入主库的全备数据

在从库上解压数据。

#gzip-d mysql_bak_2014_10_30.sql.gz

登陆mysql导入数据

mysql>source /root/mysql_bak_2014_10_30.sql

 

10、记录从库bin-log信息

因为在从库导入全备数据时,此时主库与从库的内容是一致的,但是bin-log位置不一定一致。

mysql>show master status;      #查看最新bin-log文件及位置

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

|File                   |Position   | Binlog_Do_DB      | Binlog_Ignore_DB        |

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

|mysql-bin.000003       |  2328055   |                   |                        |

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

1row in set (0.00 sec)

 

11、从库设置同步主库

此处binlog文件与位置状态,是主库在步骤4锁表时show master status查看的位置状态。

 

CHANGE MASTER TO 

MASTER_HOST='10.0.0.2',

MASTER_PORT=8306,

MASTER_USER='replication',

MASTER_PASSWORD='123456',

MASTER_LOG_FILE='mysql-bin.000001',

MASTER_LOG_POS=26314;

 

12、开启从库同步并确认同步是否成功

使用start slave开启同步功能,使用show slave status\G查看同步是否成功

mysql>start slave;

QueryOK, 0 rows affected (0.00 sec)

mysql>show slave status\G   #\G不按表格输出

***************************1. row ***************************

               Slave_IO_State: Waiting formaster to send event

                  Master_Host: 10.0.0.2

                  Master_User: replication

                  Master_Port: 8306

                Connect_Retry: 60

              Master_Log_File: mysql-bin.000001

          Read_Master_Log_Pos: 136270

               Relay_Log_File:mysqld-relay-bin.000002

                Relay_Log_Pos: 72697

        Relay_Master_Log_File: mysql-bin.000001

             Slave_IO_Running:Yes

            Slave_SQL_Running:Yes

              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: 98758

              Relay_Log_Space: 110366

              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: 622   #查看主从同步延迟,延迟大则可能需要优化

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: 1

1row in set (0.00 sec)

 

#sql线程与IO线程都是YESslave配置成功。

 

13、主库设置同步从库

由于从库是全备导入,原先在主库上配置的复制帐户也同样导入,所以这里不用在从库上新授权复制用户。

从库上的binlog文件与位置状态,是从库在刚导入时show master status查看到的位置状态。

 

CHANGEMASTER TO 

MASTER_HOST='172.16.0.2',

MASTER_PORT=3306,

MASTER_USER='replication',

MASTER_PASSWORD='123456',

MASTER_LOG_FILE='mysql-bin.000003',

MASTER_LOG_POS=2328055;

#修改相应信息,直接把这些配置在mysql中粘贴即可。

 

 

14、开启同步并确认同步是否成功

使用start slave开启同步功能,使用show slave status\G查看同步是否成功

mysql>start slave;

QueryOK, 0 rows affected (0.00 sec)

 

mysql>show slave status\G

***************************1. row ***************************

               Slave_IO_State: Waiting formaster to send event

                  Master_Host: 172.16.0.2

                  Master_User: replication

                  Master_Port: 3306

                Connect_Retry: 60

              Master_Log_File: mysql-bin.000007

          Read_Master_Log_Pos: 107

               Relay_Log_File:mysqld-relay-bin.000006

                Relay_Log_Pos: 253

        Relay_Master_Log_File: mysql-bin.000007

             Slave_IO_Running: Yes

            Slave_SQL_Running:Yes

              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: 107

              Relay_Log_Space: 556

              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: 2

1row in set (0.00 sec)

 

#IO线程与sql线程都是正常。

 

15、互为主从测试

在两台mysql各创建一个库,看两边是否都能进行同步。

分别在主库上执行 create database test01;

从库上执行create database test02;

看两台数据库上执行show databases;,看是否都有test01表和test02表。

我的经过测试,双主测试成功。

 

 


このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

phpmyadminを開く方法 phpmyadminを開く方法 Apr 10, 2025 pm 10:51 PM

次の手順でphpmyadminを開くことができます。1。ウェブサイトコントロールパネルにログインします。 2。phpmyadminアイコンを見つけてクリックします。 3。MySQL資格情報を入力します。 4.「ログイン」をクリックします。

MySQL:世界で最も人気のあるデータベースの紹介 MySQL:世界で最も人気のあるデータベースの紹介 Apr 12, 2025 am 12:18 AM

MySQLはオープンソースのリレーショナルデータベース管理システムであり、主にデータを迅速かつ確実に保存および取得するために使用されます。その実用的な原則には、クライアントリクエスト、クエリ解像度、クエリの実行、返品結果が含まれます。使用法の例には、テーブルの作成、データの挿入とクエリ、および参加操作などの高度な機能が含まれます。一般的なエラーには、SQL構文、データ型、およびアクセス許可、および最適化の提案には、インデックスの使用、最適化されたクエリ、およびテーブルの分割が含まれます。

単一のスレッドレディスの使用方法 単一のスレッドレディスの使用方法 Apr 10, 2025 pm 07:12 PM

Redisは、単一のスレッドアーキテクチャを使用して、高性能、シンプルさ、一貫性を提供します。 I/Oマルチプレックス、イベントループ、ノンブロッキングI/O、共有メモリを使用して同時性を向上させますが、並行性の制限、単一の障害、および書き込み集約型のワークロードには適していません。

MySQLの場所:データベースとプログラミング MySQLの場所:データベースとプログラミング Apr 13, 2025 am 12:18 AM

データベースとプログラミングにおけるMySQLの位置は非常に重要です。これは、さまざまなアプリケーションシナリオで広く使用されているオープンソースのリレーショナルデータベース管理システムです。 1)MySQLは、効率的なデータストレージ、組織、および検索機能を提供し、Web、モバイル、およびエンタープライズレベルのシステムをサポートします。 2)クライアントサーバーアーキテクチャを使用し、複数のストレージエンジンとインデックスの最適化をサポートします。 3)基本的な使用には、テーブルの作成とデータの挿入が含まれ、高度な使用法にはマルチテーブル結合と複雑なクエリが含まれます。 4)SQL構文エラーやパフォーマンスの問題などのよくある質問は、説明コマンドとスロークエリログを介してデバッグできます。 5)パフォーマンス最適化方法には、インデックスの合理的な使用、最適化されたクエリ、およびキャッシュの使用が含まれます。ベストプラクティスには、トランザクションと準備された星の使用が含まれます

なぜMySQLを使用するのですか?利点と利点 なぜMySQLを使用するのですか?利点と利点 Apr 12, 2025 am 12:17 AM

MySQLは、そのパフォーマンス、信頼性、使いやすさ、コミュニティサポートに選択されています。 1.MYSQLは、複数のデータ型と高度なクエリ操作をサポートし、効率的なデータストレージおよび検索機能を提供します。 2.クライアントサーバーアーキテクチャと複数のストレージエンジンを採用して、トランザクションとクエリの最適化をサポートします。 3.使いやすく、さまざまなオペレーティングシステムとプログラミング言語をサポートしています。 4.強力なコミュニティサポートを提供し、豊富なリソースとソリューションを提供します。

Apacheのデータベースに接続する方法 Apacheのデータベースに接続する方法 Apr 13, 2025 pm 01:03 PM

Apacheはデータベースに接続するには、次の手順が必要です。データベースドライバーをインストールします。 web.xmlファイルを構成して、接続プールを作成します。 JDBCデータソースを作成し、接続設定を指定します。 JDBC APIを使用して、接続の取得、ステートメントの作成、バインディングパラメーター、クエリまたは更新の実行、結果の処理など、Javaコードのデータベースにアクセスします。

DockerによるMySQLを開始する方法 DockerによるMySQLを開始する方法 Apr 15, 2025 pm 12:09 PM

DockerでMySQLを起動するプロセスは、次の手順で構成されています。MySQLイメージをプルしてコンテナを作成および起動し、ルートユーザーパスワードを設定し、ポート検証接続をマップしてデータベースを作成し、ユーザーはすべての権限をデータベースに付与します。

Centosはmysqlをインストールします Centosはmysqlをインストールします Apr 14, 2025 pm 08:09 PM

CentOSにMySQLをインストールするには、次の手順が含まれます。適切なMySQL Yumソースの追加。 yumを実行して、mysql-serverコマンドをインストールして、mysqlサーバーをインストールします。ルートユーザーパスワードの設定など、MySQL_SECURE_INSTALLATIONコマンドを使用して、セキュリティ設定を作成します。必要に応じてMySQL構成ファイルをカスタマイズします。 MySQLパラメーターを調整し、パフォーマンスのためにデータベースを最適化します。

See all articles