分类:
2010-06-22 12:16:38
1、确保在主服务器和从服务器上安装的MySQL版本相同,并且最好是MySQL的最新稳定版本。
如果不一致,保证 $version(主服务器) >= $version(从服务器)
2、在主服务器上为复制设置一个连接账户。该账户必须授予REPLICATION SLAVE权限。如果账户仅用于复制(推荐这样做),则不需要再授予任何其它权限。
|
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 +---------------+----------+--------------+------------------+ | mysql-bin.003 +---------------+----------+--------------+------------------+ |
如果主服务器运行时没有启用--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、将第3步归档数据拷贝解压在从数据库的数据目录中。确保对这些文件和目录的权限正确。服务器 MySQL运行的用户必须能够读写文件,如同在主服务器上一样。
Shell> chown -R mysql:mysql /usr/local/mysql/data |
7、启动从服务器。在从服务器上执行下面的语句,用你的系统的实际值替换选项值:
mysql> CHANGE MASTER TO |
master_host_name为主服务器的hostname,需要在从服务器的/etc/hosts文件中标记
replication_user_name和replication_password参照第2步建立的用户名密码
recorded_log_file_name和recorded_log_position参照第3步中SHOW MASTER STATUS
8、启动从服务器线程:
mysql> START SLAVE; |
执行这些程序后,从服务器会连接主服务器,并补充自从快照以来发生的任何更新。
9、在主服务器上show processlist会看到有从服务器已经连接过来了
在从服务器上show processlist会看到有两个system user的进程:
| Id | User | Host | db | Command | Time | State | Info | ---------------------------------------------------------------------------- | 4 | system user | | NULL | Connect | 1750 | Waiting for master to send event | NULL | ---------------------------------------------------------------------------- | 5 | system user | | NULL | Connect | 1856 | Has read all relay log; waiting for the slave I/O thread to update it | NULL | |
10、在从服务器上show slave status\G;
|
说明复制正在运行
如果出现复制错误,从服务器的错误日志(/usr/local/mysql/data/${HOSTNAME}.err)中也会出现错误消息。
11、从服务器复制时,会在其数据目录中发现文件master.info和HOSTNAME-relay-log.info。从服务器使用这两个文件跟踪已经处理了多少主服务器的二进制日志。不要移除或编辑这些文件,除非你确切知你正在做什么并完全理解其意义。即使这样,最好是使用CHANGE MASTER TO语句。