使用的mysql版本:mysql4.0.X
master: 192.168.1.102
slave: 192.168.1.109
如果是win机子修改c:\winnt\my.ini 如果是linux的机子请修改 /etc/my.cnf
一、master操作
1、修改my.ini
##############
server-id=1
log-bin=c:\mysql\logs\mysql_binary_log
binlog-do-db=test
binlog-ignore-db=mysql
##############
说明
binlog-do-db=test 允许同步的数据库
binlog-ignore-db=mysql 不允许同步的数据库
2、然后重启mysql
c:\mysql\bin\mysql restart 或 /etc/init.d/mysql restart
3、在master上增加一个同步的用户名
mysql> GRANT REPLICATION SLAVE ON *.* TO 'backup'@'%' IDENTIFIED BY '123456';
注:
如果mysql版本在4.0.2以前的版本请用
mysql> GRANT FILE ON *.* TO 'backup'@'%' IDENTIFIED BY '123456';
4、接下来操作要master上要同步的数据库
mysql> USE test;
mysql> FLUSH TABLES WITH READ LOCK; #锁定要同步的test表,然后导出数据结构
执行如下命令查看master的状态
mysql> SHOW MASTER STATUS;
得到如下结果
Code:
+----------------------+----------+--------------+------------------+
| File | Position | Binlog_do_db | Binlog_ignore_db |
+----------------------+----------+--------------+------------------+
| mysql_binary_log.025 | 796947 | test | mysql |
+----------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
接下来备份要同步数据库(为导入slave作准备)
$ mysqldump --opt test > test.sql
mysql> UNLOCK TABLES; #已做好同步数据库结构导出后,解锁这个表
二、slave操作
1、把master里导出的同步数据库结构再导入slave的mysql里
mysql tes < test.sql
2、修改slave的my.ini
####################
log-bin=c:\mysql\logs\mysql_binary_log
server-id=2
master-host=192.168.1.102
master-user=backup
master-password=123456
master-connect-retry=60
replicate-do-db=test
####################
说明:
master-host=192.168.1.102 #master的IP
master-user=backup #master上作为同步用的用户名
master-password=123456 #同步用户名的密码
master-connect-retry=60 #设置同步的时间
replicate-do-db=test #需要同步的数据库
3、重新启用mysql
c:\mysql\bin\mysql restart 或 /etc/init.d/mysql restart
4、进入slave的mysql,对mysql进行操作
mysql> stop slave; #停止slave服务器
mysql> CHANGE MASTER TO
-> MASTER_HOST='192.168.1.102',
-> MASTER_USER='backup',
-> MASTER_PASSWORD='123456',
-> MASTER_LOG_FILE='mysql_binary_log.025',
-> MASTER_LOG_POS=796947;
mysql> START SLAVE; #开启slave服务器就可以同步了
注:
MASTER_LOG_FILE='mysql_binary_log.025',
MASTER_LOG_POS=796947;
上面这两条是一开始从master上进入mysql,运行 SHOW MASTER STATUS; 查看到的,在实际操作中也可以不加的。
##############################################
在master的mysql里运行
mysql > show processlist;
看到两个 system user 就是正常的
+----+-------------+----------------+------+-------------+------+---------------
--------------------------------------------------------+------------------+
| Id | User | Host | db | Command | Time | State
| Info |
+----+-------------+----------------+------+-------------+------+---------------
--------------------------------------------------------+------------------+
| 1 | system user | | NULL | Connect | 4499 | Waiting for ma
ster to send event | NULL |
| 2 | system user | | NULL | Connect | 4499 | Has read all r
elay log; waiting for the I/O slave thread to update it | NULL |
| 7 | root | localhost:1309 | test | Query | 0 | NULL
| show processlist |
| 40 | backup | ETE-KF2:1354 | NULL | Binlog Dump | 513 | Has sent all b
inlog to slave; waiting for binlog to be updated | NULL |
+----+-------------+----------------+------+-------------+------+---------------
--------------------------------------------------------+------------------+
4 rows in set (0.00 sec)
mysql> show master status;
出现如下:
+----------------------+----------+--------------+------------------+
| File | Position | Binlog_do_db | Binlog_ignore_db |
+----------------------+----------+--------------+------------------+
| mysql_binary_log.001 | 1011 | test | mysql |
+----------------------+----------+--------------+------------------+
在slave的mysql里运行
mysql> show processlist;
出现如下:
+----+-------------+----------------+------+---------+------+-------------------
----------------------------------------------------+------------------+
| Id | User | Host | db | Command | Time | State
| Info |
+----+-------------+----------------+------+---------+------+-------------------
----------------------------------------------------+------------------+
| 3 | root | localhost:1353 | test | Query | 0 | NULL
| show processlist |
| 4 | system user | | NULL | Connect | 740 | Waiting for master
to send event | NULL |
| 5 | system user | | NULL | Connect | 730 | Has read all relay
log; waiting for the I/O slave thread to update it | NULL |
+----+-------------+----------------+------+---------+------+-------------------
----------------------------------------------------+------------------+
3 rows in set (0.00 sec)
mysql> show slave status;
+---------------+-------------+-------------+---------------+-------------------
---+---------------------+-----------------------+---------------+--------------
---------+------------------+-------------------+-----------------+-------------
--------+------------+------------+--------------+---------------------+--------
---------+
| Master_Host | Master_User | Master_Port | Connect_retry | Master_Log_File
| Read_Master_Log_Pos | Relay_Log_File | Relay_Log_Pos | Relay_Master_
Log_File | Slave_IO_Running | Slave_SQL_Running | Replicate_do_db | Replicate_ig
nore_db | Last_errno | Last_error | Skip_counter | Exec_master_log_pos | Relay_l
og_space |
+---------------+-------------+-------------+---------------+-------------------
---+---------------------+-----------------------+---------------+--------------
---------+------------------+-------------------+-----------------+-------------
--------+------------+------------+--------------+---------------------+--------
---------+
| 192.168.1.102 | backup | 3306 | 10 | mysql_binary_log.0
01 | 1011 | ete-kf2-relay-bin.002 | 227 | mysql_binary_
log.001 | Yes | Yes | test |
| 0 | | 0 | 1011 | 223
|
+---------------+-------------+-------------+---------------+-------------------
---+---------------------+-----------------------+---------------+--------------
---------+------------------+-------------------+-----------------+-------------
--------+------------+------------+--------------+---------------------+--------
---------+
1 row in set (0.00 sec)
参考文档:
http://forums.gentoo.org/viewtopic.php?t=241123
http://www.howtoforge.com/mysql_database_replication_p2
http://dev.mysql.com/doc/refman/4.1/en/replication-howto.html
http://bbs.chinaunix.net/viewthread.php?tid=692359&highlight=mysql
分享到:
相关推荐
一个mysql数据库数据同步至oracle数据库代码,同时修改mysql数据表标识。
特别有用的MySQL数据实时同步到ES轻松配置手册 特别有用的MySQL数据实时同步到ES轻松配置手册
SpringBoot定时任务实现Oracle和mysql数据同步
使用Kettle同步mysql数据,增量同步,两个数据库数据同步
mysql历史数据同步到clickhouse 已测试
两个mysql数据库之间实现同步,通过定时任务实现从主库到从库的同步,java代码实现,所有java项目包括配置都有,数据结构可以跟据自己的特定情况去改
Java开发springboot-整合mysql-binlog-connector-java实现MySQL数据同步-源代码+文档 Java开发springboot-整合mysql-binlog-connector-java实现MySQL数据同步-源代码+文档 Java开发springboot-整合mysql-binlog-...
易语言mssql和mysql数据自动同步源码,mssql和mysql数据自动同步,RefreshTask,ComputeEndTime,ComputeOneTime,ComputeTimeInte,ComputeWeekOneTime,ComputeWeekTimeInte,ComputeMonthOneTime,ComputeMonthTimeInte,...
shell脚本 同步mysql数据的一种实现方式,简单配置即可使用
使用Kettle同步mysql数据,增量同步,两个数据库数据同步
Mysql5.7数据同步配置文档.Forwin系统
详细讲解Sql Server 数据实时同步到Mysql的操作步骤以及注意事项,采完坑后的总结 步骤1:创建需要同步的数据库和表 步骤2:安装Mysql Connector 步骤3:配置Mysql ODBC数据源 ......
MySQL 双向数据同步解决方案,暂时没有验证
canal实现mysql到ES数据实时同步
{ job: { setting: { speed: { channel: 1 }, errorLimit: { record: 0, percentage: 0.02 } }, content: [ { reader: {
后台jdbc java 增删改查 数据同步
win2003下MySQL数据同步配置文档,这个已经做过测试!
MySQL数据库做主从同步的方案,特点是异步复制,广泛用在各种对MySQL有更高性能、更高可靠性要求的场合
XXXKETTLE全量多表数据同步 1 一. 建立资料库 3 1.1 添加资源库 3 二. 前期准备工作 7 2.1 异结构数据传输 7 2.2 数据校验 9 三. 建立转换 10 3.1 创建‘转换’(GET—ORACLE-TABLES) 10 3.1.1 创建数据源 10 3.1.2...
分别有:数据源配置、数据表结构转换、字段更新、数据迁移、根据oracle SQL的UPDATE DELETE 事物执行记录转为Mysql可执行SQL,同步执行到MySql数据库,此项目为个人兴趣爱好练手项目,项目问题欢迎留言,共同进步...