原文:http://iii75.cn/mwQhBW

作者:波波烤鸭

历史相关文章

Mycat入门教程

单个mysql数据库在处理业务的时候肯定是有限的,这时我们扩展数据库的第一种方式就是对数据库做读写分离(主从复制),本文我们就先来介绍下怎么来实现mysql的主从复制操作。

1. 读写分离

原理:需要搭建主从模式,让主数据库(master)处理事务性增、改、删操作(INSERT、UPDATE、DELETE),而从数据库(slave)处理 SELECT 查询操作。  Mycat 配合数据库本身的复制功能,可以解决读写分离的问题。

2.主从备份概念

什么是主从备份: 就是一种主备模式的数据库应用. 主库(Master)数据与备库(Slave)数据完全一致. 实现数据的多重备份, 保证数据的安全. 可以在 Master[InnoDB]和 Slave[MyISAM]中使用不同的数据库引擎,实现读写的分离 InnoDB:支持事务处理 MyISAM:不支持事务处理

2.1MySQL5.5, 5.6 版本后本身支持主从备份

在老旧版本的 MySQL 数据库系统中,不支持主从备份,需要安装额外的 RPM 包.如果需要安装 RPM,只能在一个位置节点安装.

2.2主从备份目的

2.2.1 实现主备模式

保证数据的安全. 尽量避免数据丢失的可能.

2.2.2 实现读写分离

使用不同的数据库引擎,实现读写分离.提高所有的操作效率.   InnoDB 使用 DML 语法操作. MyISAM 使用 DQL 语法操作.

2.3主从备份效果

2.3.1 主库操作同步到备库

所有对 Master 的操作,都会同步到 Slave 中.如果 Master 和 Salve 天生上环境不同,那么对 Master 的操作,可能会在 Slave 中出现错误如: 在创建主从模式之前,Master 有 database : db1, db2, db3. Slave 有 database: db1, db2.创建主从模式.现在的情况 Master 和 Slave 天生不同.主从模式创建成功后,在 Master 中 drop database db3. Slave 中抛出数据库 SQL 异常.后续所有的命令不能同步.一旦出现错误. 只能重新实现主从模式.

2.4主从模式下的逻辑图

image.png

3.MySQL主从模式搭建

3.1 安装MYSQL

mysql安装教程: https://dpb-bobokaoya-sm.blog.csdn.net/article/details/88893932

环境地址

主节点:192.168.88.180从节点:192.168.88.181

image.png

image.png

3.2 主库配置修改(Master)

路径:/etc/my.cnf

3.2.1 server_id配置

本环境中 server_id 是 1

MySQL 服务唯一标识

配置要求:

server_id 任意配置,只要是数字即可

server_id Master 唯一标识数字必须小于 Slave 唯一标识数字.

3.2.2 log_bin配置

本环境中 log_bin 值 : master_log

开启日志功能以及日志文件命名,log_bin=master_log

变量的值就是日志文件名称.是日志文件名称的主体.

MySQL 数据库自动增加文件名后缀和文件类型.

3.2.3 重启mysql

service mysql restart

3.2.4 登录mysql

从mysql的安装路径下进入

./bin/mysql -uroot -h127.0.0.1 -p123456

3.2.5 创建用户

在 MySQL 数据库中,为不存在的用户授权,就是同步创建用户并授权.

此用户是从库访问主库使用的用户

ip 地址不能写为%. 因为主从备份中,当前创建的用户,是给从库 Slave 访问主库 Master使用的.用户必须有指定的访问地址.不能是通用地址.

grant all privileges on . to ‘username’@’ip’ identified by ‘password’ with grant option;flush privileges;grant all privileges on *.* to 'myslave'@'192.168.88.181' identified by 'myslave' with grant option;flush privileges;

3.2.6 查看用户

use mysql;select host, user from user;

3.2.7 查看 Master 信息

master_log.00003就是主从复制中从数据库要读取的日志文件。

注意:关闭防火墙或在防火墙中开放 3306 端口

3.3 从库配置修改(slave)

3.3.1 修改my.cnf的server_id

从库的 server_id要比主库中的server_id的值要大

然后重启mysql服务

3.3.2 连接mysql服务

3.3.3 停止 Slave 功能

stop slave

3.3.4 配置主库信息

需要修改的数据是依据 Master 信息修改的.ip 是 Master 所在物理机 IP. 用户名和密码是Master 提供的 Slave 访问用户名和密码. 日志文件是在 Master 中查看的主库信息提供的.在Master 中使用命令 show master status 查看日志文件名称.

change master to master_host=’ip’, master_user=’username’, master_password=’password’, master_log_file=’log_file_name’;

3.3.5 启动 Slave 功能

start slave;

3.3.6 查看 Slave 配置

show slave status G; # G 行转列

注意:如果输出中有如下提示:

Last_IO_Error: Fatal error: The slave I/O thread stops because master and slave have equal MySQL server ids; these ids must be different for replication to work (or the –replicate-same-server-id option must be used on slave but this does not always make sense; please check the manual before using it).

原因是以为两个数据库是克隆出来的,所以uuid是一致的,这时只需要删除掉一个uuid即可,具体如下:

把auto.cnf 注释掉或者删除掉,重启mysql就会重新分配!

4. 主从测试

4.1 创建数据库同步

在master上新建一个数据库,然后查看slave中是否也有即可

create database demo2 default character set utf8;

4.2 创建table同步

create table t_user (id varchar(20),name varchar(20));

4.3 数据操作同步

insert into t_user (id,name)values('666','bobo');

通过演示我们发现主数据库的修改会及时的同步到从数据库,这样mysql的主从配置就OK了,好了本文就到此.

mysql文件类型_MyCat教程:实现MySql主从复制相关推荐

  1. mysql image类型_MyCat教程【mysql主从复制实现】

    原文:http://iii75.cn/mwQhBW 作者:波波烤鸭 历史相关文章 Mycat入门教程 单个mysql数据库在处理业务的时候肯定是有限的,这时我们扩展数据库的第一种方式就是对数据库做读写 ...

  2. MySQL数据库入门学习教程(mysql基础+高级)

    今天这篇文章将详细列出Mysql的学习流程,这是学习mysql数据库前你要了解的~~~ 大部分的小伙伴自己在网上找mysql资料.还有数据库的视频教程,但是都过于碎片化,没有体系,导致大家不知道如何系 ...

  3. 修改mysql文件位置_如何修改mysql数据文件存储位置

    如果想更换mysql的数据文件的存储位置,则: Centos下: 查看MYSQL数据文件存储路径 mysql>show variables like '%datadir%'; # /usr/lo ...

  4. hibernate mysql 映射_hibernate与mysql映射类型对应表与mysql导入导出

    http://blog.sina.com.cn/s/blog_5f240fc40100etlt.html 一.记录下hibernate mysql映射类型对应表: 1.常规Hibernate 映射 i ...

  5. mysql set类型的用户变量,mysql用户变量的圈套

    mysql用户变量的陷阱! 1. 用户变量 用户变量是指通过set语句:set @var_name = expr [, @var_name = expr]对指定变量名赋值,然后在以后引用它.用户变量的 ...

  6. mysql数据库建站教程视频,Mysql数据库基础入门(附视频教程)

    1:使用SHOW语句找出在服务器上当前存在什么数据库: mysql> SHOW DATABASES; 2:2.创建一个数据库MYSQLDATA mysql> CREATE DATABASE ...

  7. MySQL安装使用学习教程,mysql数据库入门的不二之选

    MySQL是最流行的关系型数据库管理系统,在WEB应用方面MySQL是最好的RDBMS(Relational Database Management System:关系数据库管理系统)应用软件之一. ...

  8. mysql varchar类型实例_Mysql实例MySQL数据类型varchar详解

    <Mysql实例MySQL数据类型varchar详解>要点: 本文介绍了Mysql实例MySQL数据类型varchar详解,希望对您有用.如果有疑问,可以联系我们.1.varchar(N) ...

  9. Mysql varchar类型长度计算(mysql字段长度计算)

    博客上的文章深度参差不齐,本人也是看了好几篇博客才找到另自己满意的博客. 1.限制规则 字段的限制在字段定义的时候有以下规则: a)存储限制 varchar 字段是将实际内容单独存储在聚簇索引之外,内 ...

最新文章

  1. python基础单词-学习Python必背的初级单词有哪些?
  2. java 网络io详解_Java网络socket编程详解
  3. android自定义控件实例
  4. 第七章:nginx的rewrite规则详解
  5. NutDao配置多数据源
  6. php7.2连接mysql8_兼容 php 7.2 及 mysql 8
  7. 小程序组件报错Uncaught TypeError: Cannot read property 'name' of undefined
  8. BZOJ 4602: [Sdoi2016]齿轮 dfs
  9. Android FrameWork——ActivityManager框架
  10. HttpClient 使用时,出现「no trusted certificate found」的原因 (JDK没有安装相应的证明书)
  11. CSS 居中 可随着浏览器变大变小而居中
  12. 怎样将树的中序遍历的数输入到一个数组中_二叉搜索树的后序遍历序列(剑指offer第三十一天)...
  13. 计算机基础和办公软件应用第23集,计算机基础及Office办公软件应用(Windows7+0ffice 2010版)...
  14. 【mock】数据模板定义规范DTD 数据占位符定义规范DPD
  15. 基因融合检测:1、基因融合数据库、融合检测软件汇总
  16. 《蜗居》100句台词 血淋淋的经典
  17. 在win10下把iPad利用起来,当作电脑的副屏
  18. 2JS-操作BOM对象
  19. amap 实现获取定位功能(高德api)
  20. windows同时代服务器系统,从Win95到Win10:那些年让你痴迷的系统特性大盘点

热门文章

  1. oracle rac理解和用途扩展
  2. Activity的四种加载模式(转载)
  3. Microsoft SQL Server 2005数据库安装
  4. 创建windows服务,定时监控网站应用程序池
  5. 【数据结构与算法】【算法思想】Dijkstra算法
  6. [Leetcode][第98 450 700 701题][JAVA][二叉搜索树的合法性、增、删、查][递归][深度遍历]
  7. [如何做研究][如何写论文]
  8. 修改场景默认pawn的方法
  9. UE4角色Location远距离时动画抖动问题(float精度不够)解决方案
  10. U-BOOT之一:BootLoader 的概念与功能