mysql cluster 设置单向复制_mysql单向主从配置

1.环境要求

操作系统:centOS6.5或以上

Mysql版本:mysql5.5

主机配置:4核CPU、4G内存

2.主从复制的方式

mysql5.6开始主从复制有两种方式:基于日志(binlog)、基于GTID(全局十事务标示符),下面主要介绍基于日志(binlog)的复制。

主从复制的原理

master将数据改变记录到二进制文件(binary log)中,也就是配置文件log-bin指定的文件,这些记录叫做二进制事件(binary log events);

slave通过I/O线程读取master中的binary log events并写入到它的中继日志(relay log);

slave重做中继日志中的事件,把中继日志中的事件信息一条一条的在本地执行一次完成数据在本地的存储,进而实现将改变反映到自己的数据;

3.主从复制注意的点

主从服务器操作系统版本和位数一致

master和slave数据库的版本要一致

master和slave数据库中的数据要一致

master开启二进制日志,master和slave的server_id在局域网内必须唯一

4.主从配置简要步骤

master上面的配置:

1.安装数据库

2.修改数据库配置文件,指明server_id,开启二进制日志(log-bin)

3.启动数据库,查看当前是哪个日志,position号是多少

4.登录数据库,授权数据复制用户

5.备份数据库(记得加锁和解锁)

6.传送备份数据到slave上

7.启动数据库

slave上面的配置:

1.安装数据库

2.修改数据库配置文件,指明server_id

3.启动数据库,还原备份

4.查看当前是哪个日志,position号是多少

5.指明master的地址、用户、密码等信息

6.开启同步,查看状态

5.单向主从环境的搭建

两台数据库服务器的selinux都要disable(永久关闭selinux,请修改/etc/selinux/config,将SELINUX改为disabled)

修改master的配置文件/etc/my.cnf,增加以下配置项:

server_id = 100  #一般设置为ip的最后一部分

binlog-do-db = admin  #需要备份的数据库

binlog-ignore-db = mysql #不需要复制的数据库

log-bin = edu-mysql-bin #开启二进制日志功能,可以随便定义但是建议有含义

6.重新启动master数据库服务,创建数据库,创建数据库同步用户并授予相应的权限

创建数据库同步用户并授予相应的权限:

grant replication slave, replication client on *.* to 'repl'@'192.168.1.206' identified by 'admin.123';

flush privileges;

show master status; #查看position号,记下position号(从机上需要用到这个position和现在的日志文件)

7.创建admin库、表,并写入一定量的数据,用于模拟现有的业务系统数据库

8.修改slave的配置文件/etc/my.cnf,增加以下配置项:

server_id = 206    #一般设置为ip的最后一部分

binlog-do-db = admin  #需要备份的数据库

binlog-ignore-db = mysql #不需要复制的数据库

log-bin = edu-mysql-bin #开启二进制日志功能,以备 Slave 作为其它 Slave 的 Master 时使用

9.重启slave数据库服务,将数据复制到从数据库中

10.slave中添加master相关信息

change master to master_host='121.199.168.20', master_user='repl', master_password='admin.123', master_port=3306,      master_log_file='edu-mysql-bin.000008' , master_log_pos=513, master_connect_retry=30;

上述参数说明:

master_log_file、master_log_pos是通过上述master的状态获取的

master_connect_retry   #当重新建立主从连接时,如果连接建立失败,间隔多久后重试。 单位为秒,默认设置为 60 秒,同步延迟调优参数。

11.slave执行主从同步:start slave;

12.show slave status\G;

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

这两个参数为Yes显示主从状态正常

13.主从配置完成,可以在master上面修改数据库验证slave数据库是否发生了改变

14.注意:如果再slave没做只读控制的情况下,千万不要在slave中手动插入数据,那样数据就会不一致,主从就会断开,就需要重新配置了

15.如果同步过程中出现错误,可以在slave上重置主从复制数据

reset slave

change master to master_host='121.199.168.20', master_user='repl', master_password='admin.123', master_port=3306,      master_log_file='edu-mysql-bin.000008' , master_log_pos=513, master_connect_retry=30;

master_log_file、master_log_pos根据最新的master状态获取

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/338946.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java处理注释_如何处理Java注释

java处理注释Java 8的一项很酷的新功能是对lambda表达式的支持。 Lambda表达式在很大程度上依赖于FunctionalInterface 注释 。 在本文中,我们将介绍注释以及如何处理它们,以便您可以实现自己的出色功能。 注解 Java 5中添加了注释 。Java语言附带了一…

nginx tcp转发_Nginx学习(九):负载均衡服务

介绍对于请求而言,负载均衡能很好的均摊请求,提高服务端吞吐率和整体性能,多个服务节点部署的方式,也提高了容灾和服务高可用。一、负载均衡分类负载均衡分为:GSLB和SLB。1. GDLB全局负载均衡,往往按照国家…

控制台发送get命令_.NET Core使用命令行参数库构建控制台应用程序

前言在我们开发中可能需要设计一次性应用程序,这些实用程序可以利用接近原始源代码的优势,但可以在与主Web应用程序完全独立的安全性上下文中启动。具体在 [管理过程](https://12factor.net/admin-processes)中也已经列出了原因。创建控制台应用打开命令…

C语言函数为什么不能返回数组?

C语言函数为什么不能返回数组?在C语言程序开发中,我们不可以编写下面这样的代码:char f(void)[8] {char ret; // ...fill... return ret; }int main(int argc, char ** argv) {char obj_a[10]; obj_a f(); }不可以编写这样的代码这其实就是不…

mockito_书评:Mockito Essentials

mockitoSujoy Acharya的Mockito Essentials副标题( Packt出版 ,2014年10月)是:“实用指南,可帮助您使用Mockito进行单元测试并开始运行。” Mockito Essentials中的前言和七章涵盖大约190个实质性页面。 前言 在序言中…

python3 byte 字面值_bytearray() Python 内置函数

转载须注明出处:简书Orca_J35 | GitHuborca-j35 class bytearray([source[, encoding[, errors]]]) 该内置函数本质上是 bytearray 类的构造函数,用于创建一个 bytearray 实例。bytearray 实例是一个由字节(8-bits 无符号)构成的可变序列,并拥…

python如何调用c函数实现真正意义的多线程_python如何使用多线程执行多个函数?...

之前小编给大家介绍了用python去返回了一个值,立马就有小伙伴跟小编留言说道“能都执行多个内容?”于是,小编就给大家整理最细致,也是最简单的实现方法,方便大家理解学习,一起来看下吧~直接上代码&#xff…

Java EE 8怎么了? (第2部分)

Java EE 8的工作仍处于初期阶段,并有望在来年跟上发展步伐,届时我们将看到专家组的完成,围绕用例/功能的更多讨论,大量JIRA和各种规范的草案版本(本会很有趣!)。 在第1部分中 ,我们…

C语言中quot;##quot;的独特用法

市面上有很多比较火的编程语言,比如Python、 JAVA、 Go等,你可能觉得C语言很古老、很落后。如果你有这种想法,那可能你只是一个初学的菜鸟。可能绝大部分 C 程序员都不知道"##"隐藏用法,下面就来给大家讲讲。一、##的“…

html a标签去掉下划线_如何用HTML基本元素制作表格

第2天【HTML基本元素】主要内容标题标签段落标签强制换行水平线图片超链接文本格式化标签列表表格学习目标一、标题标题&#xff08;Heading&#xff09;是通过 <h1> - <h6> 标签进行定义的。<h1> 定义最大的标题。 <h6> 定义最小的标题。标题很重要请…

mysql忽略数据类型_MYSQL 常用数据类型

数字列类型数字列类型用于储存各种数字数据&#xff0c;如价格、年龄或者数量。数字列类型主要分为两种&#xff1a;整数型和浮点型。所有的数字列类型都允许有两个选项&#xff1a;UNSIGNED和ZEROFILL。选择UNSIGNED的列不允许有负数&#xff0c;选择了ZEROFILL的列会为数值添…

C语言中几个容易踩的“坑”!

今天给大家分享几个C语言中的坑。一、带参数的宏展开顺序#include #define f(a,b) a##b #define g(a) #a #define h(a) g(a)int main(void) {printf("%s\n",h(f(1,2)));printf("%s\n",g(f(1,2)));return 0; }运行结果:12f(1,2)浅析&#xff1a;本题中的#运…

java 拼图_我最喜欢的Java拼图2 + 1 = 4

java 拼图这是我当前最喜欢的Java难题。 您如何获取代码来执行此操作&#xff1f; Integer b 2; Integer c 1;System.out.println("bc : " (bc) ); // output: bc : 4 !!Sytem.out.println&#xff08;&#xff09;没有技巧&#xff0c;也就是说&#xff0c;您将…

dockerfile cd目录_使用Werf和现有的Dockerfiles改善你的CI/CD体验

迟到总比不到好。该故事讲关于我们因不支持使用常规的Dockerfile来构建镜像导致我们差点犯了一个重大错误。Werf[1]是一个GitOps工具&#xff0c;可以很好地集成到任何CI/CD系统中&#xff0c;并提供完整的应用程序生命周期管理&#xff0c;允许你&#xff1a;构建和推送镜像部…

alxc tool 报错数组超出了界限_代码审计之报错信息泄露与字符串截断

机器在语言编码转换的时候&#xff0c;经常会出现各种各样的异常&#xff0c;这些神奇的字符串就有可能组合成一堆乱码出来&#xff0c;也有可能直接把程序搞崩溃掉&#xff0c;不过总有那么一些字符&#xff0c;可以帮助我们在利用漏洞的时候变得更简单一些&#xff0c;下面我…

C语言,去你的策略模式!

前言 这里先插一点题外话&#xff0c;在C语言中&#xff0c;实现封装、继承、隐藏、多态等等特性&#xff0c;是完全没有问题的。但是在使用过程中&#xff0c;必定是不如自带这些特性的语言方便好用的&#xff0c;比如C \java等。一旦要通过C语言来实现各种设计模式&#xff0…

eager_EAGER的获取是代码的味道

eager介绍 Hibernate获取策略确实可以使几乎没有爬网的应用程序和响应Swift的应用程序有所不同。 在这篇文章中&#xff0c;我将解释为什么您应该选择基于查询的获取而不是全局获取计划。 取得101 Hibernate定义了四种关联检索策略 &#xff1a; 提取策略 描述 加入 原始S…

什么时候会是用treeset?_flex:1 到底代表什么?

今天在做项目的时候遇到一个关于布局的问题, 就是 flex: 1; 我一直以为 flex: 1; 代表的是 flex: aoto; 后来发现结果并不是这样, 所以写一篇博客来讲解一下 flex: 1; 代表什么代码第一版<div class"container"><div class"div">我是一个div&l…

纠缠不清的C语言位域(位段)详解

位域是什么&#xff1f;有些数据在存储时并不需要占用一个完整的字节&#xff0c;只需要占用一个或几个二进制位即可。例如开关只有通电和断电两种状态&#xff0c;用 0 和 1 表示足以&#xff0c;也就是用一个二进位。正是基于这种考虑&#xff0c;C语言又提供了一种叫做位域的…

matlab画累计直方图_科学网—matlab 绘制直方图——常用命令 - 范凯波的博文

直方图上显示数值close all ,x rand(100,1);%获得直方图的数据[n,y] hist(x);maxN max(n);%设置显示x,y长度限制axis([0 1.2 0 maxN2])%根据直方图的数据绘制出图形bar(y,n);for i 1:length(y)%直方图上面数据对不齐&#xff0c;利用水平和垂直对齐 &#xff0c;可以参考se…