MySQL复制拓扑1

本文详细介绍了如何在Linux系统上安装MySQL8.0服务器,涉及从ISO镜像文件提取、解压、软链接、环境变量设置、my.cnf配置、数据库初始化、权限管理以及主从复制的原理和配置步骤。
摘要由CSDN通过智能技术生成

文章目录

主要内容

  1. 本实验的操作需同时在三台主机上进行,因此要确保各个主机上的 MySQL 服务器都正常运行,同时各主机之间的网络均可相互访问。
    预备知识
    MySQL主从复制是MySQL数据库中常用的一种高可用性和数据备份方案,它可以将主数据库的数据同步到从数据库,从而实现数据的备份和读写分离。下面是MySQL主从复制的详细原理及工程实现:
    1. 主从复制的原理:

主从复制的原理是通过在主数据库上记录所有的数据变更操作(如INSERT、UPDATE、DELETE)并将这些操作记录在二进制日志(Binary Log)中,然后从数据库通过读取主数据库的二进制日志来获取这些数据变更操作,并在从数据库上执行相同的操作,从而保持从数据库和主数据库的数据一致性。

一.安装MySQL服务器

1.MySQL 安装程序和其它文件保存在下发的 mysql8-files.iso 镜像文件中,可以使用虚拟光驱来提取到 Linux 文件系统。

在这里插入图片描述
在这里插入图片描述
在 server1 创建光盘镜像的挂载目录/mnt/cdrom,然后从挂载目录复制到根目录:

代码如下(示例):
 mkdir /mnt/cdrom
 mount /dev/cdrom /mnt/cdrom
 cp -R /mnt/cdrom/stage /

在这里插入图片描述

2.将 MySQL8.0 程序解压到 /opt 目录,再创建到 MySQL 默认安装目录 /usr/local/mysql 的软连接,访问默认安装目录时就会连接到实际的安装目录,这种方法非常方便后续软件版本升级:

代码如下(示例):
cd /opt
tar xf /stage/mysql-commercial-8*.tar.gz
ln -s /opt/mysql* /usr/local/msql
ls /usr/local/mysql/bin

在这里插入图片描述

3.将 mysql 客户机和使用程序的路径添加到 PATH 系统环境变量中,以便随时使用这些程序。

使用 vim 打开 root 用户的.bashrc 配置文件,添加 export PATH=$PATH:/usr/local/mysql/bin:
在这里插入图片描述
source ~/.bashrc 使修改在当前 shell 立即生效。

4.接着复制已经编写好的my.cnf配置文件到系统默认位置 /etc目录,并添加mysql用户,将来MySQL8 数据库服务器属于 mysql 所拥有,adduser-r 选项会创建一个非登录账户,以利于安全考虑

代码如下(示例):
cp /stage/my.cnf /etc/my.cnf
adduser -r mysql

在这里插入图片描述

5.接下来使用 mysqld –initialize 命令创建数据库

接下来使用 mysqld –initialize 命令创建数据库,该命令会在默认的数据目录 /var/lib/mysql 目录生成新数据库运行所必须的文件,包括三个系统数据库目录:msyqlperformance_schema、sys;innodb
存储引擎的系统表空间文件;服务器和客户端的 ssl 加密公钥和私钥文件;重做日志文件;还原表空间文件等。
在建库的同时,该命令还给 MySQL 服务器的最高管理账户 root 生成了一个临时口令,在初次登陆时需要重置 root 口令,否则不能执行进一步的操作。记录下该临时口令备用

代码如下(示例):
mysqld --initialize
ls /var/lib/mysql/

在这里插入图片描述

6.由于 pid-file 选项引用的是 /var/run/mysqld 目录,但该目录尚不存在,创建该目录并将其所有权授予 mysql 用户和组。

代码如下(示例):
cat /etc/my.cnf
mkdir /var/run/mysqld
chown mysql:mysql /var/run/mysqld/

在这里插入图片描述

7.现在就可以启动 mysqld 服务器进程,& 选项指示在后台运行:

代码如下(示例):
mysqld_safe &

在这里插入图片描述

8.为了能从 server1 主机上的 Linux 客户机访问 mysqld 服务器进程,需要配置 client 的 socket 选项,使用 vim 打开 /etc/my.cnf 配置文件,添加如下代码,保存退出。

在这里插入图片描述

9.使用 mysql 客户机以 root 用户登陆,输入建库时系统生成的临时口令 r7)k+DBJXe

代码如下(示例):
mysql -uroot -p

在这里插入图片描述

10.输入 ALTER USER USER() IDENTIFIED BY ‘oracle’; 语句重置 root 口令后,才能正常执行数据库操作:

代码如下(示例):
ALTER USER USER() IDENTFIDE BY 'oracle';

在这里插入图片描述

11.最后,配置 mysqld 系统服务,以便可以使用 Linux 操作系统的 systemctl 命令来管理 mysqld 服务。关闭 mysqld 服务:

代码如下(示例):
mysqladmin -uroot -p shutdown

在这里插入图片描述

12.复制 mysqld.service 服务配置文件到 systemd 系统目录,启用即可:

代码如下(示例):
cp /stage/mysqld.service /usr/lib/systemd/system
systemctl enable mysqld.service
systemctl starrt mysqld
systemctl status mysqld

ps aux | grep mysqld

在这里插入图片描述
在这里插入图片描述


总结

以上是今天要讲的内容,学到了MySQL复制拓扑的MySQL服务器配置。

  • 24
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

K要努力

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值