5、设置从服务器:
a.首先设置数据库的配置文件:
server-id=n //设置数据库id默认主服务器是1 //可以随便设置但是如果有多台从服务器则不能重复。 master-host=db-master.mycompany.com //主服务器的IP地址或者域名 master-port=3306 //主数据库的端口号 master-user=pertinax //同步数据库的用户 master-password=freitag //同步数据库的密码 master-connect-retry=60 //如果从服务器发现主服务器断掉,重新连接的时间差 report-host=db-slave.mycompany.com //报告错误的服务器
b.把从主数据库服务器备份出来的数据库导入到从服务器中;
c.然后启动从数据库服务器,如果启动的时候没有加上"--skip-slave-start"这个参数则进入到MySQL中:
MySQL> slave stop;//停止slave的服务
d.设置主服务器的各种参数:
MySQL> CHANGE MASTER TO -> MASTER_HOST='master_host_name', //主服务器的IP地址 -> MASTER_USER='replication_user_name', //同步数据库的用户 -> MASTER_PASSWORD='replication_password', //同步数据库的密码 -> MASTER_LOG_FILE='recorded_log_file_name', //主服务器二进制日志的文件名(前面要求记住的参数) -> MASTER_LOG_POS=recorded_log_position; //日志文件的开始位置(前面要求记住的参数)
e.启动同步数据库的线程:
MySQL> slave start;
查看数据库的同步情况吧。如果能够成功同步完成了。
f.查看主从服务器的状态:
MySQL> SHOW PROCESSLIST\G //可以查看MySQL的进程看看是否有监听的进程
如果日志太大清除日志的步骤如下:
1>.锁定主数据库:
MySQL> FLUSH TABLES WITH READ LOCK;
2>.停掉从数据库的slave:
MySQL> slave stop;
3>.查看主数据库的日志文件名和日志文件的position:
show master status; +---------------+----------+--------------+------------------+ | File | Position | Binlog_do_db | Binlog_ignore_db | +---------------+----------+--------------+------------------+ | louis-bin.001 | 79 | | MySQL | +---------------+----------+--------------+------------------+
4>.解开主数据库的锁:
MySQL> unlock tables;
5>.更新从数据库中主数据库的信息:
MySQL> CHANGE MASTER TO -> MASTER_HOST='master_host_name', //主服务器的IP地址 -> MASTER_USER='replication_user_name', //同步数据库的用户 -> MASTER_PASSWORD='replication_password', //同步数据库的密码 -> MASTER_LOG_FILE='recorded_log_file_name', //主服务器二进制日志的文件名(前面要求记住的参数) -> MASTER_LOG_POS=recorded_log_position; //日志文件的开始位置(前面要求记住的参数)
6>.启动从数据库的slave:
MySQL> slave start;