MySQL Replication(数据同步技术)

A 到 B 完成主从复制,意思是数据同步技术 从读取主的二进制日志文件,按照日志中记录对从库进行同样的操作

复制类型:

异步复制 :默认的复制是异步,主执行完后立刻将结果返给客户端,不关心从是否接收或处理

全同步复制:当主执行完一个事务,从库都执行完该事务才返回给客户端。

半同步复制:介于异步与全同步之间,主库在执行完客户端提交的事务后不是立刻返回给客户端,而是等待至少一个从库接收到并写到日志中返回客户端(最好在低延时的网络中使用)

一般使用异步复制的方式

双机部署环境:

主节点 192.168.80.24
从节点 192.168.80.26

----------------

首先要先安装mysql数据库

1,关闭防火墙和安全机制

systemctl  stop firewalld
setenforce 0
iptables -F

2,配置ntp时间同步服务器并启动

yum -y install  ntp
1,主节点做
vim /etc/ntp.conf
server 127.127.1.0
fudge 127.127.1.0 stratum 8
systemctl start ntpd
2,从节点
ntpdate 主节点IP

(第二种方法,使用互联网上时间同步服务器(每个节点都使用,方便便捷)
crontab -e
* */5 * * * /usr/sbin/ntpdate pool.ntp.org > /dev/null 2>&1       //每隔5小时同步一下时间

3,安装mysql安装包

安装 mysql-5.7.24-linux-glibc2.12-x86_64.tar.gz

1,将系统中只带的mariadb删除
rpm -q mysql mysql-server mariadb mariadb-server
rpm -e .......
2,上传mysql二进制包解压
tar xf mysql-5.7.24-linux-glibc2.17-x86_64-minimal.tar.xz -C /usr/local/        
cd /usr/local        
mv mysql-5.7.24-linux-glibc2.17-x86_64-minimal/ mysql                            
3,创建mysql用户并赋予权限    
useradd -M -s /sbin/nologin mysql                                                
chown -R mysql:mysql /usr/local/mysql/
4,初始化数据库
/usr/local/mysql/bin/mysqld --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --initialize

5,修改配置文件
cat /etc/my.cnf
[mysqld]
port=3306
datadir=/usr/local/mysql/data
max_connections = 100
default-storage-engine = InnoDB
socket=/tmp/mysql.sock
character-set-server=utf8
[mysqld_safe]
log-error=/usr/local/mysql/data/mysql.log
pid-file=/usr/local/mysql/data/mysql.pid

6,做启动文件
cd /usr/local/mysql/support-files
cp mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld
chkconfig --add mysqld
ln -s /usr/local/mysql/bin/* /usr/local/bin/
systemctl start mysqld            

7,修改密码
####mysqladmin -uroot -p'复制的初始密码' password'123456'      
mysql>alter user user() identified by "123456" ;
#登陆:
mysql -uroot -p'123456'

开始配置主从

4,配置主mysql并重启

vim /etc/my.cnf
server-id=1
log-bin=mysql-binlog
log-slave-updates=true

systemctl restart mysqld

5,主创建replication用户

进入数据库mysql 
>grant replication slave on *.* to 'myslave'@'192.168.80.%' identified by '123456';
>flush privileges;
> show master status;

replication slave :用于复制从属服务器(从主服务器中读取二进制日志事件权限)
测试是否成功
从 连接一下 主。如果成功登陆则没有问题
mysql -u myslave -p123456 -h 192.168.80.24

补充:生产环境下,主运行过一段时间,已经存在数据,为了保证数据一致性,需要先备份。两种方式,直接备份数据文件或者mysqldump工具备份

6,从配置并重启

vim /etc/my.cnf
server-id = 2
relay-log=relay-log-bin
relay-log-index=slave-relay-bin.index

补充:如若有多台从,每一台都需要配置,并只修改server-id编号即可

systemctl restart mysqld

7,从进入数据库中配置

进入从数据库
>stop slave;                       //先停掉从的角色
>change master to master_host='192.168.200.115',master_user='myslave',master_password='123456',master_log_file='mysql-bin.000002',master_log_pos=477;
                                  //配置新的从角色
>start slave;                       //启动角色
>show slave status\G                   //查看角色信息

补充:清除角色 >reset slave;

8.测试:在主中创建一个库,看从中是否复制成功

进入主数据库
>create database sampdb;
>use sampdb;
>create table new(name char(20),phone char(20));
进入从数据库
>show databases;

9.补充注意:主从复制,只是一种数据同步技术,不是架构;

如果是问数据库架构是如何,应该再加上HA(高可用),如下列举两个架构

  • MySQL主主复制+Keepalived高可用
  • MySQL+DRBD+Heartbeat

MySQL Replication(数据同步技术)的更多相关文章

  1. 两台Mysql数据库数据同步实现

    两台Mysql数据库数据同步实现 做开发的时候要做Mysql的数据库同步,两台安装一样的系统,都是FreeBSD5.4,安装了Apache 2.0.55和PHP 4.4.0,Mysql的版本是4.1. ...

  2. Goldengate完成Mysql到Mysql的数据同步

    文档参考地址:http://blog.csdn.net/u010587433/article/details/49305019 需求: 使用Goldengate完成Mysql到Mysql的数据同步,源 ...

  3. Mysql Replication 主从同步

    简介: Mysql 的主从同步功能,这种解决方案是企业很常见的一种.常用于备份数据库,当客户端操作主库时,主库会产生binlog日志文件, 从库通过复制主库的binlog日志文件,然后解析成相应的 S ...

  4. 怎么通过 Mysql 实现数据同步呢?

    怎么使 mysql 数据同步先假设有主机 A 和 B ( linux 系统),主机 A 的 IP 分别是 1.2.3.4 (当然,也可以是动态的),主机 B 的 IP 是 5.6.7.8 .两个主机都 ...

  5. MySQL主从数据同步延时分析

    一.MySQL数据库主从同步延迟                                                              要了解MySQL数据库主从同步延迟原理,我们 ...

  6. 减少mysql主从数据同步延迟

    网上给出的解决办法: 基于局域网的master/slave机制在通常情况下已经可以满足'实时'备份的要求了.如果延迟比较大,就先确认以下几个因素:1. 网络延迟2. master负载3. slave负 ...

  7. redis和mySql的数据同步的解析

    1.同步MySQL数据到Redis (1) 在redis数据库设置缓存时间,当该条数据缓存时间过期之后自动释放,去数据库进行重新查询,但这样的话,我们放在缓存中的数据对数据的一致性要求不是很高才能放入 ...

  8. k8s部署canal-1.1.6版本实现MySQL数据库数据同步

    1.版本说明 软件&镜像 版本&镜像信息 说明 Kubernetes v1.23.7 k8s服务器 Kuboard v3.5.2.0 k8s连接管理工具 Canal v1.1.6 数据 ...

  9. 使用Canal作为mysql的数据同步工具

    一.Canal介绍 1.应用场景 在前面的统计分析功能中,我们采取了服务调用获取统计数据,这样耦合度高,效率相对较低,目前我采取另一种实现方式,通过实时同步数据库表的方式实现,例如我们要统计每天注册与 ...

  10. 使用tungsten将mysql的数据同步到hadoop

    背景 线上有很多的数据库在运行,后台需要一个分析用户行为的数据仓库.目前比较流行的是mysql和hadoop平台. 现在的问题是,如何将线上的mysql数据实时的同步到hadoop中,以供分析.这篇文 ...

随机推荐

  1. day03-功能实现02

    家居网购项目实现02 5.功能04-会员登录 5.1需求分析/图解 需求如图: 输入用户名.密码后提交 判断该用户是否存在 如果存在,显示登录成功页面 否则返回登录页面,要求重新登录 要求改进登录密码 ...

  2. HTTP协议图文简述--HTTP/HTTPS/HTTP2

    01.准备 1.1.先了解下网络模型/TCP HTTP 连接是建立在 TCP* 协议之上的,其数据传输功能是由TCP完成的,那TCP又是什么呢? TCP 是一个单纯用来建立通信连接,并传输数据的基础协 ...

  3. 【机器学习】李宏毅——Anomaly Detection(异常检测)

    异常检测概述 首先要明确一下什么是异常检测任务.对于异常检测任务来说,我们希望能够通过现有的样本来训练一个架构,它能够根据输入与现有样本之间是否足够相似,来告诉我们这个输入是否是异常的,例如下图: 那 ...

  4. [数据结构]单向链表及其基本操作(C语言)

    单向链表 什么是单向链表 链表是一种物理储存单元上非连续.非顺序的储存结构.它由一系列结点(链表中每一个元素称为结点)组成,结点可动态生成.每个结点包括两个部分:一个是存储数据元素的数据域,另一个是存 ...

  5. last-child可能你也会踩的坑

    旧文章从语雀迁移过来,原日期为2021-07-14 问题 当时写在写一个列表,列表每一项需要下面加下划线,最后一项不加下划线.第一时间,想到使用 :``last-child 这个伪类来实现. 当时的代 ...

  6. 自研ORM框架实现工作单元模式

    平时我们使用事务,需要显示的Try Catch 并且开启事务 提交事务 异常回滚事务 三步骤,使用工作单元后则只需要Commit. 1.接口定义 1 /// <summary> 2 /// ...

  7. (4)go-micro微服务proto开发

    目录 一 Protobuf介绍 二 安装Protobuf 三 Protobuf语法 1.1 基本规范 1.2 字段规则 1.3 service如何定义 1.4 Message如何定义 四 proto代 ...

  8. 为什么网络I/O会被阻塞?

    摘要:I/O 其实就是 input 和 output 的缩写,即输入/输出. 本文分享自华为云社区<为啥网络IO会被阻塞呢>,作者: 龙哥手记. 我们应该都知道 socket(套接字),你 ...

  9. liunx系统安装JDK环境详细步骤

    Liunx系统安装JDK环境详细步骤 一 下载liunx版本jdk压缩包 进入JDK官方网站下载jdk压缩包.下载前需要登入账户,可以自己注册一个账户! 也可以使用本博主提供的网盘下载https:// ...

  10. 在Mac OS上将Node.js连接到XAMPP MySQL服务器一直报错error connecting: Error: connect ECONNREFUSED

    以下為通過node.js連線本機mysql資料庫的方法: var mysql = require('mysql'); var connection = mysql.createConnection({ ...