mysql5.7.21安装和主从同步

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 本篇博客带来Mysql5.7.21的安装和主从复制配置。转载请注明出处 http://blog.lzoro.commysql碎碎念惯例碎碎念。

本篇博客带来Mysql5.7.21的安装和主从复制配置。
转载请注明出处 http://blog.lzoro.com

mysql

碎碎念

惯例碎碎念。

很久之前就做过mysql的部分应用架构,包括主从复制和集群等,一直没有形成博客记录下来,虽然网上也有很多的相关资料,但是出于加深记忆,还是把自己的操作步骤和截图一步步记录下来,回头忘了也可以回顾,当然,也希望有小伙伴能得到帮助。

环境

一台装有vsphere6.5的宿主机,和宿主机上的centos虚拟机若干。

1、vsphere 6.5
2、centos 7
3、mysql 5.7
4、navicat 8 
5、windows 10

安装mysql

1、yum方式安装
# 进入文件夹
cd /usr/local
# 创建你自己的文件夹
mkdir zoro zoro/setup
# 进入创建的文件夹
cd zoro/setup
# 下载官方yum源包
wget https://repo.mysql.com//mysql57-community-release-el7-11.noarch.rpm
# 赋予执行权限
chmod +x mysql57-community-release-el7-11.noarch.rpm
# 本地安装,一路Y就行了
yum localinstall mysql57-community-release-el7-11.noarch.rpm
# 启动
systemctl start mysqld
# 获取临时密码
grep 'temporary password' /var/log/mysqld.log
# 登录mysql
mysql -uroot -pYourPwd
# 修改密码 OR 配置等,你想干嘛就干嘛
wget下载
赋予执行权
本地安装
验证本地安装
安装1
安装2
获取临时密码
2、二进制安装
# 进入文件夹
cd /usr/local
# 创建你自己的文件夹
mkdir zoro zoro/setup
# 进入创建的文件夹
cd zoro/setup
# 下载二级制包,地址二选一

# 官网镜像,跟乌龟似的
wget https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz
# 国内镜像,速度杠杠的
wget http://mirrors.ustc.edu.cn/mysql-ftp/Downloads/MySQL-5.7/mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz

# 解压缩
tar zxvf mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz

# 移动并重命名到指定地方,需要先创建目录
mkdir /usr/local/server
mv mysql-5.7.21-linux-glibc2.12-x86_64 /usr/local/server/mysql
# 进入mysql 目录
cd /usr/local/server/mysql
# 创建data目录
mkdir /data /data/db /data/db/mysql
# 检查和创建用户
cat /etc/group | grep mysql
# 如过查无结果,则创建mysql用户
groupadd mysql
useradd -r -g mysql mysql 
#科普1:-g, --gid GROUP    新账户主组的名称或 ID
#科普2:-r, --system       创建一个系统账户,不可用于登录

# 赋权
chown -R mysql:mysql /data/db/mysql
chmod 750 /data/db/mysql

# 执行安装
./bin/mysqld --initialize --user=mysql --basedir=/usr/local/server/mysql --datadir=/data/db/mysql

# 记录屏幕中的临时密码
A temporary password is generated for root@localhost: >wmujowe!68H

# 如果basedir和datadir修改过,需要先修改./support-files/mysql.server
vim ./support-files/mysql.server
#填入
basedir=/usr/local/server/mysql
datadir=/data/db/mysql

# 复制服务脚本
cp -a ./support-files/mysql.server /etc/init.d/mysqld

# 编辑配置文件,将data目录等参数修正

# 1、如果以下两个目录不在上面赋权的范围内,也要重新赋权,否则无法启动
log-error=/var/log/mysql/mariadb.log
pid-file=/var/run/mysql/mariadb.pid

chown -R mysql:mysql /var/log/mysql

# 2、配置文件加入[mysql]节点,用以客户端连接
[mysql]
socket=/data/db/mysql/mysql.sock

# 加入环境变量
export PATH=$PATH:/usr/local/server/mysql/bin

# 启动mysql
service mysqld start

# 接下来的步骤就和yum方式类似了,不再赘述
mysql -uroot -pYouPwd
...

下载二进制包
安装
3、其他说明

除了上述两种方式外,还有源码安装等方式,如有兴趣,请自行研究。

yum方式安装相对来说比较省事,但是由于下载镜像在国外,一般速度较慢,如果不能接受的话建议采用其他方式。

二进制安装稍微繁琐一点,建议有Linux经验的小伙伴采用。

Tips

①修改密码
提供关于修改密码的命令

# 登录
mysql -uroot -pYourPwd

# 第一种方式
>set password=password("YourNewPwd");

# 第二种方式
>use mysql;
>update user set authentication_string=password("YourNewPwd") where User='root';

②移动data目录
默认的mysqldata目录在于/var/lib/mysql,如果需要移动目录,可以参考下列操作

# 关闭mysql
systemctl stop mysqld

# 创建你自己的目录 
mkdir /data/db

# 移动mysql文件夹
mv /var/lib/mysql /data/db

# 更改权限
chown -R mysql:mysql /data/db/mysql

# 启动mysql 
sysctemctl start mysqld

# 如果遇到启动问题,一般先检查配置文件是否有错

# 如果确认配置文件没错,还启动不了,可以尝试下面的设置
vim /etc/selinux/config
# 设置 SELINUX=disabled
# 保存重启
reboot
# 再次尝试启动mysql
sysctemctl start mysqld

Tips:
关于selinux这里不做赘述,有兴趣的可以去查阅资料了解

④创建用户和赋权
提供关于创建用户和赋权的基础命令,如需了解详细内容,请参考官网

Create user ‘user’@’host’ identified by ‘YourPwd’;
# 赋予权限(原则上是最小权限赋予,此处赋予db.tables的全部权限)
Grant all on db.tables to user;
flush privileges;

⑤防火墙开放端口
如果你开启了防火墙,需要开放默认的3306端口,否则外网无法访问

# 查看防火墙状态
systemctl status firewalld

# 如果防火墙开启,需要开放3306端口
firewall-cmd --zone=public --add-port=3306/tcp --permanent

# 重启防火墙
systemctl restart firewalld

主从配置

前提条件,分别在两台服务器上安装msyql服务

IP :192.168.1.246(centOS7 + mysql) master
IP : 192.168.1.249(centOS7 + mysql) slave

1、master配置

这里不区分库,针对所有的库都做主从复制,如果需要特定库做主从复制的,请翻阅4、其他说明

vim /etc/my.cnf

log-bin=mysql-bin
server-id=246
log_bin_trust_function_creators=1

重启mysql,并登陆mysql进行操作

systemctl restart mysqld

mysql -uroot -pYourPwd

#创建同步账号,赋予权限,这里进行演示,不做权限限制和ip限制,请知悉
mysql>GRANT FILE ON *.* TO 'slave'@'%' IDENTIFIED BY 'YourSlavePwd';
mysql>GRANT replication slave on *.* to ’slave’@’%’ identified by 'YourSlavePwd'
mysql>flush privileges;
#查看主服务器状态,并记录下状态
mysql> show master status;
2、slave配置

vim /etc/my.cnf

read_only=1
log-bin=mysql-bin
server-id=249
log_bin_trust_function_creators=1

重启mysql,并登陆mysql进行操作

systemctl restart mysqld

mysql -uroot -pYourPwd

# 配置master,并开启同步
mysql> change master to master_host='192.168.1.246',master_user='slave',master_password='YourSlavePwd', master_log_file='mysql-bin.000033',master_log_pos=57883;
# 开启同步
mysql> start slave;
# 查看同步状态
mysql> show slave status\G;

# 如果出现以下两个Yes,证明同步成功,如果出现问题,请翻阅`4、其他说明`
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
3、验证
1、用Navicat分别连接主库和从库

2、在主库对某些记录进行修改

3、查看从库是否同步了主库的修改
4、其他说明

这里分成两部分,一部分针对主从复制中,只要求同步部分库的配置,另一部分记录主从不同步的解决方法。

①部分同步

需要修改my.cnf的配置文件,包括replicate-ignore-dbreplicate-ignore-db以及binlog-do-dbbinlog-ignore-db等参数配合。

具体配置说明请参考这里

②主从不同步解决

一、忽略错误后,继续同步。(该方法适用于主从库数据相差不大,或者要求数据可以不完全统一的情况,数据要求不严格的情况。)

1)、停止同步
mysql>stop slave;
2)、设置参数
mysql>set global sql_slave_skip_counter =1;
3)、启动同步并查看
start slave;
mysql> show slave status\G; 
Slave_IO_Running: Yes
Slave_SQL_Running: Yes

二、重新做主从,完全同步。(该方法适用于主从库数据相差较大,或者要求数据完全统一的情况。)

1)、进入主库,进行锁表,防止数据写入。注意:该处是锁定为只读状态,语句不区分大小写
mysql> flush tables with read lock;
2)、进行数据备份并解锁
mysqldump -uroot -pYouPwd YourDB > bak.sql;
mysql> UNLOCK TABLES;
3)、查看master 状态并记录
mysql> show master status;
4)、把mysql备份文件传到从库机器,进行数据恢复
5)、停止从库的状态
mysql> stop slave;
6)、从库执行mysql命令,导入数据备份
7)、设置从库同步,具体参数请根据master status填写
change master to master_host = '192.168.1.246', master_user = 'slave', master_port=3306, master_password='YourSalvePwd', master_log_file = 'mysqld-bin.000035', master_log_pos=120;
8)、重新开启从同步
mysql> start slave;
9)、查看同步状态
mysql> show slave status\G;
Slave_IO_Running: Yes
Slave_SQL_Running: Yes

写在最后

本来本篇也打算加入读写分离的内容,由于篇幅太长,综合考虑,准备另开一篇博客。

路过的小伙伴,点个喜欢呗,十分感谢。

参考

Mysql官方文档 - yum安装
Mysql官方文档 - bin安装

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
14天前
|
关系型数据库 MySQL 数据库
【MySQL基础篇】MySQL概述、Windows下载MySQL8.0超详细图文安装教程
在这一章节,主要介绍两个部分,数据库相关概念及MySQL数据库的介绍、下载、安装、启动及连接。接着,详细描述了MySQL 8.0的版本选择与下载,推荐使用社区版(免费)。安装过程包括自定义安装路径、配置环境变量、启动和停止服务、以及客户端连接测试。此外,还提供了在同一台电脑上安装多个MySQL版本的方法及卸载步骤。最后,解释了关系型数据库(RDBMS)的特点,即基于二维表存储数据,使用SQL语言进行操作,格式统一且便于维护。通过具体的结构图展示了MySQL的数据模型,说明了数据库服务器、数据库、表和记录之间的层次关系。
【MySQL基础篇】MySQL概述、Windows下载MySQL8.0超详细图文安装教程
|
8天前
|
NoSQL 关系型数据库 Redis
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
50 14
|
5天前
|
关系型数据库 MySQL 应用服务中间件
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
33 7
|
20天前
|
关系型数据库 MySQL 数据库
docker高级篇(大厂进阶):安装mysql主从复制
docker高级篇(大厂进阶):安装mysql主从复制
93 24
|
11天前
|
安全 关系型数据库 MySQL
Windows Server 安装 MySQL 8.0 详细指南
安装 MySQL 需要谨慎,特别注意安全配置和权限管理。根据实际业务需求调整配置,确保数据库的性能和安全。
61 9
|
17天前
|
监控 关系型数据库 MySQL
Flink CDC MySQL同步MySQL错误记录
在使用Flink CDC同步MySQL数据时,常见的错误包括连接错误、权限错误、表结构变化、数据类型不匹配、主键冲突和
62 16
|
15天前
|
NoSQL 关系型数据库 MySQL
Linux安装jdk、mysql、redis
Linux安装jdk、mysql、redis
142 7
|
2月前
|
运维 关系型数据库 MySQL
安装MySQL8数据库
本文介绍了MySQL的不同版本及其特点,并详细描述了如何通过Yum源安装MySQL 8.4社区版,包括配置Yum源、安装MySQL、启动服务、设置开机自启动、修改root用户密码以及设置远程登录等步骤。最后还提供了测试连接的方法。适用于初学者和运维人员。
209 0
|
16天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
41 3
|
16天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
44 3