mysql主从配置(基于mysql5.5.x)
安装mysql数据库主从复制,步骤如下:
1、主从服务器分别作以下准备:
1.1、数据库版本完全一致
1.2、修改root的密码, 不改也可以
2、修改主服务器master
#vi /etc/my.cnf
[mysqld]
server-id=222 //[必须]服务器唯一ID,默认是1,一般取IP最后一段,方便知道id是多少
log-bin=mysql-bin //[必须]启用二进制日志
slave-skip-errors=all //忽略掉一些没啥大问题的错误
下面的可以选配,一般都同步整个库,包括用户待,所以可以不配置:
binlog-do-db=repl // 需要记录二进制日志的数据库,如果有多个数据库可用逗号分隔,或者使用多个binlog-do-db选项
binlog-ignore-db=mysql //不需要记录二进制日志的数据库,如果有多个数据库可用逗号分隔,或者使用多个binlog-ignore-db选项
replicate-do-db=repl // 需要同步的数据库,如果有多个数据库可用逗号分隔,或者使用多个replicate-do-db选项
replicate-ignore-db=mysql //不需要同步的数据库,如果有多个数据库可用逗号分隔,或者使用多个replicate-ignore-db选项
log-slave-updates //这个参数是把更新的记录写到二进制文件中,保证slave挂在任何一台master上都会接收到另一个master的写入信息
3、修改从服务器slave
#vi /etc/my.cnf
[mysqld]
server-id=226 //[必须]服务器唯一ID
log-bin=mysql-bin //启用二进制日志,单向同步不是必须,但双向同步则是[必须]
slave-skip-errors=all //忽略掉一些没啥大问题的错误
4、重启两台服务器的mysql
5、在主服务器上建立帐户并授权slave
一般不用root帐号,'%'表示所有客户端都能连,只要帐号,密码正确,此处可用具体客户端IP代替,如192.168.1.9,加强安全。
CREATE USER 'myslave'@'%' IDENTIFIED BY 'myslave123';
GRANT REPLICATION SLAVE ON *.* TO 'myslave'@'%';
6、登录主服务器的mysql,查询master的状态,并记下状态值
6.1、查询master的状态前,需要保证在查询前后服务数据被更改,需要对主服务器增加只读锁
mysql>flush tables with read lock;
6.2、增加只读锁后,查询master状态,记下当前数据状态的值
mysql>show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 337 | | |
+------------------+----------+--------------+------------------+
注:执行完此步骤后不要再操作主服务器MYSQL,防止主服务器状态值变化,6.1加锁也是为了在6.3步骤备份出该状态下整个的数据库
6.3、直接把整个主库复制一份出来当从库,并启动从库(如果要做双向同步,同样需要对从库加锁,并且记下其状态值,数据必须和主库备份时一致)
7、配置从服务器slave
7.1、配置主服务器信息,注意337数字前后无单引号
mysql>change master to MASTER_HOST='192.168.1.47', MASTER_PORT=3306, MASTER_USER='myslave', MASTER_PASSWORD='myslave123', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=337;
7.2、启动从服务器复制功能
mysql>start slave;
7.3、检查从服务器复制功能状态,大概返回1行数据
mysql> show slave status;
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.1.47 //主服务器地址
Master_User: myslave //授权帐户名,尽量避免使用root
Master_Port: 3306 //数据库端口,部分版本没有此行
Connect_Retry: 60
Master_Log_File: mysql-bin.000001
Read_Master_Log_Pos: 337 //#同步读取二进制日志的位置,大于等于Exec_Master_Log_Pos
Relay_Log_File: mysql-relay-bin.000002
Relay_Log_Pos: 253
Relay_Master_Log_File: mysql-bin.000001
Slave_IO_Running: Yes //此状态必须YES
Slave_SQL_Running: Yes //此状态必须YES
......
注:Slave_IO_Running及Slave_SQL_Running两个进程都必须是Yes状态,否则都是错误状态。
8、如果是单向同步,则执行下面步骤结束配置。
8.1、主服务器执行以下命令,用于解开服务器只读锁,让主服务器可以正常使用
mysql>unlock tables;
9、双向热备
9.1、配置双向同步方法就是在单向同步的基础上略加改动,即在从机上做主机配置,在主机上做从机配置。
9.2、重复5-8步骤,但主从服务器互换
mysql主从配置(基于mysql5.5.x)的更多相关文章
- Windows下Mysql主从配置(Mysql5.5)
主数据库IP:192.168.3.169从数据库IP:192.168.3.34 主数据库配置my.inin: 在[mysqld]下添加配置数据:server-id=1 #配一个唯一的ID编号, ...
- Mysql主从配置+读写分离
Mysql主从配置+读写分离 MySQL从5.5版本开始,通过./configure进行编译配置方式已经被取消,取而代之的是cmake工具.因此,我们首先要在系统中源码编译安装cmake工具. ...
- mysql主从配置实现一主一从读写分离
主从介绍Mysql主从又叫Replication.AB复制.简单讲就是A与B两台机器做主从后,在A上写数据,另外一台B也会跟着写数据,实现数据实时同步mysql主从是基于binlog,主上需开启bin ...
- mysql主从配置
引言: 双11,阿里云服务器打折,于是我忍不住又买了一台服务器,于是咱也是有两台服务器的爷们了,既然有了两台服务器,那么肯定要好好利用一下吧,那么就来玩玩mysql的主从配置吧. 准备 两台数据库服务 ...
- Mysql主从配置,实现读写分离
大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡,远远不够.到了数据业务层.数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器扛,如此多的数据库连接操作,数据库必然会崩溃,数据丢 ...
- mysql 主从 配置和同步管理
首先呢,需要有两个mysql服务器.如果做测试的话可以在同一台机器上装两个mysql服务程序,注意要两个运行程序的端口不能一样.我用的是一个是默认的3306,从服务器用的是3307端口. 在主服务创建 ...
- MySql主从配置实践及其优势浅谈
MySql主从配置实践及其优势浅谈 1.增加两个MySQL,我将C:\xampp\mysql下的MYSQL复制了一份,放到D:\Mysql2\Mysql5.1 修改my.ini(linux下应该是my ...
- windows环境下mysql主从配置
mysql主从配置. 相关理论知识可以百度一下,这里就不多说了,直接说如何配置. 一.环境介绍及说明 主库所在的操作系统:win7 主库的版本:mysql-5.6.24-winx64.zip 主库的i ...
- 黄聪:Mysql主从配置,实现读写分离
大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡,远远不够.到了数据业务层.数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器扛,如此多的数据库连接操作,数据库必然会崩溃,数据丢 ...
- linux系统mysql主从配置
一.原理 mysql主从配置的流程大体如图: 1)master会将变动记录到二进制日志里面: 2)master有一个I/O线程将二进制日志发送到slave; 3) slave有一个I/O线程把mast ...
随机推荐
- 快速将一个表的数据生成SQL插入语句
将一个表中的数据生成SQL插入语句,方便系统快速初始化,在数据库中执行创建以下过程就可以了. ) Drop Procedure GenerateData go CREATE PROCEDURE Gen ...
- sql server 删除表及表的相关视图、存储过程、方法
注意:进行此操作前需先备份数据库,免得删错无法恢复 1.查询 SELECT Name ,type FROM SysObjects WHERE name LIKE '%cases%' 2.拼接语句 SE ...
- 如何在springMVC 中对REST服务使用mockmvc 做测试
如何在springMVC 中对REST服务使用mockmvc 做测试 博客分类: java 基础 springMVCmockMVC单元测试 spring 集成测试中对mock 的集成实在是太棒了!但 ...
- docker在centos7下的一些坑
在centos的docker上安装mysql提示chown mod /var/lib/mysql permission denied,通过下面的方法1解决. 在centos上挂载数据卷,在容器内部访问 ...
- java获取到机器IP地址及MAC码
import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.net.InetAddress; import java.ne ...
- kafka windows环境搭建 测试
http://www.cnblogs.com/alvingofast/p/kafka_deployment_on_windows.html 照着例子搭建成功
- (copy) Top Ten Reasons not to use the C shell
http://www.grymoire.com/Unix/CshTop10.txt ========================================================== ...
- Docker应用程序容器技术_转
转自:百度百科 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱机制,相 ...
- RDIFramework.NET ━ .NET快速信息化系统开发框架 记录所有操作的Sql
在实际开发或试运行过程中,我们有时需要查看或分析模块执行的所有sql,以便进行相关分析.有时我们可以通过数据库自带的软件抓取,如:SQL Server Profiler.在我们RDIFramework ...
- dubbo源码分析6-telnet方式的管理实现
dubbo源码分析1-reference bean创建 dubbo源码分析2-reference bean发起服务方法调用 dubbo源码分析3-service bean的创建与发布 dubbo源码分 ...