mysql 单机主从_《高可用MySQL》2 – 单机版MySQL主从配置

这里搭建的主从是最简单的单一主从复制(即一个Master和一个slave。没有不论什么的热机备份和多slave),该主从结构的基本拓扑图例如以下所看到的:

525b40e0d49632d1cffdc10d0fdf2c85.png

建立主要的主从复制能够总结为下面三个基本步骤:

配置masterserver

配置slaveserver

将slave连接到master

在配置完毕之后。我们会做一个简单的測试。測试复制是否正常。

本文所涉及的master和slaveserver均位于同一台单机上。使用不同的port号区分,主要的环境为:Window 7 旗舰版 32位。MySQL的版本号为5.6.21 。

上一篇笔记(Windows环境下压缩版MySQL安装)中,已经介绍了压缩版mysql配置的基本过程。这里须要复制一份,并解压缩到另外一个文件夹(比如D:/Mysql_slave文件夹中)。为了区分master和slave,我们分别使用不同的port号:master使用3306。slave使用3307port号。

一、配置Master

将server配置为Master,须要确保server有一个活动的二进制日志(binary log)和唯一的serverID(server-id,用于区分server).二进制日志中包括了Master的全部改变。而且能够在Slave上运行。

配置master的my.ini文件:

打开master文件夹下的my.ini文件,在文件里加入例如以下内容:

server-id = 1binlog-do-db =testlog-bin=master-binlog-bin-index=master-bin.index

当中:

(1)       server-id=1用于配置serverID,是mysql主从集群中的一个唯一区分号。全部的server都应该有自己的唯一ID,假设一个Slave连接到Master。可是和Master有同样的ID,则会产生Master和Slave ID同样的错误

(2)       binlog-do-db :指定主从复制的数据库。

(3)       log-bin字段给出了二进制日志所产生的全部文件的基本名,二进制文件能够包括多个文件。例如以下图所看到的:

c88fa1fd55b8b91c6f7247b8b31ebc74.png

(4)       log-bin-index.这事实上是指定了一个索引文件(纯文本,内容为文件列表)。该索引文件里包括全部二进制文件的列表。

假设没有为log-bin-index设置默认值。则会使用机器的hostname产生log-bin-index文件。这样。在server的hostname改变后。可能会出现无法找到索引文件,从而觉得二进制文件列表为空。导致无法正确的生成二进制bin-log。所以,推荐应该使用机器无关的名字作为bin-log-index的文件名称.

658f4640f5f3ba40280187ca3defc35d.png

配置完ini文件之后。须要从命令行启动mysqld服务,进入master的bin文件夹(D:.Mysql/bin)并运行下述命令(假设之前配置过mysql,运行之前请关闭已经启动的mysql服务net stop mysql):

mysqld --console

假设启动成功。cmd窗体会出现例如以下类似的内容(红色部分是关键):

a4cf058a5fa8ec1734c0a2a6cfec62b6.png

这时masterserver已经启动了.将该cmd窗体最小化不用管它。

新开一个cmd窗体,连接到master(mysql –u root -pxxx)。通过show master status能够查看master的状态。

Slave连接Master时,会启动一个标准的client去连接Master,并请求Master将全部的修改转储给它。因此。在连接时。须要Master上有一个具有复制权限的用户。在master的控制台运行例如以下命令:

Create userreply_user;Grant REPLICATION SLAVE On *.* to reply_user IDENTIFIED BY‘xxxxxxxxx’;

Flushprivileges;

Replication slave权限并没有什么特别之处,仅仅是这个用户能够从Master上二进制文件的转储数据。全然能够给一个常规的用户赋予该权限,但不妨将复制Slave的用户和其它用户区分开来。这种话。假设想要禁止某些slave的链接,仅仅要删除该用户就能够了

二、配置Slave

配置Slave的过程和配置Master的过程基本同样,不同的是,须要配置一个不同的port号,须要一个不同的server-id号。而且须要为Slave配置relay-log(中继日志)和relay-log-index(中继日志的索引文件)。打开Slave文件夹下的my.ini(D:/mysql_slave文件夹),加入例如以下内容:

48304ba5e6f9fe08f3fa1abda7d326ab.png

#mysql slave port

port= 3307#slave server id

server_id= 2#replication database

replicate-do-db=test

#relaylog filerelay-log=slave-relay-bin

#relaylog index filerelay-log-index=slave-relay-bin.index

48304ba5e6f9fe08f3fa1abda7d326ab.png

改动完Slave后。相同须要通过命令启动slave的mysqld:

d:

cd mysql_slave/bin

mysqld --console

如今尽管配置好了Master和Slave。可是Master和Slave之间没有不论什么的联系。这时假设在Slave的控制台运行:show slave status;会出现提示:it is not a slave

三、Slave连接到Master

将Slave连接到Master,须要知道Master的四个主要的信息:

(1)       主机名或者IP地址,因为这里都是单机,主机的IP为127.0.0.1

(2)       Master使用的port号。3306

(3)       Master上具有REPLICATION SLAVE权限的用户

(4)       该账号的password。

在配置Master的时候已经创建了一个具有相关权限的用户。在Slave的控制台执行下面命令:

Change Master toMaster_host=’127.0.0.1’,

Master_port=3306,

Master_user=”reply_user”,

Master_Password=”xxxx”;

运行完之后,能够通过start Slave命令启动Slave。

这时假设运行show slave status;会输出下面类似内容(注意标红部分):

1a3157857f45b4052306901f5db87cd3.png

如今,一个主要的mysql主从已经搭建起来了。我们接着做一些简单的測试,看看复制是否正常。測试过程例如以下:

1.  在Master上创建表:

48304ba5e6f9fe08f3fa1abda7d326ab.png

CREATE TABLE`web_user2` (

`id`int(10) unsigned NOT NULLAUTO_INCREMENT,

`name`varchar(30) NOT NULL DEFAULT '',

`creatime`datetime NOT NULL DEFAULT '0000-00-00 00:00:00',PRIMARY KEY(`id`)

) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

48304ba5e6f9fe08f3fa1abda7d326ab.png

2.  插入数据

Insert into web_user2 (`name`) values ('first'),('test'),('showb'),('blood');Select * from `web_user2`;

3.  进入Slave查看是否同步正常

Show tables;Select * from web_user;

4.  在master的控制台上查看复制的事件-Binlog events

Flush logs;

Show binlog events;

日志比較长,这里仅仅截取了前两条:

f2381279864da15bd8be21596a755e85.png

从binlog的内容来看。复制已经配置成功了。

下一步。将会继续探索二进制日志的相关东西。

參考文献:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
东南亚位于我国倡导推进的“一带一路”海陆交汇地带,作为当今全球发展最为迅速的地区之一,近年来区域内生产总值实现了显著且稳定的增长。根据东盟主要经济体公布的最新数据,印度尼西亚2023年国内生产总值(GDP)增长5.05%;越南2023年经济增长5.05%;马来西亚2023年经济增速为3.7%;泰国2023年经济增长1.9%;新加坡2023年经济增长1.1%;柬埔寨2023年经济增速预计为5.6%。 东盟国家在“一带一路”沿线国家中的总体GDP经济规模、贸易总额与国外直接投资均为最大,因此有着举足轻重的地位和作用。当前,东盟与中国已互相成为双方最大的交易伙伴。中国-东盟贸易总额已从2013年的443亿元增长至 2023年合计超逾6.4万亿元,占中国外贸总值的15.4%。在过去20余年中,东盟国家不断在全球多变的格局里面临挑战并寻求机遇。2023东盟国家主要经济体受到国内消费、国外投资、货币政策、旅游业复苏、和大宗商品出口价企稳等方面的提振,经济显现出稳步增长态势和强韧性的潜能。 本调研报告旨在深度挖掘东南亚市场的增长潜力与发展机会,分析东南亚市场竞争态势、销售模式、客户偏好、整体市场营商环境,为国内企业出海开展业务提供客观参考意见。 本文核心内容: 市场空间:全球行业市场空间、东南亚市场发展空间。 竞争态势:全球份额,东南亚市场企业份额。 销售模式:东南亚市场销售模式、本地代理商 客户情况:东南亚本地客户及偏好分析 营商环境:东南亚营商环境分析 本文纳入的企业包括国外及印尼本土企业,以及相关上下游企业等,部分名单 QYResearch是全球知名的大型咨询公司,行业涵盖各高科技行业产业链细分市场,横跨如半导体产业链(半导体设备及零部件、半导体材料、集成电路、制造、封测、分立器件、传感器、光电器件)、光伏产业链(设备、硅料/硅片、电池片、组件、辅料支架、逆变器、电站终端)、新能源汽车产业链(动力电池及材料、电驱电控、汽车半导体/电子、整车、充电桩)、通信产业链(通信系统设备、终端设备、电子元器件、射频前端、光模块、4G/5G/6G、宽带、IoT、数字经济、AI)、先进材料产业链(金属材料、高分子材料、陶瓷材料、纳米材料等)、机械制造产业链(数控机床、工程机械、电气机械、3C自动化、工业机器人、激光、工控、无人机)、食品药品、医疗器械、农业等。邮箱:market@qyresearch.com
在CentOS 7下配置MySQL 5.7.22的主从复制,需要以下步骤: 1.安装MySQL 5.7.22版本 在CentOS 7上安装MySQL 5.7.22,可以使用如下命令: ``` sudo yum install mysql-server ``` 2.配置主服务器 在主服务器的配置文件`/etc/my.cnf`中添加如下内容: ``` server-id=1 log-bin=mysql-bin binlog-do-db=test ``` 其中,`server-id`表示服务器的ID,`log-bin`表示开启二进制日志,`binlog-do-db`表示指定需要同步的数据库名称。 3.重新启动MySQL服务器 在修改了配置文件后,需要重新启动MySQL服务器: ``` sudo systemctl restart mysqld ``` 4.创建用于复制的用户 在主服务器上创建一个用于复制的用户,并授予复制权限: ``` GRANT REPLICATION SLAVE ON *.* TO 'slave_user'@'%' IDENTIFIED BY 'password'; FLUSH PRIVILEGES; ``` 其中,`slave_user`是用于复制的用户名,`password`是用户密码。 5.查看主服务器状态 在主服务器上运行如下命令查看主服务器状态: ``` SHOW MASTER STATUS; ``` 记录下`File`和`Position`的值,备用。 6.配置从服务器 在从服务器的配置文件`/etc/my.cnf`中添加如下内容: ``` server-id=2 replicate-do-db=test ``` 其中,`server-id`表示服务器的ID,`replicate-do-db`表示指定需要同步的数据库名称。 7.重新启动MySQL服务器 在修改了配置文件后,需要重新启动MySQL服务器: ``` sudo systemctl restart mysqld ``` 8.设置从服务器复制主服务器 在从服务器上运行如下命令,设置从服务器复制主服务器: ``` CHANGE MASTER TO MASTER_HOST='master_host_name', MASTER_USER='slave_user', MASTER_PASSWORD='password', MASTER_LOG_FILE='master_log_file_name', MASTER_LOG_POS=master_log_pos; ``` 其中,`master_host_name`是主服务器的IP地址或主机名,`slave_user`和`password`是用于复制的用户名和密码,`master_log_file_name`和`master_log_pos`是之前在主服务器上记录的值。 9.启动从服务器复制 在从服务器上运行如下命令,启动从服务器复制: ``` START SLAVE; ``` 10.查看从服务器状态 在从服务器上运行如下命令查看从服务器状态: ``` SHOW SLAVE STATUS\G ``` 如果输出中`Slave_IO_Running`和`Slave_SQL_Running`的值都为`Yes`,则表示从服务器已经成功复制主服务器。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值