起因

最近项目上开始重构,可能会用到主从加读写分离的情况,就想先在本地搭一个出来试试效果,结果百度一搜出来一大堆,然而自己去踩坑的没几个,绝大多数都是去抄的别人的内容,关键是实际应用中还会出错,浏览器开了接近二十个标签页,试了好几个都有问题,完全用不了,时间浪费了不说,还会让你很憋屈,所以就自己搞。

一、准备

1、首先检查并清理系统中存在的mysql相关文件

 # 检查系统中是否存在Mysql的文件
find / -name mysql

# 删除存在mysql的文件或文件夹
rm -rf /usr/lib64/mysql/

# 检查是否存在mysql的相关依赖
rpm -qa|grep mysql

# 卸载mysql的依赖
rpm -e mysql-.....

2、下载对应版本的mysql安装文件

因为我使用的是CentOS 7 64位,所以在MySQL官网中选择如下图的操作系统,然后选择tar包进行下载。

在这儿说明下,为什么我要使用tar包进行安装,而不是使用网上普遍的一个正常安装,另一个用rpm安装的方法,因为如果第一个使用yum正常安装,第二个使用本地安装,那么无法指定安装路径,无法将两个mysql放在一起进行系统性管理,所以我在这儿使用tar包来安装多个实例,并且放在同一目录下方便管理与配置。

 # 在下载前先创建一个mysql用户,为什么要创建MySQL用户?因为解压出来的mysql文件没有任何的属组,以及为了避免在配置、启动时MySQL不能读取某些文件,所以建议使用mysql用户来运行mysql
adduser mysql
# 设置密码
passwd mysql # 接下来输入两次密码

# 切换用户
su mysql

# 下载Mysql的tar包
wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.20-el7-x86_64.tar.gz

# 解压文件并重命名文件夹为 mysql_01
tar xf mysql-8.0.-el7-x86_64.tar.gz ./mysql_01

# 复制一份mysql_01并重命名为mysql_02
cp -r ./mysql_01 ./mysql_02/

# 切换到root用户,更改两个mysql的数组为mysql用户,然后再切换回mysql用户
exit
chown -R mysql:mysql /home/mysql/mysql_01/ /home/mysql/mysql_02/
su mysql

二、修改配置

接下来就是对MySQL进行配置,两个MySQL的配置其实是差不多的,只是说路径不同而已,在这儿我就只展示mysql_01的配置,mysql_02则将相应的路径替换成自己的路径即可。

1、自定义配置my.cnf

 # 切换到mysql_01路径下
cd ./mysql_01

# 创建配置文件my.cnf,直接使用vim编辑,保存后即可。其中###表示为必须项,#表示为可选项
vim my.cnf
----------以下是文件内容-------------
[mysqld]
### 端口号
port= ### 安装目录
basedir=/home/mysql/mysql_01/ ### 数据存放路径
datadir=/home/mysql/mysql_01/data/ ### 会话文件目录
socket=/home/mysql/mysql_01/mysql.sock # 允许连接失败的最大次数
max_connect_errors= # 服务端的字符集编码
character-set-server=utf8 # 默认存储引擎
default-storage-engine=INNODB # 默认用户
user=mysql # 开启慢查询
slow_query_log=on # 慢查询日志文件目录
slow_query_log_file=/home/mysql/mysql_01/slow-query.log
 [client]                              
 ### 连接服务端使用的端口号                        
 port=10085
 ​
 ### 会话文件                                
 socket=/home/mysql/mysql_01/mysql.sock
                                       
 # 默认字符集编码                            
 default-character-set=utf8
 ---------------文件内容结束--------------------
 ​
 # 在上面的配置中可以看到datadir项中存在data文件夹,而mysql_01下并没有,因此需要创建data文件夹
 mkdir data

2、修改自带的默认配置

接下来就需要修改mysql的默认配置信息

 # 修改文件中的默认配置信息
vim ./support-files/mysql.server
# 将文件中的所有有关basedir和datadir的配置全部修改为当前的路径,如下图

以及修改该文件中加载的MySQL配置文件路径,修改为刚才创建的my.cnf文件,如下图,修改完成后,保存退出。

同样也需要修改support-files下的另一个文件

 # 修改support-files文件夹下的mysqld_multi.server文件
vim ./support-files/mysqld_multi.server

#还是修改basedir和datadir两项属性,如下图所示

三、初始化安装及启动服务

1、初始化安装

 # 切换到mysql_01的根目录
cd /home/mysql/mysql_01/

# 初始化安装 --defaults-file表示指定初始化的配置文件 --console表示将初始化信息打印在控制台
./bin/mysqld --defaults-file=/home/mysql/mysql_01/my.cnf --initialize --console --user=mysql

# 初始化成功后,会在控制台中打印出初始化密码,大致格式如下
root@localhost: fa356fgss,

2、启动服务

 # 后台启动当前mysql_01的mysql服务,还是需要去指定配置文件,因为在配置文件中我们设置了一个socket参数,只有按照这个配置文件去启动,才会按照socket配置的路径去生成,否则会自动生成在/tmp/mysql.sock,如果mysql_02也是这么生成,则会形成覆盖,在连接时造成只能连接一个服务,甚至报错。
./bin/mysqld_safe --defaults-file=./my.cnf &

# 使用命令查看mysql服务是否启动,如下图
netstat -nultp|grep

四、连接数据库与修改密码

 # 通过上面可以看到mysql服务已经启动,那么就可以连接MySQL了
./bin/mysql --socket=./mysql.sock -uroot -p # 输入初始密码

# 修改MySQL登录密码,这儿我的修改为 root,注意末尾的结束符分号
alter user root@localhost identified by "root";

同样配置之后,启动mysql_02,效果如下

以上就是MySQL_01的配置,同样的MySQL_02和这个一致,只需要将对应的目录修改为自己的文件路径即可。当安装上多个实例之后,就可以进行主从复制、读写分离等相关配置。

【转载请注明 https://www.cnblogs.com/fqgump/p/12957145.html

【原创】CentOS 7搭建多实例MySQL8(想要几个搞几个)的更多相关文章

  1. 【原创】C#搭建足球赛事资料库与预测平台(2) 数据库与XCode组件

            本博客所有文章分类的总目录:[总目录]本博客博文总目录-实时更新 开源C#彩票数据资料库系列文章总目录:[目录]C#搭建足球赛事资料库与预测平台与彩票数据分析目录  本篇文章开始将逐步 ...

  2. SpringMVC笔记——SSM框架搭建简单实例

    落叶枫桥 博客园 首页 新随笔 联系 订阅 管理 SpringMVC笔记——SSM框架搭建简单实例 简介 Spring+SpringMVC+MyBatis框架(SSM)是比较热门的中小型企业级项目开发 ...

  3. centos上搭建git服务--3

    前言:当我们想要实现几个小伙伴合作开发同一个项目,或者建立一个资源分享平台的时候,GIT就是一个很好的选择.当然,既然是一个共有平台,那么把这个平台放到个人计算机上明显是不合适的,因此就要在服务器上搭 ...

  4. CentOs上搭建nginx

    目录 CentOs上搭建nginx 1. 在root环境下安装nginx 1.1 常用工具安装 1.2 关闭iptables规则 1.3 关闭SELinux 1.4 安装C/C++环境和PCRE库 1 ...

  5. Centos 6 搭建邮箱服务器教程

    Centos 6 搭建邮箱服务器主要是是包括了Postfix, Dovecot和 MySQL了,下文我们详细的为各位介绍Centos 6 搭建邮箱服务器教程(Postfix, Dovecot和 MyS ...

  6. CentOS 7 搭建 GitLab

    概述 GitLab 是我在日常工作中使用的代码仓库管理系统,它带有非常友好的 Web 界面,并且功能丰富.下面将介绍我在 CentOS 7 上搭建 GitLab 的步骤,以及遇到的一些问题. 关于不同 ...

  7. CentOS Linux搭建独立SVN Server全套流程(修改svn仓库地址、服务启动等)

    CentOS Linux搭建独立SVN Server全套流程(修改svn仓库地址.服务启动等) 原 一事能狂便少年 发布于 2016/12/27 11:16 字数 1113 阅读 1.3K  收藏 0 ...

  8. CentOS下搭建LAMP环境详解

    前言:在这里将介绍如何在CentOS下搭建LAMP环境(全部使用源码编译安装),用于web服务器开发. •LAMP: Linux + Apache + PHP + Mysql. •系统: CentOS ...

  9. CentOS 配置防火墙操作实例(启、停、开、闭端口):

    CentOS 配置防火墙操作实例(启.停.开.闭端口): 注:防火墙的基本操作命令: 查询防火墙状态: [root@localhost ~]# service   iptables status< ...

随机推荐

  1. KafkaConsumer assign VS subscribe

    背景 在kafka中,正常情况下,同一个group.id下的不同消费者不会消费同样的partition,也即某个partition在任何时刻都只能被具有相同group.id的consumer中的一个消 ...

  2. json序列化字符串后,配置枚举类型显示数值而不是名称

    2019独角兽企业重金招聘Python工程师标准>>> 经常有这么一个需求,实体类里面用到枚举常量,但序列化成json字符串时.默认并不是我想要的值,而是名称,如下 类 @Data ...

  3. 数论--HDU 1495 非常可乐

    Description 大家一定觉的运动以后喝可乐是一件很惬意的事情,但是seeyou却不这么认为.因为每次当seeyou买了可乐以后,阿牛就要求和seeyou一起分享这一瓶可乐,而且一定要喝的和se ...

  4. 网络流--最大流--POJ 1273 Drainage Ditches

    链接 Description Every time it rains on Farmer John's fields, a pond forms over Bessie's favorite clov ...

  5. 实现MapReduce

    简介 当我们要统计数亿文本的词频,单个机器性能一般,况且是数亿级数据,处理是十分缓慢的,对于这样的任务,希望的是多台电脑共同处理,大幅度减少任务时间.联合多台电脑一起工作的系统就是分布式系统. 最近在 ...

  6. IIS 搭网站(一)

    搭建类型win+IIs+asp+access(一) 第一步首先保证虚拟机的系统软盘是连接状态,如下图状态即可 第二步: 第三步: 第四步: 第五步: 第六步:这个时候就会自动搜索软盘里面的数据自动安装 ...

  7. 配置中心Apollo搭建全过程

    总体架构 用户在Portal操作配置发布 Portal调用Admin Service的接口操作发布 Admin Service发布配置后,发送ReleaseMessage给各个Config Servi ...

  8. Spring官网阅读(一)容器及实例化

    从今天开始,我们一起过一遍Spring的官网,一边读,一边结合在路神课堂上学习的知识,讲一讲自己的理解.不管是之前关于动态代理的文章,还是读Spring的官网,都是为了之后对Spring的源码做更全面 ...

  9. 假如用王者荣耀的方式学习webpack

    英雄介绍 崴博.派克诞生于遥远西方的勇士之地,拥有着高超的机械技艺,善于运用各种工具来实现一些看似不可能完成的事.游历王者大陆时机缘巧合遇到了年轻的墨子,与之成为好友.后协助大宗师墨子建造了大陆第一雄 ...

  10. Spark Streaming 基本操作

    Spark Streaming 基本操作 ​ 一.案例引入        3.1 StreamingContext        3.2 数据源        3.3 服务的启动与停止二.Transf ...