本文以MySQL5.7为例,介绍在同一台机器下如何安装多个MySQL实例。

环境:RHEL 6.5 + MySQL 5.7

1.单实例MySQL安装

先来看下MySQL5.7单实例的安装方法(这里引用官方文档的安装步骤):

shell> groupadd mysql
shell> useradd -r -g mysql -s /bin/false mysql
shell> cd /usr/local
shell> tar zxvf /path/to/mysql-VERSION-OS.tar.gz
shell> ln -s full-path-to-mysql-VERSION-OS mysql
shell> cd mysql
shell> mkdir mysql-files
shell> chown mysql:mysql mysql-files
shell> chmod 750 mysql-files
shell> bin/mysqld --initialize --user=mysql
shell> bin/mysql_ssl_rsa_setup
shell> bin/mysqld_safe --user=mysql &
# Next command is optional
shell> cp support-files/mysql.server /etc/init.d/mysql.server --修改/etc/profile 增加
export PATH=/usr/local/mysql/bin:$PATH --需要修改密码才可以正常操作数据库:
mysql> show databases;
ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.
mysql> alter user 'root'@'localhost' identified by '123';
Query OK, 0 rows affected (0.00 sec)

可以看到单实例MySQL的安装非常简单,只需创建了必要的用户组和用户,解压二进制软件包,初始化然后调整下权限基本就OK了。

2.多实例MySQL配置

下面来看下多实例MySQL配置,如果需要安装多实例在同一台机器上,主要4个地方的配置需要区分:端口(Port)、数据目录(datadir)、socket文件、server-id标识。(注:对其他配置可以根据实际需求去自定义各个实例的一些参数)
MySQL的配置文件my.cnf支持标签重定义,比如我这里安装4个实例,分别定义为[mysqld1]、[mysqld2]、[mysqld3]、[mysqld4]。

举例来说,我在原本的标准my.cnf配置文件中增加如下配置内容:

...这里省略原本的my.cnf配置内容...

[mysqld_multi]
mysqld=/usr/local/mysql/bin/mysqld_safe
mysqladmin=/usr/local/mysql/bin/mysqladmin
Log=/usr/local/mysql/multi.log [mysqld1]
server-id=101
datadir=/data/mysqldata/3307
socket=/tmp/mysql.sock3307
port=3307 [mysqld2]
server-id=102
datadir=/data/mysqldata/3308
socket=/tmp/mysql.sock3308
port=3308 [mysqld3]
server-id=103
datadir=/data/mysqldata/3309
socket=/tmp/mysql.sock3309
port=3309 [mysqld4]
server-id=104
datadir=/data/mysqldata/3310
socket=/tmp/mysql.sock3310
port=3310

3.多实例MySQL初始化

多实例MySQL初始化:即分别初始化不同实例,也就是指定不同的datadir
bin/mysqld --initialize --user=mysql --datadir=/data/mysqldata/3307
bin/mysqld --initialize --user=mysql --datadir=/data/mysqldata/3308
bin/mysqld --initialize --user=mysql --datadir=/data/mysqldata/3309
bin/mysqld --initialize --user=mysql --datadir=/data/mysqldata/3310

--创建多实例各自的datadir
[root@jystdrac2 mysqldata]# pwd
/data/mysqldata
[root@jystdrac2 mysqldata]# mkdir 3307 3308 3309 3310 --具体参照安装单实例的步骤
[root@jystdrac2 local]# tar zxvf /public/ISO/mysql/mysql-5.7.28-linux-glibc2.12-x86_64.tar.gz
[root@jystdrac2 local]# ln -s mysql-5.7.28-linux-glibc2.12-x86_64 mysql --多实例MySQL初始化
[root@jystdrac2 mysql]# pwd
/usr/local/mysql
[root@jystdrac2 mysql]# bin/mysqld --initialize --user=mysql --datadir=/data/mysqldata/3307
[root@jystdrac2 mysql]# bin/mysqld --initialize --user=mysql --datadir=/data/mysqldata/3308
[root@jystdrac2 mysql]# bin/mysqld --initialize --user=mysql --datadir=/data/mysqldata/3309
[root@jystdrac2 mysql]# bin/mysqld --initialize --user=mysql --datadir=/data/mysqldata/3310

记录好每个MySQL实例默认生成的密码:

yD*jUO%pj4ta
aHiLky?Ge28k
psPWYuk/)8=j
<8Pk#rxteaqx

修改密码,我这里测试环境为了方便统一设置密码为123,如果是生产环境切记要设计符合客户要求的密码安全策略:

[root@jystdrac2 3307]# mysql -uroot -S/tmp/mysql.sock3307 -p
yD*jUO%pj4ta
mysql> set password='123'; mysql -uroot -S/tmp/mysql.sock3308 -p
mysql -uroot -S/tmp/mysql.sock3309 -p
mysql -uroot -S/tmp/mysql.sock3310 -p

多实例MySQL开机启动项设置:

[root@jystdrac2 mysql]# chkconfig --list|grep mysql
[root@jystdrac2 mysql]# cp support-files/mysqld_multi.server /etc/init.d/mysqld_multi
[root@jystdrac2 mysql]# chkconfig --add mysqld_multi
[root@jystdrac2 mysql]# chkconfig --list|grep mysql
mysqld_multi 0:off 1:off 2:on 3:on 4:on 5:on 6:off

4.多实例MySQL常用管理命令

多实例MySQL常用管理命令:

--显示多实例mysqld的运行状态
mysqld_multi report --启动[mysqld1]
mysqld_multi start 1 --启动[mysqld2]
mysqld_multi start 2 --启动所有多实例mysqld进程
mysqld_multi start --通过socket连接到指定的MySQL实例
mysql -uroot -S/tmp/mysql.sock3307 -p
mysql -uroot -S/tmp/mysql.sock3308 -p
mysql -uroot -S/tmp/mysql.sock3309 -p
mysql -uroot -S/tmp/mysql.sock3310 -p --确认连接实例的端口信息
show variables like '%port%';

最后确认下4个MySQL实例的启动、关闭均正常:

[root@jystdrac2 mysql]# mysqld_multi report
Reporting MySQL servers
MySQL server from group: mysqld1 is running
MySQL server from group: mysqld2 is running
MySQL server from group: mysqld3 is running
MySQL server from group: mysqld4 is running
[root@jystdrac2 mysql]# ps -ef|grep mysql
root 10923 1 0 23:48 pts/0 00:00:00 /bin/sh /usr/local/mysql/bin/mysqld_safe --server-id=101 --datadir=/data/mysqldata/3307 --socket=/tmp/mysql.sock3307 --port=3307
root 10930 1 0 23:48 pts/0 00:00:00 /bin/sh /usr/local/mysql/bin/mysqld_safe --server-id=102 --datadir=/data/mysqldata/3308 --socket=/tmp/mysql.sock3308 --port=3308
root 10947 1 0 23:48 pts/0 00:00:00 /bin/sh /usr/local/mysql/bin/mysqld_safe --server-id=103 --datadir=/data/mysqldata/3309 --socket=/tmp/mysql.sock3309 --port=3309
root 10963 1 0 23:48 pts/0 00:00:00 /bin/sh /usr/local/mysql/bin/mysqld_safe --server-id=104 --datadir=/data/mysqldata/3310 --socket=/tmp/mysql.sock3310 --port=3310
mysql 11438 10923 0 23:48 pts/0 00:00:00 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/data/mysqldata/3307 --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --server-id=101 --log-error=jystdrac2.err --pid-file=jystdrac2.pid --socket=/tmp/mysql.sock3307 --port=3307
mysql 11461 10947 0 23:48 pts/0 00:00:00 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/data/mysqldata/3309 --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --server-id=103 --log-error=jystdrac2.err --pid-file=jystdrac2.pid --socket=/tmp/mysql.sock3309 --port=3309
mysql 11463 10930 0 23:48 pts/0 00:00:00 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/data/mysqldata/3308 --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --server-id=102 --log-error=jystdrac2.err --pid-file=jystdrac2.pid --socket=/tmp/mysql.sock3308 --port=3308
mysql 11472 10963 0 23:48 pts/0 00:00:00 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/data/mysqldata/3310 --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --server-id=104 --log-error=jystdrac2.err --pid-file=jystdrac2.pid --socket=/tmp/mysql.sock3310 --port=3310
root 12228 7701 0 23:51 pts/0 00:00:00 grep mysql
[root@jystdrac2 mysql]# mysqld_multi stop
[root@jystdrac2 mysql]# mysqld_multi report
Reporting MySQL servers
MySQL server from group: mysqld1 is not running
MySQL server from group: mysqld2 is not running
MySQL server from group: mysqld3 is not running
MySQL server from group: mysqld4 is not running
[root@jystdrac2 mysql]# ps -ef|grep mysql
root 12400 7701 0 23:52 pts/0 00:00:00 grep mysql
[root@jystdrac2 mysql]# mysqld_multi start
[root@jystdrac2 mysql]# mysqld_multi report
Reporting MySQL servers
MySQL server from group: mysqld1 is running
MySQL server from group: mysqld2 is running
MySQL server from group: mysqld3 is running
MySQL server from group: mysqld4 is running
[root@jystdrac2 mysql]#

MySQL多实例安装(相同版本)的更多相关文章

  1. linux下mysql多实例安装

    1.MySQL多实例介绍 1.1.什么是MySQL多实例 MySQL多实例就是在一台机器上开启多个不同的服务端口(如:3306,3307),运行多个MySQL服务进程,通过不同的socket监听不同的 ...

  2. mysql多实例安装与ssl认证

    mysql多实例安装有两种形式: 同一数据库版本的多实例安装. 不同数据库版本的多实例安装. 同一数据库的多实例安装: 在同一台机器上安装4台mysql数据库实例. 从官网下载MySQL5.6版本的二 ...

  3. linux下mysql多实例安装(转)

    转自:http://www.cnblogs.com/xuchenliang/p/6843990.html   1.MySQL多实例介绍 1.1.什么是MySQL多实例 MySQL多实例就是在一台机器上 ...

  4. Mysql多实例安装+主从复制+读写分离 -学习笔记

    Mysql多实例安装+主从复制+读写分离 -学习笔记 .embody{ padding:10px 10px 10px; margin:0 -20px; border-bottom:solid 1px ...

  5. Windows下MySQL多实例安装/主从复制/重置密码

    Windows创建MySQL多实例 安装MYSQL和实例1 运行mysql-installer-community-5.7.16.0.msi 选择组件 MySQL Server 5.7.16 – X6 ...

  6. Mysql多实例 安装以及配置

    MySQL多实例 1.什么是MySQL多实例 简单地说,Mysql多实例就是在一台服务器上同时开启多个不同的服务端口(3306.3307),同时运行多个Mysql服务进程,这些服务进程通过不同的soc ...

  7. windows下mysql多实例安装

    在学习和开发过程中有时候会用到多个MySQL数据库,比如Master-Slave集群.分库分表,开发阶段在一台机器上安装多个MySQL实例就显得方便不少. 在 MySQL教程-基础篇-1.1-Wind ...

  8. mysql多实例安装详解

    首先说明一个场景:我的电脑是ubuntu系统,之前apt-get自动安装过mysql.这也是出现错误最多的原因之一. 安装过程,其中充斥着各种错误: 6.mkdir mysql 7.groupadd  ...

  9. centos下mysql多实例安装3306、3307实例(2014-10-15)

    背景说明       mysql的安装方法有多种,如二进制安装.源代码编译安装.yum安装等.yum安装仅仅能安装mysql 5.1 版本号:源代码安装编译的过程比較长.若没有对源代码进行改动且要求使 ...

随机推荐

  1. JavaSE复习~基本数据类型

    数据类型 java有两大类数据类型:基本数据类型 和 引用数据类型 基本数据类型 整数型:byte.short.int.long 浮点型:float.double 字符型:char 布尔型:boole ...

  2. C语言函数不能返回数组,但可以返回结构体

    为什么C语言函数可以返回结构体,却不可以返回数组?有这样的问题并不奇怪,因为C语言数组和结构体本质上都是管理一块内存,那为何编译器要区别对待二者呢? C语言函数为什么不能返回数组? 在C语言程序开发中 ...

  3. Hibernate学习(五)

    自关联测试案例 1.创建表 drop table if exists t_category ; create table t_category ( id ) primary key , name ) ...

  4. MySQL优化2.索引

    什么是索引: 索引的作用相当于图书的目录,可以根据目录中的页码快速找到所需的内容. 建立索引合适的列 经常用作where条件的列,order by排序的列 数据列不重复而且并不是唯一的几个值 不被经常 ...

  5. Educational Codeforces Round 77 (Rated for Div. 2) - D. A Game with Traps(二分)

    题意:$m$个士兵,每个士兵都有一个灵敏度$a[i]$,起点为$0$,终点为$n + 1$,在路上有$k$个陷阱,每个陷阱有三个属性$l[i],r[i],d[i]$,$l[i]$表示陷阱的位置,如果你 ...

  6. Shell函数!

    1.作用:将命令序列按格式写在一起,可方便重复使用命令序列2.Shell 函数定义格式:[ function ] 函数名(){命令序列[ return x ]}3.调用函数的方法:函数名 [ 参数 1 ...

  7. Day11 - F - A Dangerous Maze LightOJ - 1027

    求期望注意期望的定义,这题我们可以分正负数情况,设所求期望为E 正数: 1/n*x_i 负数:1/n*(E+x_j) 此时概率为1/n,根据期望定义,他回到起点后出去的期望为E,花费回起点的时间为x_ ...

  8. RestTemplate post请求使用map传参 Controller 接收不到值的解决方案 postForObject方法源码解析.md

    结论 post方法中如果使用map传参,需要使用MultiValueMap来传递 RestTemplate 的 postForObject 方法有四个参数 String url => 顾名思义 ...

  9. 【网寻】IE F12 后报错,无法查看 DOM 等信息

    错误图片: 解决办法 : 安装Windows7补丁:KB3008923: 补丁下载地址: http://www.microsoft.com/en-us/download/details.aspx?id ...

  10. Pycharm 在 import requests 时报错

    requests的安装我尝试了两种方法: 第一种:下载安装 https://github.com/requests/requests 然后解压到:(python的安装路径,这里使用的是默认路径) Ap ...