linuxsir首页 LinuxSir.Org | Linux、BSD、Solaris、Unix | 开源传万世,因有我参与欢迎您!
网站首页 | 设为首页 | 加入收藏
您所在的位置:主页 > Linux数据库 >

如何在Ubuntu 18.04上配置MySQL主从复制

时间:2019-05-19  来源:未知  作者:admin666

MySQL复制是一个允许来自一个数据库服务器的数据自动复制到一个或多个服务器的过程。

MySQL支持许多复制拓扑,其中主/从拓扑是一个最着名的拓扑之一,其中一个数据库服务器充当主服务器,而一个或多个服务器充当从服务器。默认情况下,复制是异步的,其中主服务器将描述数据库修改的事件发送到其二进制日志,并且从服务器在准备好时请求事件。

本教程介绍了在Ubuntu 18.04上使用一个主服务器和一个从服务器进行MySQL主/从复制的基本示例。同样的步骤适用于MariaDB。

此类复制拓扑最适合部署用于读取扩展的只读副本,用于灾难恢复和分析作业的实时数据库备份。

必要条件

此示例假设您有两台运行Ubuntu 18.04的服务器,它们可以通过专用网络相互通信。如果您的托管服务提供商不提供私有IP地址,您可以使用公共IP地址并配置防火墙,以允许端口3306上的流量仅来自可信来源。

此示例中的服务器具有以下IP:

Master IP(主服务器IP): 192.168.100.190
Slave IP(从服务器IP):  192.168.100.236

安装MySQL

默认的Ubuntu 18.04存储库包含MySQL 5.7版。 为避免出现任何问题,最好在两台服务器上安装相同的MySQL版本。

在Master服务器上安装MySQL:

sudo apt-get update
sudo apt-get install mysql-server

使用相同的命令在Slave服务器上安装MySQL:

sudo apt-get update
sudo apt-get install mysql-server

配置主服务器

第一步是配置主MySQL服务器。 我们将进行以下更改:

将MySQL服务器设置为侦听专用IP 设置唯一的服务器ID 启用二进制日志记录

为此,请打开MySQL配置文件并取消注释或设置以下内容:

sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf

master:/etc/mysql/mysql.conf.d/mysqld.cnf

bind-address          = 192.168.100.190
server-id              = 1
log_bin                = /var/log/mysql/mysql-bin.log

完成后,重新启动MySQL服务以使更改生效

sudo systemctl restart mysql

下一步是创建一个新的复制用户。 键入以下内容以root用户身份登录MySQL服务器:

sudo mysql

在MySQL提示符内,运行以下SQL查询,这些查询将创建副本用户并向用户授予REPLICATION SLAVE权限:

CREATE USER 'replica'@'192.168.100.236' IDENTIFIED BY 'replica_password';

GRANT REPLICATION SLAVE ON *.* TO 'replica'@'192.168.100.236';

确保使用从属IP地址更改IP。 您可以根据需要为用户命名。

在仍然在MySQL提示符内时,执行以下命令将打印二进制文件名和位置。

SHOW MASTER STATUS\G

输出:

*************************** 1. row ***************************
            File: mysql-bin.000001
        Position: 629
    Binlog_Do_DB:
 Binlog_Ignore_DB:
Executed_Gtid_Set:
1 row in set (0.00 sec)

记下文件名'mysql-bin.000001'和位置'629'。 配置从属服务器时,您将需要这些值。 您的服务器上的这些值可能会有所不同。

配置从属服务器

与上面的主服务器一样,我们将对从服务器进行以下更改:

将MySQL服务器设置为侦听专用IP 设置唯一的服务器ID 启用二进制日志记录

打开MySQL配置文件并编辑以下行:

sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf

slave:/etc/mysql/mysql.conf.d/mysqld.cnf

bind-address          = 192.168.100.236
server-id              = 2
log_bin                = /var/log/mysql/mysql-bin.log

重启MySQL服务:

sudo systemctl restart mysql

下一步是配置从服务器用于连接主服务器的参数。 登录MySQL shell:

sudo mysql

首先,停止slave线程:

STOP SLAVE;

运行以下查询,该查询将设置从服务器来复制主服务器:

CHANGE MASTER TO
MASTER_HOST='192.168.100.190',
MASTER_USER='replica',
MASTER_PASSWORD='replica_password',
MASTER_LOG_FILE='mysql-bin.000001',
MASTER_LOG_POS=629;

确保使用正确的IP地址,用户名。 和密码。 日志文件名称和位置必须与从主服务器获取的值相同。

完成后,启动从线程。

START SLAVE;

测试配置

此时,您应该有一个正常工作的主/从复制设置。

要验证一切是否按预期工作,我们将在主服务器上创建一个新数据库:

sudo mysql

CREATE DATABASE replicatest;

登录到从属MySQL shell:

sudo mysql

列出数据库:

SHOW DATABASES;

您会注意到在主服务器上创建的数据库是在从服务器上复制的:

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

总结

在本教程中,我们展示了您创建MySQL主/从复制。

如果您有任何疑问,请随时发表评论。

Linux公社的RSS地址:https://www.linuxidc.com/rssFeed.aspx

上一篇:ORA
友情链接
  • Mozilla发布Firefox 67.0.4,修复沙箱逃逸漏洞
  • 蚂蚁金服正式成为CNCF云原生计算基金会黄金会员
  • Firefox 68将采用Microsoft BITS安装更新
  • OpenSSH增加对存储在RAM中的私钥的保护
  • 谷歌想实现自己的curl,为什么?
  • Raspberry Pi 4发布:更快的CPU、更大的内存
  • Firefox的UA将移除CPU架构信息
  • Ubuntu放弃支持32位应用程序实属乌龙,Steam会否重回Ubuntu怀抱
  • Qt 5.13稳定版发布:引入glTF 2.0、改进Wayland以及支持Lottie动
  • 红帽企业Linux 7现已内置Redis 5最新版
  • Slack进入微软内部禁用服务清单,GitHub也在其列?
  • 安全的全新编程语言V发布首个可用版本
  • Windows Terminal已上架,快尝鲜
  • 阿里巴巴微服务开源生态报告No.1
  • 面世两年,Google地球将支持所有基于Chromium的浏览器
  • 推进企业容器化持续创新,Rancher ECIC千人盛典完美收官
  • CentOS 8.0最新构建状态公布,或于数周后发布
  • Debian移植RISC
  • 微软拆分操作系统的计划初现雏形
  • Oracle发布基于VS Code的开发者工具,轻松使用Oracle数据库
  • Ubuntu 19.10停止支持32位的x86架构
  • 微软为Windows Terminal推出全新logo
  • 联想ThinkPad P系列笔记本预装Ubuntu系统
  • 微软发布适用于Win7/8的Microsoft Edge预览版
  • 启智平台发布联邦学习开源数据协作项目OpenI纵横
  • 经过六个多月的延迟,微软终于推出Hyper
  • ZFS On Linux 0.8.1 发布,Python可移植性工作
  • DragonFly BSD 5.6.0 发布,HAMMER2状态良好
  • Linux Kernel 5.2
  • CentOS 8.0 看起来还需要几周的时间
  • 百度网盘Linux版正式发布
  • PCIe 6.0宣布:带宽翻倍 狂飙至256GB/s
  • PHP 7.4 Alpha 发布,FFI扩展,预加载Opcache以获得更好的性能
  • Canonical将在未来的Ubuntu版本中放弃对32位架构的支持
  • Scala 2.13 发布,改进的编译器性能
  • 微软的GitHub收购了Pull Panda,并且使所有订阅完全免费
  • Windows Subsystem for Linux 2 (WSL 2)现在适用于Windows 10用
  • Debian 10 “Buster”的RISC
  • MariaDB宣布发布MariaDB Enterprise Server 10.4
  • DXVK 1.2.2 发布,带来微小的CPU开销优化
  • DragonFlyBSD 5.6 RC1 发布,VM优化,默认为HAMMER2
  • PrimeNG 8.0.0 发布,支持Angular 8,FocusTrap等
  • GIMP 2.10.12 发布,一些有用的改进
  • 清华大学Anaconda 镜像服务即将恢复
  • Debian GNU/Linux 10 “Buster” 操作系统将于2019年7月6日发布
  • 时时彩论坛
  • 五星体育斯诺克
  • 北单比分直播
  • 河北11选5走势图
  • 福建体彩36选7开奖结果
  • 九龙图库下载