mysql multi主从复制_mysqld_multi方式配置Mysql数据库主从复制

mysqld_multi设计用于管理在同一台机器上运行的多个mysqld进程,这些进程使用不同的socket文件并监听在不同的端口上。mysqld_multi可以批量启动、关闭、或者报告这些mysqld进程的状态。在这里我们通过这种方式来在同一个机器上启动多个数据库实例,并配置主从关系。

1、下载MySQL压缩包

wget http://dev.MySQL.com/get/Downloads/MySQL-5.7/mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz

2、创建安装目录

这里我将Mysql安装在/usr/local/mysql目录里面,也可以安装在其他地方;

mkdir /usr/local/mysql

3、解压并复制

tar -xvf mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz

mv mysql-5.7.18-linux-glibc2.5-x86_64/* /usr/local/mysql/

4、创建data目录

mkdir /usr/local/mysql/data{3306,3307,3308} -p

5、创建mysql用户组及其用户

groupadd mysql

useradd -r -g mysql mysql

6、修改权限

chown -R mysql:mysql /usr/local/mysql

7、初始化实例的数据库

mysql_install_db 方式已经 deprecated 了,我们使用 mysqld 的 initialize 方法来做初始化

# --no-defaults 不读取默认的 /etc/my.cnf 全局配置文件 否则可能存在一些冲突问题

# --initialize-insecure 初始化且不需要生成密码,我不太喜欢那一大串字符...

# --basedir mysql 的安装目录

# --datadir 本实例的数据目录

# --user 这样生成的文件用户为 mysql

# --explicit_defaults_for_timestamp timestamp 已经 deprecated 了

#生成 3306 的数据目录

[root@localhost ~]# mysqld --no-defaults --initialize-insecure --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data3306 --user=mysql --explicit_defaults_for_timestamp

#生成 3307 的数据目录

[root@localhost ~]# mysqld --no-defaults --initialize-insecure --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data3307 --user=mysql --explicit_defaults_for_timestamp

#生成 3307 的数据目录

[root@localhost ~]# mysqld --no-defaults --initialize-insecure --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data3308 --user=mysql --explicit_defaults_for_timestamp

8、将mysql命令加入环境变量

在/etc/profile最后加入两行命令:

MYSQL_HOME=/usr/local/mysql

export PATH=$PATH:$MYSQL_HOME/bin

最后执行source /etc/profile,使得配置生效

9、创建/etc/my.cnf

[mysqld_multi]

mysqld=/usr/local/mysql/bin/mysqld_safe #mysqld命令的位置,用于启动mysql实例,也可以指定为mysqld_safe命令的位置

mysqladmin = /usr/local/mysql/bin/mysqladmin #用于停止mysql实例

user=root #调用mysqladmin时使用的账号

#password=123456 调用 mysqladmin时使用的账号的密码,因为我们使用了initialize-insecure,所以root用户最开始是没有密码的

log=/usr/local/mysql/mysql_multi.log

[mysqld3306]

basedir=/usr/local/mysql

datadir=/usr/local/mysql/data3306

port=3306

user=mysql

socket=/tmp/mysql.sock3306

server_id=1

log_bin=mysql-bin #主库

[mysqld3307]

basedir=/usr/local/mysql

datadir=/usr/local/mysql/data3307

port=3307

user=mysql

socket=/tmp/mysql.sock3307

server_id=2

[mysqld3308]

basedir=/usr/local/mysql

datadir=/usr/local/mysql/data3308

port=3308

user=mysql

socket=/tmp/mysql.sock3308

server_id=3

在mysqld_multi中配置的user和password是mysql的用户名和密码。为了使用mysqld_multi命令,每个mysql实例都必须要提供一个相同的用户名和密码,用于启动和停止服务。而且要确保这个用户具有停止mysql实例的权限。提示:

在[mysqlN]中配置的user是linux中的用户,是启动mysql服务实例时使用的用户

mysqld_multi提供了start, stop, reload (stop and restart)和report 表示要执行的不同操作。可以参见官方文档查看https://dev.mysql.com/doc/refman/5.7/en/mysqld-multi.html其完整用法,因为命令非常简单,这里不做过多介绍。

10、启动MySQL实例

[root@localhost mysql]# mysqld_multi start

11、查看3个实例的运行状态

[root@localhost mysql]# mysqld_multi report

Reporting MySQL servers

MySQL server from group: mysqld3306 is running

MySQL server from group: mysqld3307 is running

MySQL server from group: mysqld3308 is running

也可以通过netstat-tln来查看

[root@localhost Desktop]# netstat -tln|grep 330*

tcp 0 0 :::3307 :::* LISTEN

tcp 0 0 :::3308 :::* LISTEN

tcp 0 0 :::3306 :::* LISTEN

12 配置主从关系

打开3个命令行窗口,分别执行以下命令登录主从数据库:

mysql -h127.0.0.1 -uroot -P3306 -p

mysql -h127.0.0.1 -uroot -P3307 -p

mysql -h127.0.0.1 -uroot -P3308 -p

因为我们初始化数据库的时候,没有为root用生成密码,因此出现提示输入password的时候,直接按enter键就可以了。在这3个命令行窗口都执行以下命令,用于创建复制账号:

GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO slave@'localhost' IDENTIFIED BY 'slave';

33de785b14a163424be398b58a595ee4.png

理论上,只要再主库上创建复制账号即可,但是因为考虑到主备切换的问题,因此在从库上也创建复制账号。另外需要注意的是,从库从主库复制,本身只需要REPLICATION SLAVE权限即可,REPLICATION CLIENT权限是让这个用户拥有执行SHOW MASTER STATUS和SHOW SLAVE STATUS命令,也就是说这个权限是用于授予账户监视Replication状况的权力,我们将在之后看到这两个命令如何使用。

我们需要在3307和3308上,分别执行以下命令,将3306设置为主库,这一步是告诉备库如何连接到主库并重复其二进制日志,旧版本的方式是通过修改my.cnf来配置,但是在新的版本中,修改my.cnf的配置方式已经废弃。而是使用CHANGE MASTER TO 语句,该语句完全替代了my.cnf 中相应的设置,并且允许以后指向别的主库时无须重启备库。下面是复制开始的基本命令:

mysql> CHANGE MASTER TO

MASTER_HOST='localhost',

MASTER_USER='slave',

MASTER_PORT=3306,

MASTER_PASSWORD='slave',

MASTER_LOG_FILE='mysql-bin.000001',

MASTER_LOG_POS=0;

只需要配置一次即可,之后重启的时候,slave会自动连接到master同步数据,不需要每次都执行这些命令。

需要注意的是,此时复制并没有真正的开始,我们可以在主库3306上执行以下命令,,查看主库状态:

mysql> show master status;

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

| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |

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

| mysql-bin.000001 | 154 | | | |

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

1 row in set (0.00 sec)

mysql> show processlist;

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

| Id | User | Host | db | Command | Time | State | Info |

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

| 3 | root | localhost:58685 | NULL | Query | 0 | starting | show processlist |

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

1 row in set (0.00 sec)

在从库3307或者3308上,执行以下命令:

mysql> show slave statusG;

*************************** 1. row ***************************

Slave_IO_State:

Master_Host: localhost

Master_User: slave

Master_Port: 3306

Connect_Retry: 60

Master_Log_File: mysql-bin.000001

Read_Master_Log_Pos: 4

Relay_Log_File: localhost-relay-bin.000001

Relay_Log_Pos: 4

Relay_Master_Log_File: mysql-bin.000001

Slave_IO_Running: No

Slave_SQL_Running: No

Replicate_Do_DB:

Replicate_Ignore_DB:

...omitted....

Seconds_Behind_Master: NULL

...omitted....

1 row in set (0.00 sec)

Slave_IO_State、Slave_IO_Running、Slave_SQL_Running这三列显示备库复制尚未执行。

此时在从库3307和3308上分别执行以下命令,开始复制:

mysql> start slave;

此时在3307和3308上再执行show slave status,可以看到

mysql> show slave statusG;

*************************** 1. row ***************************

Slave_IO_State: Waiting for master to send event #等待主库发送bin-log同步事件

Master_Host: localhost

Master_User: slave

Master_Port: 3306

Connect_Retry: 60

Master_Log_File: mysql-bin.000001

Read_Master_Log_Pos: 4

Relay_Log_File: localhost-relay-bin.000001

Relay_Log_Pos: 4

Relay_Master_Log_File: mysql-bin.000001

Slave_IO_Running: Yes #状态变为YES

Slave_SQL_Running: Yes #状态变为YES

Replicate_Do_DB:

Replicate_Ignore_DB:

...omitted....

Seconds_Behind_Master: NULL

...omitted....

此时再查看主库3306的状态

mysql> show processlistG;

*************************** 1. row ***************************

Id: 3

User: root

Host: localhost:58685

db: NULL

Command: Query

Time: 0

State: starting

Info: show processlist

*************************** 2. row ***************************

Id: 4

User: slave

Host: localhost:35312

db: NULL

Command: Binlog Dump

Time: 161

State: Master has sent all binlog to slave; waiting for more updates

Info: NULL

*************************** 3. row ***************************

Id: 5

User: slave

Host: localhost:35313

db: NULL

Command: Binlog Dump

Time: 154

State: Master has sent all binlog to slave; waiting for more updates

Info: NULL

3 rows in set (0.00 sec)

可以看有2个线程执行了Binlog Dump命令,这就是我们的两个从库已经开始复制。

现在在主库3306上创建一个库draon_ha,在其中创建一个表user,并插入一条记录,这数据都会自动同步到两个从库中

CREATE DATABASE `dragon_ha`;

use dragon_ha;

CREATE TABLE `user` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`name` varchar(255) NOT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

insert into user(name) values('tianshouzhi');

mysql> show databases;分别在3307和3308两个从库中执行以下命令,查看数据是否已经同步:

mysql> show databases;

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

| Database |

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

| information_schema |

| dragon_ha |#插入的库已经同步

| mysql |

| performance_schema |

| sys |

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

5 rows in set (0.00 sec)

mysql> use dragon_ha;

Reading table information for completion of table and column names

You can turn off this feature to get a quicker startup with -A

Database changed

mysql> show tables;

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

| Tables_in_dragon_ha |

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

| user |#插入的表已经同步

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

1 row in set (0.00 sec)

mysql> select * from user;

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

| id | name |

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

| 1 | tianshouzhi |#插入的记录已经同步

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

1 row in set (0.00 sec)

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

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

相关文章

mysql中if在oracle怎么用_mysql和oracle的mybatis操作

1.Oracle、MySQL插入时返回下一个主键的操作Xml代码 Oracle:SELECT SEQ_ROLE.NEXTVAL AS ID FROM DUALinsert into ROLE(ID, NAME, CREATE, MODIFY) values (#{id}, #{name}, sysdate, sysdate)注意:这边的keyProperty"id"中"id"指的…

mysql数据库的三级模式_2016年计算机三级MySQL数据库试题

2016年计算机三级MySQL数据库试题一、选择题1.E-R图提供了表示信息世界中实体、属性和________的方法。A.数据B.联系C.表D.模式2.数据库系统的核心是________。A.数据模型B.数据库管理系统C.数据库D.数据库管理员3.E-R图是数据库设计的工具之一,它一般适用于建立数据…

mysql没加引号导致全表扫描_mysql隐蔽的索引规则导致数据全表扫描

索引是为了加速数据的检索,但是不合理的表结构或适应不当则会起到反作用。我们在项目中就遇到过类似的问题,两个十万级别的数据表,在做连接查询的时候,查询时间达到了7000多秒还没有查出结果。首先说明,关联的字段都已…

mysql 多个密码登录_mysql 多实例登录密码测试

最近在做mysql 多实例的时候,采用不同的方式登录mysql数据库,发现mysql -uroot -p -h 127.0.0.1 -P3308 ,登录时居然不要密码就可以登录,吓得我一身汗,经过检查终于找到原因记录下来,给小白们参考。[rootmy…

redhat5.4 安装mysql_Linux redhat 5.4上安装MYDNS

Linux redhat 5.4上安装MYDNS一、1,MYDNS 的简介:MyDNS是一个UNIX平台下的免费DNS服务器端软件。它被设计成直接从数据库中读取DNS记录软件,并且修改记录后也可时时生效。在MyDNS上,你可随心所欲地增加你自己的次级域名的同时建站…

java的反射机制是什么_JAVA反射机制

一、什么是反射机制 简单的来说,反射机制指的是程序在运行时能够获取自身的信息。在java中,只要给定类的名字,那么就可以通过反射机制来获得类的所有信息。二、哪里用到反射机制 有些时候,我们用过一些知识&#xf…

java unsafe park_Java魔法类——Unsafe应用解析

前言Unsafe是位于sun.misc包下的一个类,主要提供一些用于执行低级别、不安全操作的方法,如直接访问系统内存资源、自主管理内存资源等,这些方法在提升Java运行效率、增强Java语言底层资源操作能力方面起到了很大的作用。但由于Unsafe类使Java…

计算机视觉基础(12)——图像恢复

前言 我们将学习图像恢复相关知识。主要有图像恢复的定义、评价标准和实现图像恢复的方法。图像恢复任务包括图像去噪、去模糊、图像超分辨率、图像修复等;评价标准有峰值信噪比和结构相似性;图像超分辨的方法有传统方法和基于深度学习的方法&#xff1a…

百度编辑器图片上传 java_百度编辑器粘贴图片自动上传到服务器(Java版)

ChromeIE默认支持粘贴剪切板中的图片,但是我要发布的文章存在word里面,图片多达数十张,我总不能一张一张复制吧?Chrome高版本提供了可以将单张图片转换在BASE64字符串的功能。但是无法处理多张图片。而且转换成BASE64后是作为内容…

matlab解方java_Java:调用window的matlab遇到的问题和解决方案

描述容易报错的问题和可能原因1.java.lang.NullPointerException解决途径:window和linux的文件路径不同,window分隔符是\\,linux是/2.Exception in thread “main” java.lang.ExceptionInInitializerError解决途径:matlab生成的j…

java中的输入语句判断正负_在java中使用方法调用统计数组中正数的个数,将判断数据的正负功能定义成方法...

满意答案donglin820推荐于 2018.04.21public class TestDemo {static int count 0;// 统计整数的个数public static void main(String[] args) {int[] number new int[10];// 动态生成一个整数数组(长度为10)Scanner s new Scanner(System.in);for (int i 0; i < 10; i)…

java二级考试有草稿纸吗_“大型考试”为什么需要回收草稿纸?学生:这么多年也没整明白!...

在大家的求学生涯中&#xff0c;肯定不难发现这个事情&#xff0c;那就是学生考完试不能带走草稿纸&#xff0c;尤其是高考、中考这种全国统一大型考试&#xff0c;英语四六级等等&#xff0c;而一些初中高中、大学院校内部期末考试也是这样。学校和考场提供统一草稿纸目的是非…

expressjs如何做mysql注入_Node.js+Express+Mysql 实现增删改查

这次选用nodejsexpressmysql 使用http作为客户端&#xff0c;express框架搭建服务端&#xff0c;从而实现数据的增删改查。这篇文章可以算作上篇文章的升级篇&#xff0c;加入了和数据库的交互。安装node 直接去官网下载选择下载即可https://nodejs.org/en/download/current/cn…

docker pxc mysql_docker安装pxc集群的详细教程

前言现在mysql自建集群方案有多种&#xff0c;keepalived、MHA、PXC、MYSQL主备等&#xff0c;但是目前根据自身情况和条件&#xff0c;选择使用pxc的放来进行搭建&#xff0c;最大的好处就是&#xff0c;多主多备&#xff0c;即主从一体&#xff0c;没有同步延时问题&#xff…

php微信开源框架,SOPHP免费微信开源框架 php版 v4.5

SOPHP是一款稳定开源的微信公众平台开发系统,也是基于weiphp开发的第一款商业系统。依托自身强大的钩子功能&#xff0c;她可以帮助大家快速开发出自己想要的微信功能插件&#xff0c;运营近两年来我们收获了上千用户与良好的口碑。作为一个开源产品&#xff0c;希望大家都能参…

java系统管理员停用,为什么犯错让我成为一个更好的系统管理员

诀窍就是同一个错误不要犯两次。到目前为止&#xff0c;我已做了十多年 Fedora 贡献者。 Fedora 有一个由开发者和用户组成的大型社区&#xff0c;其中每一个人&#xff0c;不管是极富洞察力的用户还是出色的程序员&#xff0c;都有一些独有的技能。我喜欢这样的社区&#xff0…

php ajax json 实例,php+ajax+json 详解及实例代码

phpajaxjson 实例代码html页面&#xff1a;$(function(){$("#send").click(function(){var cont $("input").serialize();$.ajax({url:ab.php,type:post,dataType:json,data:cont,success:function(data){var str data.username data.age data.job;$(&…

php 五颗星评价,简单实现点触/输入值给五颗星评价

先上效果图gif.gif1.码UI。。。UILabel *label [[UILabel alloc] initWithFrame:CGRectMake(0, 0, kScreenWidth, 30)];label.text "点击星星可以自动获取评分哦&#xff5e;";label.textColor [UIColor whiteColor];label.textAlignment NSTextAlignmentCenter;…

oracle1461,Oracle 10.2.0.3的ORA-1461错误

Oracle 10.2.0.3的ORA-1461错误ORA-1461 encountered when generating server alert SMG-3500经研究发现&#xff0c;其是Oracle 10g的一个Bug&#xff0c;并且目前只有Oracle 10.2.0.3会遇到&#xff1a;造成这个错误的原因是由于SMON 进程正在 UPDATE SMON_SCN_TIME表时引发了…

linux uefi无法启动文件,解决UEFI安装无法启动的问题

前言我们产品是支持UEFI安装的&#xff0c;在很多款机器上都正常的安装。今日在浪潮服务器和技嘉服务器上都遇到一次&#xff0c;可以安装&#xff0c;但是无法正常启动。所以我们必须要解决此问题&#xff0c;来支持更多的硬件。基础知识EFI的全称是&#xff0c;Extensible Fi…