Ubuntu12.04 下配置MySQL主从(实践)
2014-03-31 09:07
239 查看
测试时主从数据库mysql版本不一样,都是5.5的
环境:Ubuntu12.04 ,5.5.35-0ubuntu0.12.04.2-log
主服务器地址:192.168.1.116
从数据库地址:192.168.1.117
提示:主从同步前要求主从机上的数据库都存在且里面的数据相等
第一部分:配置主服务器
1./etc/mysql/my.cnf
[mysqld]
server-id=1
log-bin=log #这个很重要后面从服务器要用到
binlog-do-db=test1 #需要同步的数据库
binlog-ignore-db=mysql #被忽略的数据库
2:保存/etc/mysql/my.cnf文件,重启数据库,然后会在/var/lib/mysql/log.000011文件;
3:输入用户名和密码:mysql -u用户名 -p密码 ( mysql -uroot -proot )
4:给要连接的从服务器设置权限:grant all on *.* to 'slave'@'%' identified by '123456';
5:输入命令 show master status;
mysql> show master status;
+------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------+----------+--------------+------------------+
| log.000011 | 4234 | test1 | mysql |
+------------+----------+--------------+------------------+
# 找到File 和 Position 的值记录下来(这个很重要哦,在配置slave时要用到的呢);
第二部分:配置从服务器
1:找到/etc/mysql/my.cnf文件,在其[mysqld] 下添加从服务器端配置:
server-id=2 #服务器 id ,不能和主服务器一致
replicate-do-db=test1 #待同步的数据库
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
2:保存/etc/mysql/my.cnf文件,重启从数据库,在mysql5.1以上版本中是不支持1中master设置的,如果添加了master设置,数据库就无法重启了
4:从服务器上测试:mysql -u slave -p 123456 -h 192.168.1.116 (一定不要加分号,之前我是加分号所以一直提示无法连接)查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库
5:修改对主数据库的连接的参数:mysql>change master to master_host='192.168.1.116',master_user='slave',master_password='1234562', master_log_file='log.000011',master_log_pos=4234;
在这里一个要配置好master_log_file(配置主服务器第5步show master status中的log.000011) 和master_log_pos(配置主服务器第5步show master status中的4234)
ps:可能会报一个错误,大概的意思是说slave线程正在运行,不能设置,这样的话,执行mysql>stop slave; 停止slave线程,然后再设置连接的参数;
6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G (没有分号),查看
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
环境:Ubuntu12.04 ,5.5.35-0ubuntu0.12.04.2-log
主服务器地址:192.168.1.116
从数据库地址:192.168.1.117
提示:主从同步前要求主从机上的数据库都存在且里面的数据相等
第一部分:配置主服务器
1./etc/mysql/my.cnf
[mysqld]
server-id=1
log-bin=log #这个很重要后面从服务器要用到
binlog-do-db=test1 #需要同步的数据库
binlog-ignore-db=mysql #被忽略的数据库
2:保存/etc/mysql/my.cnf文件,重启数据库,然后会在/var/lib/mysql/log.000011文件;
3:输入用户名和密码:mysql -u用户名 -p密码 ( mysql -uroot -proot )
4:给要连接的从服务器设置权限:grant all on *.* to 'slave'@'%' identified by '123456';
5:输入命令 show master status;
mysql> show master status;
+------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------+----------+--------------+------------------+
| log.000011 | 4234 | test1 | mysql |
+------------+----------+--------------+------------------+
# 找到File 和 Position 的值记录下来(这个很重要哦,在配置slave时要用到的呢);
第二部分:配置从服务器
1:找到/etc/mysql/my.cnf文件,在其[mysqld] 下添加从服务器端配置:
server-id=2 #服务器 id ,不能和主服务器一致
replicate-do-db=test1 #待同步的数据库
binlog-ignore-db=mysql #忽略不同步的数据库,这个可以不用写
2:保存/etc/mysql/my.cnf文件,重启从数据库,在mysql5.1以上版本中是不支持1中master设置的,如果添加了master设置,数据库就无法重启了
4:从服务器上测试:mysql -u slave -p 123456 -h 192.168.1.116 (一定不要加分号,之前我是加分号所以一直提示无法连接)查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库
5:修改对主数据库的连接的参数:mysql>change master to master_host='192.168.1.116',master_user='slave',master_password='1234562', master_log_file='log.000011',master_log_pos=4234;
在这里一个要配置好master_log_file(配置主服务器第5步show master status中的log.000011) 和master_log_pos(配置主服务器第5步show master status中的4234)
ps:可能会报一个错误,大概的意思是说slave线程正在运行,不能设置,这样的话,执行mysql>stop slave; 停止slave线程,然后再设置连接的参数;
6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G (没有分号),查看
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
相关文章推荐
- MySql主从配置实践及其优势浅谈
- mysql主从配置实践
- Linux MySQL主从复制(Replication)实践配置
- mysql主从同步配置实践
- mysql主从配置与读写分离实践与思路
- Ubuntu12.04下MySQL主从配置
- mysql replication 基本原理,mysql主从配置原理
- MySQL的复制(Replication)与主从服务器的配置
- Mysql主从复制原理及配置
- MySQL 5.6 主从复制配置
- mysql主从复制和读写分离配置
- MySql高可用性HA主从配置(双主双从HA模式)
- mysql主从复制简单配置
- MySQL 5.7.14主从配置
- mysql主从配置出错
- 安装配置Mysql主从
- Spring+Hibernate框架下MySql读写分离,主从数据库配置
- Mysql之主从架构的复制原理及主从/双主配置详解(二)
- mysql5.6.x GTID主从复制配置
- MySQL主从服务器配置,读写分离【Master-Slave集群】