mysql数据库主从同步

花了2天,google了无数才配出来,见笑。

环境
主机:freeBSD8.2 + myslq5.1 ip:192.168.1.240(vm)
从机:freeBSD8.2 + mysql5.1 ip:192.168.1.121(vm)



主机设置:
创建从机访问帐号
flush privileges;(防止出现ERROR 1290(HY000)错误)
GRANT REPLICATION SLAVE ON *.* TO '帐号'@'主机' IDENTIFIED BY '密码';

修改my.cnf
server-id=1 #主机id
log-bin=mysql-bin #同步文件类型
binlog-do-db=backtest #同步数据库(可多行)
binlog-ignore-db=mysql #不同步数据库(可多行)

备份需要同步的数据库(备份之后不可再写入数据)

查看主机信息
show master status;

从机设置:
导入主机备份的数据库

停止从机mysql

修改my.cnf
server-id = 2 #从机id(不可重复)
master-host=192.168.1.240 #主机ip
master-user=backuser #备份用户
master-password=root #密码
master-port=3306  #端口
replicate-do-db=backtest  #备份数据库
replicate-ignore-db=mysql #不备份数据库
master-connect-retry=60   #主机断线后重新连接的时间
#character-set-server=utf-8 #中文字符集

打开从机mysql
停止slave服务
slave stop
根据主机信息设置从机信息
CHANGE MASTER TO
MASTER_HOST='192.168.1.240',
MASTER_USER='backuser',
MASTER_PASSWORD='root',
MASTER_LOG_FILE='mysql-bin.000001',
MASTER_LOG_POS=264;
打开slave服务
slave start



查看从机信息
show slave status\G
显示信息如下
       Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.1.240
                  Master_User: backuser
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000001
          Read_Master_Log_Pos: 264
               Relay_Log_File: freeBSD-relay-bin.000002
                Relay_Log_Pos: 251
        Relay_Master_Log_File: mysql-bin.000001
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
              Replicate_Do_DB: backtest
          Replicate_Ignore_DB: mysql
…………………………



如果有
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
说明配置成功

ps:配置时遇到的问题
修改my.inf时报Warning: World-writable config file '/etc/my.cnf' is ignored
原因:my.inf权限太高
处理:权限不可设成777,只能设成755

用mysql远程工具链接数据库报错
原因:没有开放远程链接功能
处理:在mysql里面输入如下命令:GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY' password' WITH GRANT OPTION;

ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
原因:用户表中root密码为空
处理:先停止mysql,转入安全模式,修改root密码
#/usr/local/etc/rc.d/mysql-server stop
# mysqld_safe --user=mysql --skip-grant-tables --skip-networking &
# mysql -u root mysql
mysql> UPDATE user SET Password=PASSWORD('newpassword') where USER='root' and

host='root' or host='localhost';//把空的用户密码都修改成非空的密码就行了。
mysql> FLUSH PRIVILEGES;
mysql> quit
# /usr/local/etc/rc.d/mysql-server restart
# mysql -uroot -p
Enter password: <输入新设的密码newpassword>

创建同步帐号时出现ERROR 1290(HY000)错误
原因:不明
处理:先flush privileges; 再用grant all 命令。
flush privileges;
GRANT REPLICATION SLAVE ON *.* TO 'backuser'@'192.168.1.121' IDENTIFIED BY 'root';

猜你喜欢

转载自li-hy2002.iteye.com/blog/1407813