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

news2024/9/23 17:14:27

官网下载地址:

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

1、单机安装

安装依赖

yum -y install libaio

解压安装

tar -zxvf mysql-5.7.44-linux-glibc2.12-x86_64.tar.gz

mv mysql-5.7.44-linux-glibc2.12-x86_64 /usr/local/mysql

cd /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 = 28800

socket=/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 -proot

SHOW 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: Yes
            Slave_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.coloradmin.cn/o/1542990.html

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

相关文章

吴恩达深度学习笔记:神经网络的编程基础2.1-2.4

目录 第一门课&#xff1a;神经网络和深度学习 (Neural Networks and Deep Learning)第二周&#xff1a;神经网络的编程基础 (Basics of Neural Network programming)2.1 二分类(Binary Classification)2.2 逻辑回归(Logistic Regression)2.3 逻辑回归的代价函数&#xff08;Lo…

计数DP

J - The King‘s Walk 思路&#xff1a;dx abs(x1 - x2), dy abs(y1 - y2), 那么最短距离一定是,然后就是状态表示了&#xff0c;表示当前点向上走i步且最终在第j列的方案数&#xff0c;我们知道我们每一步都要缩短短距离&#xff0c;也就是向上走&#xff0c;那么我们转移…

vue3怎么读取本地json数据

在Vue 3中&#xff0c;可以使用fetch API或其他HTTP客户端来读取本地JSON数据。以下是一个使用fetch的示例&#xff1a; <template><div><h1>本地JSON数据</h1><div v-if"data">{{ data }}</div></div> </template>…

JAVA校园失物招领网站源码带后台

开发环境是Eclipse none&#xff0c;Mysql5.6数据库&#xff0c;Spring MVC框架&#xff0c;jdk1.7&#xff0c;Tomcat 8.0.27,静态页面是参照网上设计的&#xff0c;系统功能基本完善&#xff0c;目前还没有发现有需要解决的bug

vim编辑器和gcc/g++编辑器的使用讲解

vim编辑器 1 vim的基本概念 vim是Linux的编写代码的工具&#xff0c;是一种多模式的编辑器。 Linux中vim的常用的模式大概可以分为三种&#xff0c;分别是&#xff1a; 命令模式&#xff08;command mode&#xff09;、插入模式&#xff08;Insert mode&#xff09;和底行模式…

Xcode-双架构arm64 x86_64编译

要启用通用构建&#xff0c;在最新版本的 Xcode 中&#xff0c;请打开您的项目设置&#xff0c;然后依次选择&#xff1a; 1. “Build Settings” 选项卡。 2. 在顶部输入框中输入 “Architectures”。 3. 在 “Architectures” 下拉列表中选择 “Other”。 4. 在输入框中输入 …

Personal Website

Personal Website Static Site Generators hexo hugo jekyll Documentation Site Generator gitbook vuepress vitepress docsify docute docusaurus Deployment 1. GitHub Pages 2. GitLab Pages 3. vercel 4. netlify Domain 域名注册 freessl 域名解析域名…

【微服务】Eureka(服务注册,服务发现)

文章目录 1.基本介绍1.学前说明2.当前架构分析1.示意图2.问题分析 3.引出Eureka1.项目架构分析2.上图解读 2.创建单机版的Eureka1.创建 e-commerce-eureka-server-9001 子模块2.检查父子pom.xml1.子 pom.xml2.父 pom.xml 3.pom.xml 引入依赖4.application.yml 配置eureka服务5.…

火星文:一种特殊的文字编码

title: 火星文&#xff1a;一种特殊的文字编码 date: 2024/3/25 13:26:20 updated: 2024/3/25 13:26:20 tags: 火星文文字变种网络流行解码阅读社交趣味艺术创新未来符号 定义 火星文是一种特殊的文字编码&#xff0c;也称为奇文&#xff0c;其特点是将常见的文字进行特殊的变…

5.3 用PyTorch实现Logistic回归

一、数据准备 Logistic回归常用于解决二分类问题。 为了便于描述&#xff0c;我们分别从两个多元高斯分布 N₁&#xff08;μ₁&#xff0c;Σ₁ &#xff09;、N₂&#xff08;μ₂&#xff0c;Σ₂&#xff09;中生成数据 x₁ 和 x₂&#xff0c;这两个多元高斯分布分别表示…

【Redis知识点总结】(七)——缓存雪崩、缓存穿透、缓存击穿、Redis高级用法

Redis知识点总结&#xff08;七&#xff09;——缓存雪崩、缓存穿透、缓存击穿、Redis高级用法 缓存雪崩缓存穿透布隆过滤器 缓存击穿Redis高级用法bitmapHyperLogLog 缓存雪崩 缓存雪崩是指&#xff0c;同一时间有大量的缓存key失效&#xff0c;或者redis节点直接宕机了&…

基于nodejs+vue学生作业管理系统python-flask-django-php

他们不仅希望页面简单大方&#xff0c;还希望操作方便&#xff0c;可以快速锁定他们需要的线上管理方式。基于这种情况&#xff0c;我们需要这样一个界面简单大方、功能齐全的系统来解决用户问题&#xff0c;满足用户需求。 课题主要分为三大模块&#xff1a;即管理员模块和学生…

(已解决)vue运行时出现Moudle Bulid error: this.getoptios is not a function at........

1.首先查看你的less-loader版本 点击package.json 即可查看less-loader版本&#xff0c;我之前的版本是12.0&#xff0c;太高了&#xff0c;出现了不兼容的问题 2、卸载less-loader ctrlshift~ 打开项目终端 &#xff0c;输入&#xff1a; npm uninstall less-loader 3.重…

Linux中的常用基础操作

ls 列出当前目录下的子目录和文件 ls -a 列出当前目录下的所有内容&#xff08;包括以.开头的隐藏文件&#xff09; ls [目录名] 列出指定目录下的子目录和文件 ls -l 或 ll 以列表的形式列出当前目录下子目录和文件的详细信息 pwd 显示当前所在目录的路径 ctrll 清屏 cd…

突破极限!DNF全新装备现身,无限高达流震撼登场

近期&#xff0c;DNF&#xff08;地下城与勇士&#xff09;的玩家们热议的话题不再是往日的副本攻略或职业平衡&#xff0c;而是一件神秘的装备——“玉化腰带”。这个装备的出现&#xff0c;引发了一股前所未有的热潮&#xff0c;因为它带来的无限高达流&#xff0c;彻底颠覆了…

0325 ISP流程介绍 RAW/RGB/YUV

学习参考:isp流程介绍(yuv格式阶段) - 知乎 一、RAW 1.1 ISP RAW 之DPC DPC(defective pixel correction)也就是坏点矫正&#xff0c;在sensor接收光信号&#xff0c;并做光电转换之后。 这一步设计的意义在于&#xff1a;摄像头sensor的感光元件通常很多会存在一些工艺缺陷…

硅谷甄选项目笔记

硅谷甄选运营平台 此次教学课程为硅谷甄选运营平台项目,包含运营平台项目模板从0到1开发&#xff0c;以及数据大屏幕、权限等业务。 此次教学课程涉及到技术栈包含***:vue3TypeScriptvue-routerpiniaelement-plusaxiosecharts***等技术栈。 一、vue3组件通信方式 通信仓库地…

maven下载与使用

Maven介绍 Maven 是一款为 Java 项目构建管理、依赖管理的工具&#xff08;软件&#xff09;&#xff0c;使用 Maven 可以自动化构建、测试、打包和发布项目&#xff0c;大大提高了开发效率和质量。 总结&#xff1a;Maven就是一个软件&#xff0c;掌握软件安装、配置、以及基…

苍穹外卖项目笔记

软件开发流程 需求分析&#xff1a;说明书和原型 设计&#xff1a;UI&#xff0c;数据库&#xff0c;接口设计 编码&#xff1a;项目代码&#xff0c;单元测试 测试&#xff1a;测试用例&#xff0c;测试报告 上线运维&#xff1a;软件环境安装&#xff0c;配置 软件环境…

《大模型技术要求标准》重磅发布,九章云极DataCanvas公司助力我国大模型技术发展

近日&#xff0c;中国信息通信研究院&#xff08;简称“中国信通院”&#xff09;重磅发布**《人工智能开发平台通用能力要求 第4部分&#xff1a;大模型技术要求》**&#xff08;以下简称“大模型技术要求标准”&#xff09;&#xff0c;九章云极DataCanvas公司依托在大模型领…