[转帖]mysql数据库主从配置

mysql数据库主从配置

https://www.toutiao.com/i6680489302947791371/

多做实验 其实挺简单的 很多东西 要提高自信 去折腾. 

架构与我 2019-04-16 21:50:24

在一篇文章《离线安装mysql数据库》,讲解了离线安装mysql数据库的过程,本文将讲解mysql数据库的主从配置方法。mysql数据库进行主从配置后,可以实现数据库的备份、同时应用也可以实现读写分离,提高应用的并发量。

1、主从原理

从《高性能mysql》书中讲解主从原理大致有三个步骤:

  • 在主库上把数据更改记录到二进制日志中(Binary Log)中,这些记录称为二进制日志事件。
  • 从库通过IO线程将主库上的日志复制到自己的中继日志(Relay Log)中。
  • 从库通过SQL线程读取中继日志中的事件,将其重放到自己数据上。

原理图为:

2、主从配置

演示的环境如下:

首先在这两台服务器安装mysql数据库,安装方法参考《离线安装mysql数据库》

(1)、配置主库

  • 修改my.cnf文件,在[mysqld]加入下面的内容:
# 服务的唯一编号server-id = 1?# 开启mysql binlog功能log-bin = mysql-bin?# binlog记录内容的方式,记录被操作的每一行binlog_format = ROW?# 减少记录日志的内容,只记录受影响的列binlog_row_image = minimal?# 指定需要复制的数据库名为jgywbinlog-do-db = jgyw
  • 修改好配置文件,重启mysql服务
service mysqld restart
  • 创建从库同步数据的账号
grant replication slave on *.* to ‘jgyw‘@‘192.168.197.136‘ identified by ‘[email protected]‘;flush privileges;

注意:上面这两个命令是在mysql的终端执行的。

  • 查看主库的状态:

mysql的终端执行:

show master statusG;

返回的信息为:

*************************** 1. row *************************** File: mysql-bin.000002 Position: 2380 Binlog_Do_DB: jgyw Binlog_Ignore_DB: Executed_Gtid_Set: 1 row in set (0.00 sec)

(2)、配置从库

  • 修改my.cnf文件,在[mysqld]加入下面的内容:
# 服务的唯一编号server-id = 2?# 开启mysql binlog功能log-bin = mysql-bin?# binlog记录内容的方式,记录被操作的每一行binlog_format = ROW?# 减少记录日志的内容,只记录受影响的列binlog_row_image = minimal?# 指定需要复制的数据库名为jgywreplicate-do-db = jgyw
  • 修改好配置文件,重启mysql服务
service mysqld restart
  • 执行同步命令

mysql的终端执行:

# 设置主服务器ip,同步账号密码,同步位置change master to master_host=‘192.168.197.135‘,master_user=‘jgyw‘,master_password=‘[email protected]‘,master_log_file=‘mysql-bin.000002‘,master_log_pos=2380;?# 开启同步功能start slave;
  • 查看从库的状态

mysql的终端执行:

show slave statusG;

返回信息为:

注意:Slave_IO_Running和Slave_SQL_Running的状态都为Yes时,说明从库配置成功。

3、测试

(1)、在主库上创建jgyw模式,即:

create schema jgyw;

(2)、在主库上的jgyw模式里面创建comm_config表,即:

use jgyw;CREATE TABLE comm_config (configId varchar(200) NOT NULL ,configValue varchar(1024) DEFAULT NULL ,description varchar(2000) DEFAULT NULL ,PRIMARY KEY (configId)) ENGINE=InnoDB DEFAULT CHARSET=utf8 ;

(3)、在主库上往comm_config表中插入一条记录,即:

insert into comm_config(configId, configValue, description) values(‘name‘, ‘架构与我‘, ‘测试一下‘);

(4)、在从库上查看模式,即:

show schemas;

结果为:

+--------------------+| Database |+--------------------+| information_schema || jgyw || mysql || performance_schema || sys |+--------------------+5 rows in set (0.00 sec)

说明jgyw模式同步到从库了

(5)、在从库上查看jgyw模式下的表及数据,即:

use jgyw;show tables;

结果为:

+----------------+| Tables_in_jgyw |+----------------+| comm_config |+----------------+1 row in set (0.00 sec)

说明表也同步好了,再查看数据,即:

select * from comm_config;

结果为:

+----------+--------------+--------------+| configId | configValue | description |+----------+--------------+--------------+| name | 架构与我 | 测试一下 |+----------+--------------+--------------+1 row in set (0.00 sec)

说明数据也同步过来了。

原文地址:https://www.cnblogs.com/jinanxiaolaohu/p/10796917.html

时间: 2024-10-11 18:28:20

[转帖]mysql数据库主从配置的相关文章

Linux系统中MySQL数据库“主从”配置

MySQL数据库"主从"配置 一.配置概述: 在Linux操作系统中配置MySQL数据库的主从复制是很重要的,为什么这样说呢!是因为在你搭建一个服务器以后你配置了2台数据库,一主一从.2台数据库配置好以后,当其中一台数据库被攻击以后,你被攻击的这台数据库的数据会被自动的备份到另一台数据库中去.即使被攻击了数据也不会丢失.配置主从就是为了让web网站或其他的软件可以正常运转,确保数据的存在. 二.配置步骤: <配置具备的条件> 1.需要在虚拟机上安装好两台主机,同时安装好同一

mysql数据库主从配置

MySQL支持单向.异步复制,复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器.主服务器将更新写入二进制日志文件,并维 护日志文件的一个索引以跟踪日志循环.当一个从服务器连接到主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置.从服务器接收从那 时起发生的任何更新,然后封锁并等待主服务器通知下一次更新. 为什么使用主从复制? 1.主服务器/从服务器设置增加了健壮性.主服务器出现问题时,你可以切换到从服务器作为备份. 2.通过在主服务器和从服务器之间切分处理

mysql数据库主从配置及还原

主数据库服务器的配置master 51 做主从配置要保持两个数据库中的库和表一致 1 做用户授权2 启用binlog日志3 查看正在使用的binlog日志文件1. mysql> grant replication slave on . 授权.(所有的库和表)-> to-> [email protected]"%" 可用%代表所有,也可指定具体ip地址-> identified by "123456"; 指定密码2.]#vim /etc/my.

mysql数据库主从配置的几种方式

摘录地址:http://www.cnblogs.com/stacks/p/7171648.html 1.主从复制集群: 主服务器负责数据写入,从服务器负责读操作. 主服务器所有的操作都写入二进制日志,从服务器开启中继日志和两个线程: (1)sql_thread:负责从中继日志读取内容,然后replay到数据库中: (2)io_thread:负责连接主服务器,把主服务器的二进制日志复制到自己的中继日志: 2.双主复制集群配置 主服务器和从服务器同时开启二进制日志和中继日志,数据可以写入任何一个服务

linux下mysql数据库主从同步配置

说明: 操作系统:CentOS 5.x 64位 MySQL数据库版本:mysql-5.5.35 MySQL主服务器:192.168.21.128 MySQL从服务器:192.168.21.129 准备篇: 说明:在两台MySQL服务器192.168.21.128和192.168.21.129上分别进行如下操作 备注: 作为主从服务器的MySQL版本建议使用同一版本! 或者必须保证主服务器的MySQL版本要高于从服务器的MySQL版本! 一.配置好IP.DNS .网关,确保使用远程连接工具能够连接

mysql数据库主从同步配置教程--数据库同步

背景: 最近有一个mysql数据库同步的需求,我用了mysql主从同步的方法来实现.下面把步骤记录一下. 环境和拓扑 操作系统:Centos6.6 X64 mysql版本:5.1.73 Master: 10.6.1.210 Slave:  10.6.1.211 需求: 实现Master上test库同步到Slave上,但是禁止同步该库下的AA表 1.配置Master上的my.cnf #vim  /etc/my.cnf 添加内容到[mysqld]下,设定只同步test 数据库: [mysqld] l

mysql_multi方式配置Mysql数据库主从

如上面所说:http://www.cnblogs.com/super-d2/p/3851957.html 安装好mysql; 授予用于同步用的用户同步数据的权限 grant replication slave on *.* to 'slave3306'@'127.0.0.1' identified by '3306'; flush privileges; 此时查看主从状态,如下 show master status; 配置多数据库: 内容如下: [mysqld_multi] mysqld    

mysql数据库主从同步

环境: Mater:   CentOS7.1  5.5.52-MariaDB  192.168.108.133 Slave:   CentOS7.1  5.5.52-MariaDB  192.168.108.140 1.导出主服务数据,将主备初始数据同步 master: //从master上导出需要同步的数据库信息 mysqldump -u*** -p*** --database test > test.sql //将master上的备份信息传输到slave上 scp /root/test.sq

谈谈Mysql数据库主从同步延迟分析及解决方案

一.MySQL的数据库主从复制原理 MySQL主从复制实际上基于二进制日志,原理可以用一张图来表示: 分为四步走: 1. 主库对所有DDL和DML产生的日志写进binlog: 2. 主库生成一个 log dump 线程,用来给从库I/O线程读取binlog: 3. 从库的I/O Thread去请求主库的binlog,并将得到的binlog日志写到relay log文件中: 4. 从库的SQL Thread会读取relay log文件中的日志解析成具体操作,将主库的DDL和DML操作事件重放. 关