您的位置:首页 > 数据库 > MySQL

第一章:Mysql负载均衡与主从复制实验

2015-11-13 11:51 597 查看

1 数据库主从复制

1.1 环境配置

MASTER数据库 ip:192.168.118.135

SLAVE数据库 ip: 192.168.118.137

保证主从3306端口互通.

1.2 MASTER数据库配置

1. 配置/etc/my.cnf配置文件

#给服务器起一个唯一的id(一般都配置ip的最后三位值)

server-id=135

#开启二进制日志

log-bin=mysql-bin

#指定日志格式

binlog-format=mixed

2. 重启数据库服务器

Service mysqld restart

3. 查询日志文件以及日志文件的段数



1.3创建相应的复制账号

replication slave, replication授权并且是所有数据库所有表,给repl用户。只在192.168.2.%服务器生效。

grant replication slave, replication client on *.* to repl@'192.168.118.%' identified by '111111'
flush privileges;

1.3 SLAVE数据库配置

1. 配置/etc/my.cnf配置文件

#服务器id

server-id=137

#从服务器中继日志

relay-log=mysql-relay

2. 重启数据库服务器

Service mysqld restart

3. 在从服务器通过语句指定要复制的主服务器(注意,可以一主多从,不可一从多主).

changemaster to

master_host='192.168.118.135',

master_user='repl',

master_password='111111',

master_log_file='mysql-bin.000001',

master_log_pos=491;

4. 启动SLAVE功能进行数据同步

Start slave

1.4 常用命令

常用语句:

show master status ; 查看master的状态, 尤其是当前的日志及位置

show slave status \G; 查看slave的状态.

reset slave ; 重置slave状态.

start slave ; 启动slave 状态(开始监听msater的变化)

stop slave; 暂停slave状态;

1.5 常见问题

1.主服务器的日志格式用哪种好?

有 statement,row, mixed3种,其中mixed是指前2种的混合.

以insert into xxtable values (x,y,z)为例,

影响: 1行,且为新增1行, 对于其他行没有影响.

这个情况,用row格式,直接复制磁盘上1行的新增变化.

以update xxtable set age=21 where name=’sss’;

这个情况,一般也只是影响1行. 用row也比较合适.

以过年发红包,全公司的人,都涨薪100元.

update xxtable set salary=salary+100;

这个语句带来的影响,是针对每一行的, 因此磁盘上很多row都发生了变化.

此处,适合就statment格式的日志.

2种日志,各有各的高效的地方,mysql提供了mixed类型.

可以根据语句的不同,而自动选择适合的日志格式.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: