MYsql主从复制

1.mysql主从复制原理:

Master将数据变化记录到二进制日志中【binary log】

Slave将master的二进制日志【binary log】拷贝到自己的中继日志【relay log】中。

Slave将中继入日志【relay log】事件在做一次,将数据变化,反应到自身数据库。

简述:mysql主从复制其实就是完全备份,和二进制日志备份还原的过程。二进制日志的还原基本上是实时进行的。注意不是完全实时,而是异步实时,主从直接的执行有延迟。如果master压力过大,则延迟就会很长,

原理详解:一个是i/o线程,负责:读取主服务器的二级制日志文件【binary log】。并将其保存在自己的中继日志中。

-个是sql线程,负责:复制执行中继日志【relay log】。

1.安装mysql服务器:二进制包安装

主master:192.168.1.105

从slave :192.168.1.106

安装:

查看系统配置:uname -a

添加用户:useradd -s /sbin/nologin -M mysql

下载mysql二进制安装包

wget:  http://mirrors.sohu.com/mysql/MySQL-5.1/mysql-5.1.73-linux-x86_64-glibc23.tar

解压移动到/usr/local/src

tar -xvzf mysql-5.1.73-linux-x86_64-glibc23.tar

mv mysql-5.1.73-linux-x86_64-glibc23 /usr/local/mysql

创建数据存放位置:mkdir -p /data/mysql

设定权限:chown -R mysql:mysql /data/mysql

初始化:进入/usr/local/mysql下。注意:定义数据存放位置及数据库所属主

# ./scripts/mysql_install_db --user=mysql --datadir=/data/mysql

拷贝mysql配置文件到/etc/下

cp support-files/my-large.cnf /etc/my.cnf

拷贝启动脚本并修改其属性

cp support-files/mysql.server /etc/init.d/mysqld

chmod +x /etc/init.d/mysqld

添加path路径便于管理:

vim /etc/profile.d/path.sh

export PATH=$PATH:/usr/local/mysql/bin

运行:source /etc/profile.d/path.sh

或者:echo "PATH=/usr/local/mysql/bin:$PATH" >> /etc/profile

service mysqld start

--------------------------------基础安装到此--------------------------------

mysql主从复制配置正式开始

配置mysql master主:

修改主配置文件:打开log_bin功能,设置服务器id默认企业中此值可以不用修改

默认为1.即可。

server-id = 1 服务器id 每一个服务器id必须唯一。

log-bin=wangyunlong可以自定义,默认为:mysql-bin可以忽略不变。

Binlog二进制日志:主服务变更信息会记录再次文件中:/data/mysql下

退出登录更改root密码:

指定需要同步的库:

binlog-do-db=db1,(指定需要同步的库)

binlog-ignore-db=db1,(指定出除此库外其它全部同步。此时binlog-do-db和binlog-ignore-db二选一)

保存退出。

设置主数据库root密码

mysql>update user set password=password('wangyunlong') where user='root';
mysql>flush privileges;

配置主从测试文件

在住上创建测试数据库db1

mysql -uroot -pwangyunlong1992 -e "create database db1"

导出主的mysql数据库然后倒入给db1数据库。

mysqldump -uroot -p"wangyunlong1992" mysql > 123.sql

mysql -uroot -p"wangyunlong1992" db1 < 123.sql

查看master id

mysql> show variables like 'server_id';

查看binlog是否开启

show variables like 'log_bin';

mysql> show variables like 'log_bin';

+---------------+---------+

| Variable_name | Value |

+---------------+---------+

| log_bin          | ON      |

+---------------+---------+

1 row in set (0.00 sec)

在master上建立主从复制的账号

在masger上建立复制账号“rep”密码“123456”用于从服务器i/o读取主binlog数据所需的账号密码。

mysql> grant replication slave on *.* to 'rep'@'192.168.1.%' identified by '123456';

检查主库创建的rep复制账号:

mysql> select user,host from mysql.user;

mysql> select user,host from mysql.user;

+------+-------------------+

| user | host                    |

+------+-------------------+

| root | 127.0.0.1            |

| rep  | 192.168.1.%       |

|        | bogon                 |

| root | bogon                 |

|        | localhost             |

| root | localhost             |

+------+------------------+

6 rows in set (0.00 sec)

检查权限

mysql> show grants for rep@'192.168.1.%';

+----------------------------------------------------------------------------------------------------------------------------------------------------------------+

| Grants for rep@192.168.1.%                                                                                                                                                                      |

+----------------------------------------------------------------------------------------------------------------------------------------------------------------+

| GRANT REPLICATION SLAVE ON *.* TO 'rep'@'192.168.1.%' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' |

+-----------------------------------------------------------------------------------------------------------------------------------------------------------------+

1 row in set (0.00 sec)

对主服务器锁表(考虑备份测试数据完整性。)

mysql> flush tables with read lock;

查看master状态

mysql> show master status;

+--------------------+----------+--------------+------------------+

| File               | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+--------------------+----------+--------------+------------------+

| wangyunlong.000004 |      106 |     db1      |                  |

+--------------------+----------+--------------+------------------+

1 row in set (0.00 sec)

wangyunlong.000002->主数据变化就记录再次文件中。Position 为106

Binlog_do_db:只同步的数据有db1 binlog_ignore_db(除此之外的数据库全部同步;

主配置完成。

配置从slave:192.168.1.106

设置从数据密码:wangyunlong

设置从slave id

server-id = 2 服务器id 每一个服务器id必须唯一。

关闭从的binlog功能,关闭只需要注释掉即可。

#log-bin=mysql-bin 
#binlog_format=mixed

保存退出。

查看状态:

mysql> show variables like  'log_bin';

ERROR 2006 (HY000): MySQL server has gone away

No connection. Trying to reconnect...

Connection id:    3

Current database: *** NONE ***

+---------------+----------+

| Variable_name | Value  |

+---------------+---------+

| log_bin       | OFF         |

+---------------+----------+

1 row in set (0.00 sec)

备份主的db1并拷贝从并倒入

主备份:mysqldump -uroot -pwangyunlong1992 db1>db1.sql

拷贝:scp db1.sql 192.168.1.106:/tmp/

从创建db1库:mysql -uroot -pwangyunlong -e "create database db1"

导入到从mysql -uroot -pwangyunlong db1 < db1.sql

查看从:

mysql> show databases;

+------------------------+

| Database            |

+------------------------+

| information_schema  |

| db1                          |

| mysql                       |

| test                          |

+------------------------+

执行:slave stop

配置从连接主数据库信息

mysql> change master to master_host='192.168.1.105', master_port=3306, master_user='rep', master_password='123456',  master_log_file='wangyunlong.000005', master_log_pos=106;

解释:

master_host='192.168.1.105', 主库ip

master_port=3306, 主库端口

master_user='rep', 主库上建立的复制用户名

master_password='123456', 复制用户密码

master_log_file='wangyunlong.000005', 二进制日志文件名称刚才查看状态“show master status”显示的File 信息。

master_log_pos=106;

二进制日志偏移量:查看状态“show master status”显示的Position信息。

从执行slave start;开启从复制开关

开启主:

mysql -uroot -pwangyunlong -e "unlock tables";

查看从是否配置是否成功:

show slave status\G;

显示:如下信息表示成功。

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

Seconds_Behind_Master: 0

完整显示:mysql> show slave status\G;

解释:

Slave_IO_Running: Yes 负责从从库到主库第七binLog日志,并写入从库的中继日志中

Slave_SQL_Running: Yes 负责读取从库的中继日志信息并转化为sql语句引用执行到从数据库中。

Seconds_Behind_Master: 0 复制过程中从库到主库延迟的秒数。企业例判断延迟的方法为:在主库写的时间戳,然后从库中读取时间戳,和当前数据时间进行比较,判断是否延迟。

测试主从配置是否成功:

在主master上进入删除主库db1中的event表。

use db1

drop table event;

在从上看没有了

select count(*)from event;

...继续测试...增加删除插入等.......ok即可。

mysql读写分离后续补充

mysql主从复制+读写分离 菜鸟入门的更多相关文章

  1. mysql主从复制-读写分离

    mysql主从复制+读写分离 环境:mysql主:193.168.1.1mysql从:193.168.1.2amoeba代理:193.168.1.3########################## ...

  2. mysql主从复制-读写分离-原理

    Mysql主从复制和读写分离 在实际的生产环境中,如果对mysql数据库的读和写都在一台数据库服务器中操作,无论是在安全性.高可用性,还是高并发等各个方面都是不能满足实际需求的.因此,一般通过主从复制 ...

  3. MySQL 主从复制&读写分离 简介

    1. 读写分离&读写分离 简介 主从同步延迟 分配机制 解决单点故障 总结 2. 主从复制&读写分离 搭建 搭建主从复制(双主) 搭建读写分离 1. 读写分离&读写分离 简介 ...

  4. Mycat+MySql 主从复制-读写分离 看这一篇就够了

    ​ 通过mycat和mysql的主从复制配合搭建数据库的读写分离,可以实现mysql的高可用性,下面我们来搭建mysql的读写分离. 1.一主一从 1.在node01上修改/etc/my.cnf的文件 ...

  5. MYSQL 主从复制,读写分离(8)

    Mysql 数据库的主从复制方案,是其自带的功能,并且主从复制并不是复制磁盘上的数据文件,而是通过binlog日志复制到需要同步的服务器上. 一 主从复制的原理实现 原理图解说: 数据库更改 生成数据 ...

  6. Mycat实现mysql主从复制(读写分离)

    数据库性能瓶颈主要原因: 随着用户数的增多,带来的是数据库连接的大幅度增长 随着业务体量的增长,表数据量(空间存储的问题)的大幅增长,其中涉及到索引的优化,mysql默认的索引是硬盘级别的,BTREE ...

  7. Mysql主从复制读写分离

    一.前言:为什么MySQL要做主从复制(读写分离)?通俗来讲,如果对数据库的读和写都在同一个数据库服务器中操作,业务系统性能会降低.为了提升业务系统性能,优化用户体验,可以通过做主从复制(读写分离)来 ...

  8. MySQL主从复制&读写分离&分库分表

    MySQL主从复制 MySQL的主从复制只能保证主机对外提供服务,从机是不提供服务的,只是在后台为主机进行备份数据 首先我们说说主从复制的原理,这个是必须要理解的玩意儿: 理解: MySQL之间的数据 ...

  9. MySQL主从复制读写分离如何提高从库性能-实战

    在做主从读写分离时候,需要注意主从的一些不同参数设置,来提高从库的性能,提高应用读取数据的速度,这样做很有必要的. 做读写分离复制主从参数不同设置如下(需要根据自己应用实际情况来设置): parmet ...

随机推荐

  1. 图表控件FlowChart.NET详细介绍及免费下载地址

    FlowChart.NET是一款专业的.NET平台下的流程图及图表控件,它可以运行在任何C#, VB.NET或Delphi.NET语言编写的软件中.能够帮助你创建工作流程图.对象层次和关系图.网络拓扑 ...

  2. 关于在工程中添加新文件时的LNK2019错误的一个解决办法

    我这几天一直在研究Qt的串口程序,在读懂了官方给出的实例程序后我决定把其多线程的串口监视程序加入到我自己的工程中,便直接把问价复制到自己的工程下面,在Qt中加入到自己的工程中,但是总是出现LNK201 ...

  3. 【一套C语言控制台的输出框代码】

    效果演示 可以生成一个输出框 首先 要创建输出框,设置输出框风格,可以设置的元素包括: 左上角符号,右上角符号,左下角符号,右下角符号,以及上下左右边界线符号,理论上,只要你电脑能显示的符号,都可以支 ...

  4. 内存管理 - MEMORY POOL

    内存池优势: 效率高,频繁的new和delete效率低下 减少内存碎片,反复向系统申请和释放内存会产生大量内存碎片 防止内存泄露 内存池设计思路: 内存池可以根据实际需要,设计成不同的样子.下面是针对 ...

  5. HDU 5884 (贪心)

    problem sort 题目大意 有n个数组,每个数组有a[i]个元素,每次可以将至多k个数组合并为一个数组,所花费代价为这些数组的元素和.给定代价上限,求将所有数组合并为1个数组的最小k. 解题分 ...

  6. Android 学习第14课,Android 布局

    布局分4种: 1. LinearLayout (线性布局) file:///H:/tool/01/Android/android-sdk-windows/docs/guide/topics/ui/la ...

  7. android 查看MD5、sha1值命令

    cmd 进去keystore 文件所在目录 keytool -list -v -keystore xxx.keystore debug.keystore 默认目录:C:\Documents and S ...

  8. Struts2学习笔记(拦截器配置添加)

    一.拦截器工作原理: 根据Struts2的工作原理图,拦截器在action执行前进行顺序调用,之后执行Action并返回结果字符串,再逆序调用拦截器.(结构类似递归方式...)大部分时候,拦截器方法都 ...

  9. 3-Spark高级数据分析-第三章 音乐推荐和Audioscrobbler数据集

    偏好是无法度量的. 相比其他的机器学习算法,推荐引擎的输出更直观,更容易理解. 接下来三章主要讲述Spark中主要的机器学习算法.其中一章围绕推荐引擎展开,主要介绍音乐推荐.在随后的章节中我们先介绍S ...

  10. MVCC PostgreSQL实现事务和多版本并发控制的精华

    原创文章,同步发自作者个人博客,http://www.jasongj.com/sql/mvcc/ PostgreSQL针对ACID的实现机制 事务的实现原理可以解读为RDBMS采取何种技术确保事务的A ...