I am in the process of migrating 2 DB servers (Master & Slave) to two new DB Servers (Master and Slave)
DB1 - Master (production)
DB2 - Slave (production)
DB3 - New Master
DB4 - New Slave
Currently I have the replication set up as:
DB1 -> DB2
DB3 -> DB4
To get the production data replicated to the new servers, I'd like to get it "daisy chained" so that it looks like this:
DB1 -> DB2 -> DB3 -> DB4
Is this possible? When I run show master status; on DB2 (the production slave) the binlog possition never seems to change:
+------------------+----------+--------------+------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | +------------------+----------+--------------+------------------+ | mysql-bin.000020 | 98 | | | +------------------+----------+--------------+------------------+
I'm a bit confused as to why the binlog position is not changing on DB2, Ideally it will be the master to DB3.
-
Yes, it is possible. Realistically, you need a new snapshot of DB2 to build DB3. At that point, if you have a good position, you can either use than for DB4 or take another snapshot of DB3.
Don't forget to set unique
server_idfor each server.High Performance MySQL is a great book for referencing more advanced MySQL administration.
mmattax : @Warner DB2 is currently only a slave, but it's binlog position isn't changing... Do you know if that's normal?mmattax : @Warner - The slave (DB2) is up to date with the master, yet the binlog position isn't changing, what should I check?mmattax : @Warner Yes, I've confirmed that I can change data on DB1 and it's replicated to DB2, yet DB2's binlog position is the same.mmattax : @Warner, I think DB@ isn't logging slave updates, hence why the position isn't changing: http://dev.mysql.com/doc/refman/5.1/en/replication-options-slave.html#option_mysqld_log-slave-updatesFrom Warner -
yes - you can daisy-chain mysql servers, you can even make a circular replication with two or more machines in it. just remember to enable binloging on slave that also acts as master.
Warner : Circular replication is incredibly fragile. It's ill-advised under most circumstances.pQd : @Warner - this was just example of even more complicated replication setup.From pQd -
Yes, it is possible :) This is called "Master with Relay Slave" replication and there a lot of documents about it on the net.
I'd recommend you to take a look at the official documentation here.
Btw, also take a look at these slides. They've some hints about replication topologies.
Hope this helps.
From Marco Ramos -
The binlog on
DB2wasn't updating the slave updates. To daisy chain the replication, one must setlog-slave-updatesin my.conf.From mmattax -
Why not just add DB3 as a new slave, and then promote it to master when you're ready to make the switch? This would give you the temporary added benefit of having multiple slaves, and reduce or eliminate your downtime.
mmattax : @phuzion, that's exactly what I am doing...From phuzion
0 comments:
Post a Comment