第一章:Mysql负载均衡与主从复制实验
2015-11-13 11:51
597 查看
1 数据库主从复制
1.1 环境配置
MASTER数据库 ip:192.168.118.135SLAVE数据库 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类型.
可以根据语句的不同,而自动选择适合的日志格式.
相关文章推荐
- 辛星浅析mysql中的单词的局部修改
- 【原创】MySQL5.7 虚拟列实现表达式索引
- MySQL5.7 虚拟列实现表达式索引
- navicat for mysql的使用
- mysql学习心得转
- mysql伪序列实现-最简单方法
- VS 2013下实现通过数据实体模型使用MySql
- mysql密码的加密与解密
- MySQL单列索引和组合索引的区别介绍
- MySQL
- Mysql主从配置,实现读写分离
- 安全地关闭MySQL服务的教程
- Ubuntu Server 15.10 打开mysql远程访问(3306端口)
- Mysql学习笔记(二)
- Mysql学习笔记(一)
- Mysql配置及基础
- mysql夸库复制表命令
- Mac OSX环境下搭建本地服务器
- homebrew下载安装及mysql的下载安装
- Mac OS X 上搭建LAMP环境(续)