http://www.tecmint.com/how-to-setup-mysql-master-slave-replication-in-rhel-centos-fedora/
The following tutorial aims to provide you a simple step-by-step guide for setting up MySQL (Master-Slave)Replication in RHEL 6.3/6.2/6.1/6/5.8, CentOS 6.3/6.2/6.1/6/5.8 and Fedora 17,16,15,14,13,12 using latestMySQL version. This guide is specially written for CentOS 6.3 Operating System, but also work with older version of Linux distributions with MySQL 5.x.
The MySQL Replication is very useful in terms of Data Security, Fail-over Solution, Database Backup from Slave, Analytics etc. We use the following things to carry the replication process. In your scenario it would be different.
- Working Linux OS like CentOS 6.3, RedHat 6.3 or Fedora 17
- Master and Slave are CentOS 6.3 Linux Servers.
- Master IP Address is: 192.168.1.1.
- Slave IP Address is: 192.168.1.2.
- Master and Slave are on the same LAN network.
- Master and Slave has MySQL version installed.
- Master allow remote MySQL connections on port 3306.
We have two servers, one is Master with IP (192.168.1.1) and other is Slave as (192.168.1.2). We have divided the setup process in two phases to make things easier for you, In Phase I we will configure Master server and inPhase II with Slave server. Let’s start the replication setup process.
Phase I: Configure Master Server (192.168.1.1) for Replication
In Phase I, we will see the installation of MySQL, setting up Replication and then verifying replication.
Install a MySQL in Master Server
First, proceed with MySQL installation using YUM command. If you already have MySQL installation, you can skip this step.
Configure a MySQL in Master Server
Open my.cnf configuration file with VI editor.
Add the following entries under [mysqld] section and don’t forget to replace tecmint with database name that you would like to replicate on Slave.
Restart the MySQL service.
Login into MySQL as root user and create the slave user and grant privileges for replication. Replace slave_userwith user and your_password with password.
Please write down the File (mysql-bin.000003) and Position (11128001) numbers, we required these numbers later on Slave server. Next apply READ LOCK to databases to export all the database and master database information with mysqldump command.
Once you’ve dump all the databases, now again connect to mysql as root user and unlcok tables.
Upload the database dump file on Slave Server (192.168.1.2) using SCP command.
That’s it we have successfully configured Master server, let’s proceed to Phase II section.
Phase II: Configure Slave Server (192.168.1.2) for Replication
In Phase II, we do the installation of MySQL, setting up Replication and then verifying replication.
Install a MySQL in Slave Server
If you don’t have MySQL installed, then install it using YUM command.
Configure a MySQL in Slave Server
Open my.cnf configuration file with VI editor.
Add the following entries under [mysqld] section and don’t forget to replace IP address of Master server,tecmint with database name etc, that you would like to replicate with Master.
Now import the dump file that we exported in earlier command and restart the MySQL service.
Login into MySQL as root user and stop the slave. Then tell the slave to where to look for Master log file, that we have write down on master with SHOW MASTER STATUS; command as File (mysql-bin.000003) and Position (11128001) numbers. You must change 192.168.1.1 to the IP address of the Master Server, and change the user and password accordingly.
Verifying MySQL Replication on Master and Slave Server
It's really very important to know that the replication is working perfectly. On Master server create table and insert some values in it.
On Master Server
On Slave Server
Verifying the SLAVE, by running the same command, it will return the same values in the slave too.
That's it, finally you've configured MySQL Replication in a few simple steps. More information can be found atMySQL Replication Guide.