一文教你在 CentOS7 下安装 MySQL 及搭建主从复制

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 一篇文章,教你搞定 MySQL 主从复制。

01、CentOS7 下安装 MySQL

1,wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm
2,rpm -ivh mysql-community-release-el7-5.noarch.rpm
3,yum install mysql-community-server
4,service mysqld restart(此为重启MySQL服务命令)
5,mysql -uroot -p(此为进入MySQL命令)

至此,就算安装完毕。刚安装上 MySQL 时,是没有密码的,所以运行第 5 个命令之后,直接回车,就能进入到 MySQL 界面,如图,即表示成功


25.jpg

02、MySQL 修改密码

没有密码就能进入 MySQL ,安全性肯定是不能保证的,所以接下来介绍一下,如何修改密码。运行以下命令即可(这里以将密码改为 root 为例):

use mysql;
update user set password=password("root") where user='root';
flush privileges;
exit;

检测密码是否成功,重新进入 MySQL :

mysql -uroot -p

输入root之后,能看到如下界面,即为成功:

26.jpg

03、MySQL搭建主从复制

写在前面:搭建主从复制的前提是,都安装好了 MySQL 。这篇文章以 192.168.243.133 为主,192.168.243.132 为从为例,来演示搭建过程。同时请注意,MySQL 密码为 root

  1. 133 为主,132 为从,从 133 上面,进入 MySQL 给 132 授权:
grant replication slave on *.* to 'root'@'192.168.243.132' identified by 'root';

参数说明:

  • 用户名:root
  • 密码:root
  • 意为:允许192.168.243.132使用用户名为root,密码为root访问133

成功效果如图:

27.jpg

  1. 开启 133 的 binarylog

MySQL Binary Log 也就是常说的 bin-log  ,是 mysql 执行改动产生的二进制日志文件,其主要作用有两个:

  • 数据恢复
  • 主从数据库。用于 slave 端执行增删改,保持与 master 同步。
编辑my.cnf这个配置文件:vi /etc/my.cnf
将以下内容保存至该配置文件中:
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
server-id=1
log-bin=mysql-bin
expire_logs_days= 7
max_binlog_size= 100m                       //binlog每个日志文件大小
binlog_cache_size= 4m                        //binlog缓存大小
max_binlog_cache_size= 512m                     //最大binlog缓存大小
binlog-do-db=401_test
lower_case_table_names=1

具体如图:

28.jpg

进入 mysql ,查看 binary 是否开启成功:

29.jpg

  1. 133 和 132 上面分别创建数据库。此处以 401_test (如果数据库和我的不同,则主从的 my.cnf 上面相对应的数据库名称都要更改)为例
创建数据库:create database 401_test;
  1. 编辑 132 的 my.cnf 文件:
编辑my.cnf配置文件:vi /etc/my.cnf
将以下内容保存至该配置文件中:
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
log-bin=mysql-bin
binlog_format=mixed
server-id=2
replicate-do-db=401_test

与 133 稍微有些不同,请注意。效果如图:

30.jpg

  1. 查看 133 的 binary 日志位置,这在后续配置 132 时会用到。连接 MySQL ,使用命令查看 binary
show master status\G

31.jpg

具体解析:
File:日志名称
Position:日志偏移量
Binlog_Do_DB:记录日志的库
  1. 开启 132 的同步:在 132 上面运行以下命令:
CHANGE MASTER TO
    -> MASTER_HOST='192.168.243.133',
    -> MASTER_USER='root',
    -> MASTER_PASSWORD='root',
    -> MASTER_LOG_FILE='mysql-bin.000002',
    -> MASTER_LOG_POS=120;

具体如图:

32.jpg

HOST:主节点ip
USER: 133 授权给 132 的用户名
PASSWORD:授权给 132 的密码
MASTER_LOG_FILE: 133 的日志名称
MASTER_LOG_POS:日志偏移量,需要和 133 的一样
如果忘记了,请回看第 5 步
  1. 查看 132 的 slave 线程是否开启:
show slave status\G

33.jpg

Slave_IO_Running为读取master的binaryLog的线程 Slave_SQL_Running为执行SQL的线程 这两个线程必须都为YES才可以实现主从复制 至此主从复制就搭建完了。

04、MySQL搭建互为主从

在以上配置的基础之上,将 132 作为 master , 133 作为 slave 进行再次配置。

  1. 在 132 上面连接 MySQL 之后,为 133 授权
grant replication slave on *.* to 'root'@'192.168.243.133' identified by 'root';
  1. $查看 132 的 binarylog
show master status;

34.jpg

  1. 开启 133 的同步(这里的步骤和 132 配置相同,我就不在这里展示了,如果忘记了,可以往上面再翻翻看)
  2. 查看 133 slave 的状态:
show slave status\G;

35.jpg

可能出现的错误:

36.jpg

解决办法:出现上图的错误就先将 slave 停掉,再操作一遍,使用命令: STOP SLAVE ,(此处命令必须为大写) 开启完同步之后需要打开 slave ,使用命令: START SLAVE (此处命令必须为大写)。至此,搭建互为主从复制结束。

05、常用到的命令

在这个过程中有几个命令是常用到的,来总结一下(#后面为注释内容):

进入 mysql :mysql -uroot -p
重启 mysql :systemctl restart mysql或service mysqld restart
查看 slave 线程:show slave status\G
mysql 授权命令:GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root';
#参数说明:
#第一个 root 是 mysql 的用户名
#第二个 root 是 mysql 的密码
# %表示所有机器都可以通过用户名 root ,密码 root 访问该 mysql
flush privileges ;  #使修改生效
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
39 4
|
1月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
86 3
|
1月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。
本文介绍了在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。内容涵盖准备工作、下载源码、编译安装、配置服务、登录设置及实践心得,帮助读者根据需求选择最适合的安装方法。
60 2
|
1月前
|
存储 SQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(1)作者——LJS[含MySQL的下载、安装、配置详解步骤及报错对应解决方法]
Mysql And Redis基础与进阶操作系列(1)之[MySQL的下载、安装、配置详解步骤及报错对应解决方法]
|
1月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
109 2
|
24天前
|
运维 关系型数据库 MySQL
安装MySQL8数据库
本文介绍了MySQL的不同版本及其特点,并详细描述了如何通过Yum源安装MySQL 8.4社区版,包括配置Yum源、安装MySQL、启动服务、设置开机自启动、修改root用户密码以及设置远程登录等步骤。最后还提供了测试连接的方法。适用于初学者和运维人员。
148 0
|
3天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
48 15
|
4天前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
8天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。