CentOS7安装mysql-5.7.44单机和主从复制

官网下载地址:

https://downloads.mysql.com/archives/community/

1、单机安装

安装依赖

yum -y install libaio

解压安装

tar -zxvf mysql-5.7.44-linux-glibc2.12-x86_64.tar.gzmv mysql-5.7.44-linux-glibc2.12-x86_64 /usr/local/mysqlcd /usr/local/mysql

创建一个mysql组和用户

groupadd mysql
useradd -r -g mysql mysql

更改mysql 目录所属的用户组、用户以及文件权限

#切换到刚刚下载的mysql文件夹对应的目录下
cd /usr/local
#更改文件的用户组和用户
chown -R mysql:mysql mysql
#给mysql目录下的所有文件加执行权限
chmod -R 775 mysql

把mysql/bin目录加入到系统环境变量中

#把这个写到配置文件里,路径不同,记得要修改路径
echo "export PATH=$PATH:/usr/local/mysql/bin" >> /etc/profile
#生效配置文件
source /etc/profile
# 检查环境变量是否配置成功
mysql --version

如果出现版本号,则表示MySQL环境变量配置成功了。

生成临时密码,记住这个密码,后面要使用。

#切换到mysql目录下
cd /usr/local/mysql# 生成临时数据库密码
mysqld --user=mysql --initialize --datadir=/usr/local/mysql/data

注意:这里的临时密码需要记住 w,bnuSs<t1tV

复制启动文件到/etc/init.d目录

# 在mysql目录下复制启动文件到/etc/init.d/目录
cp -a /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

配置my.cnf

vi /etc/my.cnf

[mysqld]
# 指定Mysql数据库的开放端口。
port = 3306
# 设置Mysql数据库的安装目录(绝对路径)。
basedir = /usr/local/mysql
# 设置Mysql数据库的数据存放的绝对路径(存放目录)。必须是data,或者是\\xxx-data(my.ini需要,my.cnf不需要)。
datadir = /usr/local/mysql/data
# 设置MySQL数据库的最大连接数量。
max_connections = 100
# 设置MySQL数据库的连接超时时间。默认设置是一个数据库连接超过8小时没有使用,达到了server端的timeout,服务器将断开这条连接。
wait_timeout = 28800
# 当没有数据库请求时,28800秒(即8小时)将自动断开连接。要同时设置interactive_timeout和wait_timeout才会生效。
interactive_timeout = 28800socket=/var/lib/mysql/mysql.sock
symbolic-links=0[mysqld_safe]
log-error=/var/log/mariadb/mariadb.log
pid-file=/var/run/mariadb/mariadb.pid[client]
socket=/var/lib/mysql/mysql.sock!includedir /etc/my.cnf.d

保存后,给配置文件加上可执行权限 

chmod -R 775 /etc/my.cnf
#日志目录
mkdir /var/log/mariadb/
touch /var/log/mariadb/mariadb.log
chown -R  mysql:mysql /var/log/mariadb/mkdir /var/lib/mysql/
chown -R  mysql:mysql  /var/lib/mysql/

 启动服务,启动之前我们先查询有没有启动过,没有启动查询结果为空

ps -ef|grep -v grep |grep mysql
ps -ef|grep -v grep |grep mysqld

 启动

#启动mysql服务
/etc/init.d/mysqld start#启动成功标志
Starting MySQL. SUCCESS!

登录并修改root密码

# mysql -u用户名 -p密码
mysql -uroot -p"w,bnuSs<t1tV"

登录mysql ,密码就是初始化时生成的临时密码;

登录进来之后,我们来修改密码

#修改密码为root
set password for root@localhost = password('root');

quit 退出后,重新登录一下 

mysql -uroot -proot

开放远程登陆

#登录进来之后,切换到mysql库
use mysql;
#修改用户权限
update user set user.Host='%' where user.User='root';
#刷新权限
flush privileges;

开启防火墙

#开启端口
firewall-cmd --permanent --add-port=3306/tcp
#重新加载防火墙
firewall-cmd --reload

2、主从复制

按照上面的方式,安装两台单机版本。

二进制日志文件

修改数据节点的唯一标识
在 [mysqld] 下新增2行,其中server-id用来区分节点的编号,唯一。log-bin设置二进制文件的名称。

vi /etc/my.cnf

[mysqld]
server-id=1
log-bin=mysql-bin

另外一台

[mysqld]
server-id=2
log-bin=mysql-bin

重启数据库 让二进制文件生效即可

/etc/init.d/mysqld restart

重启后生成二进制文件

ll /usr/local/mysql/data/mysql-bin*-rw-r----- 1 mysql mysql 154 3月  21 16:37 /usr/local/mysql/data/mysql-bin.000001
-rw-r----- 1 mysql mysql  19 3月  21 16:37 /usr/local/mysql/data/mysql-bin.index

实现主从挂载

主库状态
主库IP这里使用192.168.111.201
检查主库的状态,主要查询 要同步的 文件名 File 和 位置 Position 

#在主库执行
# 在主库201查询状态
# 登录
mysql -uroot -prootSHOW MASTER STATUS;

如下 Position 查询结果为 154 后面需要使用。

mysql> SHOW MASTER STATUS;
+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000001 |      154 |              |                  |                   |
+------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

实现主从挂载
这一步在 从库 192.168.111.202 里面执行

# 在从库中执行
# 从库链接主库
# IP/端口/用户名/密码/二进制文件名/pos位置# 登录
mysql -uroot -proot#同步主库
CHANGE MASTER TO 
MASTER_HOST="192.168.111.201",#主库ip
MASTER_PORT=3306,
MASTER_USER="root",
MASTER_PASSWORD="root",
MASTER_LOG_FILE="mysql-bin.000001",
MASTER_LOG_POS=154;

启动主从
启动主从服务,在从库执行下面命令

# 登录
mysql -uroot -proot#启动
START SLAVE;

这一步在 从库里面执行,出现如下2个yes就成功了。

# 登录
mysql -uroot -proot#检查主从状态
#SHOW SLAVE STATUS;#检查主从状态,命令行客户端,垂直格式显示结果
SHOW SLAVE STATUS\G
mysql> SHOW SLAVE STATUS\G
*************************** 1. row ***************************Slave_IO_Running: YesSlave_SQL_Running: Yes

测试主从

主从要达到的效果,修改主库的数据,从库的数据跟着改变。千万不要手动去改从库的数据,去看主库变化没有,千万不要这样操作,这样主从就废了。

主从不一致

主从报错 Slave_SQL_Running: No

重新做主从,完全同步

该方法适用于主从库数据相差较大,或者要求数据完全统一的情况
重新做主从,然后使用change master指定同步位置,这种耗时长

主库执行

mysql -uroot -proot#1.先进入主库,进行锁表,防止数据写入 
mysql> flush tables with read lock; 
#注意:该处是锁定为只读状态
#2.进行数据备份,test表示要备份的数据库名称
mysqldump -uroot -proot --lock-all-tables --flush-logs test > /usr/local/mysql/data/back.sql# 修改导出的sql语句
vi /usr/local/mysql/data/back.sql
# 创建数据库,test改成自己的数据库名称
CREATE DATABASE IF NOT EXISTS  `test` CHARSET utf8;
# 在执行SQL语句之前,使用USE 数据库名;test改成自己的数据库名称
use `test`;# 复制到从库
scp /usr/local/mysql/data/back.sql root@192.168.111.202:/usr/local/mysql/data/
mysql> unlock tables;#查看主机状态:File和Position对应的值
show master status;

从库执行

# 从库操作
mysql -uroot -proot# 1.停止从库的状态
mysql> stop slave;
# 2.清除从节点配置信息(仅清理master.info 和 relay-log.info 文件)
mysql> reset slave;
# 3.从库执行mysql命令,导入数据备份
mysql> source /usr/local/mysql/data/back.sql# 4.设置从库同步,master_log_pos改成主库Position最新的值CHANGE MASTER TO 
MASTER_HOST="192.168.111.201",#主库ip
MASTER_PORT=3306,
MASTER_USER="root",
MASTER_PASSWORD="root",
MASTER_LOG_FILE="mysql-bin.000001",
MASTER_LOG_POS=154;# 5.启动同步
start slave ;# 查看
SHOW SLAVE STATUS\G

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/769035.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

文件上传一-WEB攻防-PHP应用文件上传函数缺陷条件竞争二次渲染黑白名单JS绕过9

演示案例&#xff1a; PHP-原生态-文件上传-前后端验证PHP-原生态-文件上传-类型文件头验证PHP-原生态-文件上传-后缀黑白名单验证PHP-原生态-文件上传-解析配置&二次渲染PHP-原生态-文件上传-逻辑缺陷&函数缺陷 #学习前必读&#xff1a; 1、课前一定要明白&#xff1a…

蓝桥杯基础练习详细解析一(代码实现、解题思路、Python)

试题 基础练习 数列排序 资源限制 内存限制&#xff1a;512.0MB C/C时间限制&#xff1a;1.0s Java时间限制&#xff1a;3.0s Python时间限制&#xff1a;5.0s 问题描述 给定一个长度为n的数列&#xff0c;将这个数列按从小到大的顺序排列。1<n<200 输入格式 第…

MySQL事务(超详细!!!)

目录 一、MySQL事务的概念 二、事务的ACID特点 1、原子性&#xff08;Atomicity&#xff09; 2、持久性 3、隔离性&#xff08;Isolation&#xff09; 3.1 事务的并发问题 ①、脏读(读取未提交数据) ②读已提交、不可重复读(前后多次读取&#xff0c;数据内容不一致) …

【Redis主从架构。主从工作原理psync、bgsave、部分数据复制、主从复制风暴解决方案】【Redis哨兵高可用架构。sentinel】

Redis主从架构 Redis主从工作原理数据部分复制 Redis哨兵高可用架构client连接哨兵规则主节点挂了&#xff0c;集群从新选择主节点&#xff0c;并且同步给sentinel 转自图灵课堂 redis主从架构搭建&#xff0c;配置从节点步骤&#xff1a; 1、复制一份redis.conf文件2、将相关…

美易官方:除了散户,对冲基金也在重返加密市场

高盛&#xff1a;除了散户&#xff0c;对冲基金也在重返加密市场 随着加密货币市场的逐渐成熟和技术的不断进步&#xff0c;越来越多的机构投资者开始重新审视加密货币市场。除了散户投资者外&#xff0c;对冲基金也在重返加密市场&#xff0c;成为市场的重要参与者之一。高盛作…

苹果手机强制重启方法大揭秘!不同机型多种方法一网打尽

随着苹果手机的普及&#xff0c;越来越多的人选择使用这款优秀的智能手机。然而&#xff0c;就像任何其他设备一样&#xff0c;苹果手机也可能会出现各种问题&#xff0c;例如系统崩溃、应用程序冻结或其他错误。在这种情况下&#xff0c;强制重启手机是解决问题的一个有效方法…

Pygame基础3-动画

3.动画 原理 动画是连续播放的图片。 使用精灵显示动画只需要在update()方法中改变精灵的图片。 需要注意的是播放速度&#xff0c;可以 通过pygame.time.get_ticks()来控制时间&#xff0c;但是这样比较复杂。最直接的方式是根据帧数来控制播放。每过n帧就切换一次图片。 …

linux系统--------------mysql数据库管理

目录 一、SQL语句 1.1SQL语言分类 1.2查看数据库信息 1.3登录到你想登录的库 1.4查看数据库中的表信息 1.5显示数据表的结构&#xff08;字段&#xff09; 1.5.1数据表的结构 1.5.2常用的数据类型: 二、关系型数据库的四种语言 2.1DDL&#xff1a;数据定义语言&am…

Web安全基础入门+信息收集篇

教程介绍 学习信息收集&#xff0c;针对域名信息,解析信息,网站信息,服务器信息等&#xff1b;学习端口扫描&#xff0c;针对端口进行服务探针,理解服务及端口对应关系&#xff1b;学习WEB扫描&#xff0c;主要针对敏感文件,安全漏洞,子域名信息等&#xff1b;学习信息收集方法…

SpringMVC | SpringMVC中的 “文件上传和下载”

目录: 一、文件上传1.1 文件上传“概述”1.2 文件上传“具体配置” :“前端”中配置“文件上传” ( type“file” 满足3个条件 )“后端”中配置“文件上传” ( 配置id为“CommonsMultipartResolver”的bean 配置“文件上传”的“约束条件” 通过“MultipartFile接口”参数接…

RabbitMQ 的高阶应用及可靠性保证

目录 一、RabbitMQ 高阶应用 1.1 消息何去何从 1.2 过期时间 1.3 死信队列 1.4 延迟队列 1.5 优先级队列 1.6 消费质量保证&#xff08;QOS&#xff09; 二、持久化 三、生产者确认 四、消息可靠性和重复消费 4.1 消息可靠性 4.2 重复消费问题 上篇文章介绍了 Rabb…

流畅的 Python 第二版(GPT 重译)(三)

第五章&#xff1a;数据类构建器 数据类就像孩子一样。它们作为一个起点是可以的&#xff0c;但要作为一个成熟的对象参与&#xff0c;它们需要承担一些责任。 马丁福勒和肯特贝克 Python 提供了几种构建简单类的方法&#xff0c;这些类只是一组字段&#xff0c;几乎没有额外功…

Linux 安装 JDK、MySQL、Tomcat(图文并茂)

所需资料 下载 1.1 软件安装方式 在Linux系统中&#xff0c;安装软件的方式主要有四种&#xff0c;这四种安装方式的特点如下&#xff1a; 安装方式特点二进制发布包安装软件已经针对具体平台编译打包发布&#xff0c;只要解压&#xff0c;修改配置即可rpm安装软件已经按照re…

美易官方:科技巨头涨势好标普指数年底前有望升至6000点

高盛&#xff0c;作为全球领先的金融机构之一&#xff0c;近日发布了一份报告&#xff0c;预测在科技巨头的涨势推动下&#xff0c;标普500指数年底前有望升至6000点。这一预测引起了市场的广泛关注&#xff0c;投资者们纷纷开始重新评估自己的投资策略。 David Kostin等策略师…

超过 1200 个能够拦截在野外检测到的 2FA 的网络钓鱼工具包

超过 1200 个能够拦截在野外检测到的 2FA 的网络钓鱼工具包。 #################### 免责声明&#xff1a;工具本身并无好坏&#xff0c;希望大家以遵守《网络安全法》相关法律为前提来使用该工具&#xff0c;支持研究学习&#xff0c;切勿用于非法犯罪活动&#xff0c;对于恶…

202基于matlab的曲柄滑块机构的运动学仿真分析

基于matlab的曲柄滑块机构的运动学仿真分析&#xff0c;分析各个杆的速度、位移、加速度曲线&#xff0c;以及曲柄滑块机构的动画。程序已调通&#xff0c;可直接运行。 202 matlab 曲柄滑块机构 运动学仿真分析 - 小红书 (xiaohongshu.com)

第九篇【传奇开心果系列】Python自动化办公库技术点案例示例:深度解读Python处理PDF文件

传奇开心果博文系列 系列博文目录Python自动化办公库技术点案例示例系列 博文目录前言一、重要作用介绍二、Python库处理PDF文件基础操作和高级操作介绍&#xff08;一&#xff09;基础操作介绍&#xff08;二&#xff09;高级操作介绍 三、Python库处理PDF文件基础操作示例代码…

H5实现Web ECharts教程:轻松创建动态数据图表

&#x1f31f; 前言 欢迎来到我的技术小宇宙&#xff01;&#x1f30c; 这里不仅是我记录技术点滴的后花园&#xff0c;也是我分享学习心得和项目经验的乐园。&#x1f4da; 无论你是技术小白还是资深大牛&#xff0c;这里总有一些内容能触动你的好奇心。&#x1f50d; &#x…

【OpenBayes 官方教程】快速部署通义千问 72B 大模型

本教程主要为大家介绍怎样在 OpenBayes 上快速部署通义千文 72B 大模型&#xff0c;新朋友点击下方链接注册后&#xff0c;即可获得 4 小时 RTX 4090 5 小时 CPU 的免费使用时长哦&#xff01; 注册链接 https://openbayes.com/console/signup?ryuudi_nBBThttps://openbaye…

算法|数学与数论|素数筛

数学与数论|素数筛 1.判断素数 2.朴素筛 3.埃氏筛 4.欧拉筛(线性筛) 心有猛虎&#xff0c;细嗅蔷薇。你好朋友&#xff0c;这里是锅巴的C\C学习笔记&#xff0c;常言道&#xff0c;不积跬步无以至千里&#xff0c;希望有朝一日我们积累的滴水可以击穿顽石。 质数(素数)&…