您的位置:首页 > 数据库 > MySQL

mysql主从复制配置

2010-11-19 16:51 513 查看
一,mysql主从复制原理:

Mysql的 Replication 是一个异步的复制过程,从一个 Mysql instace(我们称之为 Master)复制到另一个

Mysql instance(我们称之 Slave)。
在 Master 与 Slave之间的实现整个复制过程主要由三个线程来完成,其中两个线程(Sql线程和IO线程)在 Slave 端,另外一个线程(IO线程)在 Master

端。

要实现 MySQL 的 Replication ,首先必须打开 Master 端的Binary Log(mysql-bin.xxxxxx)功能,否则无法实现。因为整个复制过程实际上就是Slave从Master端获取该日志然后再在自己身上完全顺序的执行日志中所记录的各种操作。打开 MySQL 的 Binary Log 可以通过在启动 MySQL Server 的过程中使用

“—log-bin” 参数选项,或者在 my.cnf 配置文件中的 mysqld 参数组([mysqld]标识后的参数部分)增加“log-bin” 参数项。

MySQL 复制的基本过程如下:

  1. Slave 上面的IO线程连接上 Master,并请求从指定日志文件的指定位置(或者从最开始的日志)之后的日志内容;

2. Master 接收到来自 Slave 的 IO 线程的请求后,通过负责复制的 IO线程根据请求信息读取指定日志指定位置之后的日志信息,返回给 Slave 端的 IO

线程。返回信息中除了日志所包含的信息之外,还包括本次返回的信息在 Master 端的 Binary Log 文件的名称以及在 Binary

Log 中的位置;

3. Slave 的 IO 线程接收到信息后,将接收到的日志内容依次写入到 Slave 端的Relay Log文件(mysql-relay-bin.xxxxxx)的最末端,并将读取到的Master端的bin-log的文件名和位置记录到master-info文件中,以便在下一次读取的时候能够清楚的高速Master“我需要从某个bin-log的哪个位置开始往后的日志内容,请发给我”

 4. Slave 的 SQL 线程检测到 Relay Log 中新增加了内容后,会马上解析该 Log 文件中的内容成为在 Master

端真实执行时候的那些可执行的 Query 语句,并在自身执行这些 Query。这样,实际上就是在 Master 端和 Slave

端执行了同样的 Query,所以两端的数据是完全一样的。
[align=left] [/align]
[align=left] [/align]
[align=left]二。实验环境:[/align]
[align=left]master:node6,172.16.41.30[/align]
[align=left]slave:node2,172.16.41.25[/align]
[align=left] [/align]
[align=left]在master端执行以下操作:[/align]
[align=left]1)修改my.cnf文件:[/align]
[align=left] [/align]
[align=left]server-id = 1[/align]
[align=left]log-bin=mysql-bin[/align]
[align=left]binlog-do-db = audit (需要复制的数据库)[/align]
[align=left]binlog-ignore-db = information_schema (不需要复制的数据库)[/align]
[align=left]binlog-ignore-db = mysql[/align]
[align=left]binlog-ignore-db = test[/align]
[align=left] [/align]
[align=left]master-host = 192.168.0.189[/align]
[align=left]master-user =admin[/align]
[align=left]master-password = 12345678[/align]
[align=left]master-port = 3306[/align]
[align=left]replicate-do-db = audit[/align]
[align=left]master-connect-retry = 60[/align]
[align=left] [/align]
[align=left]2)创建要同步的数据库:[/align]
[align=left]本测试环境中用的是库audit[/align]
[align=left]create database audit;[/align]
[align=left] [/align]
[align=left]3)给用户授权[/align]
[align=left]从开始菜单中打开mysql5的命令行,输入正确的密码,进入mysql控制台命令行模式后,输入如下命令:[/align]

[align=left]授权给slave服务器node2(172.16.41.25)的admin用户拥有对所有库的复制数据的权限,该用户的密码设为12345678[/align]

[align=left]GRANT REPLICATION SLAVE ON *.* TO 'admin'@'172.16.41.25' IDENTIFIED BY '12345678';[/align]

[align=left]刷新权限设置[/align]

[align=left]FLUSH PRIVILEGES ;[/align]
[align=left] [/align]
[align=left]4)查看master上的post值:[/align]
mysql> show master status;

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

| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |

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

| mysql-bin.000004 | 922 | audit | |

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

1 row in set (0.00 sec)
[align=left] [/align]
[align=left]记住上面红色字体部分,slave配置时要使用的;[/align]
[align=left] [/align]
[align=left]在slave上的操作:[/align]
[align=left]1)修改my.cnf文件:[/align]
[align=left]server-id = 2 (不可和master一样)[/align]
[align=left]master-host = 172.16.41.30[/align]
[align=left]master-user = backup[/align]
[align=left]master-password = 12345678[/align]
[align=left]master-port = 3306[/align]
[align=left]replicate-do-db = audit[/align]
[align=left]master-connect-retry = 60[/align]
[align=left] [/align]
[align=left]log-bin=mysql-bin[/align]
[align=left]binlog-do-db = audit[/align]
[align=left]binlog-ignore-db = information_schema[/align]
[align=left]binlog-ignore-db = mysql[/align]
[align=left]binlog-ignore-db = test[/align]
[align=left] [/align]
[align=left]2)配置slave:[/align]
[align=left] 1。slave stop[/align]
2。 mysql> change master to master_host='172.16.41.30',master_user='admin', master_password='12345678', master_log_file='mysql-bin.000004', master_log_pos=922;
红色字体要和master上一致!!!
3。启动slave:
slave start
4。查看salve 状态:
mysql> show slave status\G

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

Slave_IO_State: Waiting for master to send event

Master_Host: 172.16.41.30

Master_User: admin

Master_Port: 3306

Connect_Retry: 60

Master_Log_File: mysql-bin.000004

Read_Master_Log_Pos: 922

Relay_Log_File: node2-relay-bin.000002

Relay_Log_Pos: 382

Relay_Master_Log_File: mysql-bin.000004

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

Replicate_Do_DB: audit

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

Relay_Log_Space: 537

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

Last_IO_Error: error connecting to master 'admin@172.16.41.30:3306' - retry-time: 60 retries: 86400

Last_SQL_Errno: 0

Last_SQL_Error:

1 row in set (0.00 sec)
ps:红色字体为yes,代表配置正确!
[align=left]测试:[/align]
[align=left]在master机器audit库中创建一个表看是否在slave上同步了![/align]
[align=left] [/align]
[align=left]进入audit库:[/align]
[align=left]use audit; [/align]
[align=left] 创建表:[/align]
[align=left]create table myte3 ( name char(20), weight int, sex enum('F','M') );[/align]
[align=left] [/align]
[align=left] [/align]
[align=left] [/align]
[align=left] [/align]本文出自 “shine_forever的博客” 博客,请务必保留此出处http://shineforever.blog.51cto.com/1429204/427596
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: