mysql多实例介绍及配置

1、mysql多实例介绍

1.1 什么是mysql多实例

mysql多实例就是在一台机器上开启多个不同的服务端口(如:3306,3307),运行多个MySQL服务进程,通过不同的socket监听不同的服务端口来提供各自的服务:;

1.2 mysql多实例的特点有以下几点

1:有效利用服务器资源,当单个服务器资源有剩余时,可以充分利用剩余的资源提供更多的服务。

2:节约服务器资源

3:资源互相抢占问题,当某个服务实例服务并发很高时或者开启慢查询时,会消耗更多的内存、CPU、磁盘IO资源,导致服务器上的其他实例提供服务的质量下降;

1.3 部署mysql多实例的两种方式

第一种是使用多个配置文件启动不同的进程来实现多实例,这种方式的优势逻辑简单,配置简单,缺点是管理起来不太方便;

第二种是通过官方自带的mysqld_multi使用单独的配置文件来实现多实例,这种方式定制每个实例的配置不太方面,优点是管理起来很方便,集中管理;

1.4 同一开发环境下安装两个数据库,必须处理以下问题

配置文件安装路径不能相同

数据库目录不能相同

启动脚本不能同名

端口不能相同

socket文件的生成路径不能相同

2、mysqld_multi配置mysql多实例

在进行此操作前已经编译安装好了mysql,安装位置在/application/mysql/下

2.1 初始化数据目录

mkdir /usr/local/var -p

/application/mysql/scripts/mysql_install_db --basedir=/application/mysql/ --datadir=/usr/local/var/mysql1 --user=mysql

/application/mysql/scripts/mysql_install_db --basedir=/application/mysql/ --datadir=/usr/local/var/mysql2 --user=mysql

/application/mysql/scripts/mysql_install_db --basedir=/application/mysql/ --datadir=/usr/local/var/mysql3 --user=mysql

/application/mysql/scripts/mysql_install_db --basedir=/application/mysql/ --datadir=/usr/local/var/mysql4 --user=mysql

修改授权

chown -R mysql.mysql /usr/local/var/mysql*

2.2 配置多实例启动脚本

cp /application/mysql/support-files/mysqld_multi.server /etc/init.d/

#修改basedir和bindir为安装路径

basedir=/application/mysql

bindir=/application/mysql/bin

2.3 配置多实例数据库配置文件

在/etc/目录下创建创建文件/etc/mysqld_multi.cnf,内容如下

[mysqld_multi]

mysqld = /application/mysql/bin/mysqld_safe

mysqladmin = /application/mysql/bin/mysqladmin

#user = mysql

#password = my_password

[mysqld1]

socket = /usr/local/var/mysql1/mysql1.sock

port = 3306

pid-file = /usr/local/var/mysql1/mysql1.pid

datadir = /usr/local/var/mysql1

#language = /usr/local/mysql/share/mysql/english

user = mysql

[mysqld2]

socket = /usr/local/var/mysql2/mysql2.sock

port = 3307

pid-file = /usr/local/var/mysql2/mysql2.pid

datadir = /usr/local/var/mysql2

#language = /usr/local/mysql/share/mysql/english

user = mysql

[mysqld3]

socket = /usr/local/var/mysql3/mysql3.sock

port = 3308

pid-file = /usr/local/var/mysql3/mysql3.pid

datadir = /usr/local/var/mysql3

#language = /usr/local/mysql/share/mysql/english

user = mysql

[mysqld4]

socket = /usr/local/var/mysql4/mysql4.sock

port = 3309

pid-file = /usr/local/var/mysql4/mysql4.pid

datadir = /usr/local/var/mysql4

#language = /usr/local/mysql/share/mysql/english

user = mysql

2.4 启动多实例数据库

mysqld_multi --defaults-extra-file=/etc/mysqld_multi.cnf start

#启动或停止具体某一个实例可在start、stop后面加上具体数据1,2,3等

mysqld_multi进行多实例管理

启动全部实例:/usr/local/mysql/bin/mysqld_multi --defaults-extra-file=/etc/mysqld_multi.cnf start

查看全部实例状态:/usr/local/mysql/bin/mysqld_multi report

启动单个实例:/usr/local/mysql/bin/mysqld_multi --defaults-extra-file=/etc/mysqld_multi.cnf start 3306

停止单个实例:/usr/local/mysql/bin/mysqld_multi --defaults-extra-file=/etc/mysqld_multi.cnf stop 3306

查看单个实例状态:/usr/local/mysql/bin/mysqld_multi --defaults-extra-file=/etc/mysqld_multi.cnf report 3306

检查

[root@db02 ~]# netstat -lntup

Active Internet connections (only servers)

Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name

tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 5016/mysqld

tcp 0 0 0.0.0.0:3307 0.0.0.0:* LISTEN 5026/mysqld

tcp 0 0 0.0.0.0:3308 0.0.0.0:* LISTEN 5036/mysqld

tcp 0 0 0.0.0.0:3309 0.0.0.0:* LISTEN 5042/mysqld

tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 1317/sshd

tcp 0 0 :::22 :::* LISTEN 1317/sshd

2.5 登录相应数据库

#进入端口为3306的数据库

mysql -uroot -p -h127.0.0.1 -P3306 ####密码为空

或者

mysql -S /usr/local/var/mysql1/mysql1.sock

3、多配置文件实现MySQL多实例

在进行此操作前已经编译安装好了mysql,安装位置在/application/mysql/下

3.1 创建目录和配置文件

mkdir -p /data/{3306,3307}/data

vim /data/3306/my.cnf

[client]

port = 3306

socket = /data/3306/mysql.sock

[mysql]

no-auto-rehash

[mysqld]

user = mysql

port = 3306

socket = /data/3306/mysql.sock

basedir = /application/mysql

datadir = /data/3306/data

pid-file = /data/3306/mysql.pid

log-bin = /data/3306/mysql-bin

relay-log = /data/3306/relay-bin

relay-log-info-file = /data/3306/relay-log.info

server-id = 1

[mysqld_safe]

log-error=/data/3306/mysql_3306.err

pid-file=/data/3306/mysqld.pid

3.2 创建启动脚本

vim /data/3306/mysql

#!/bin/sh

#init

port=3306

CmdPath="/application/mysql/bin"

mysql_sock="/data/${port}/mysql.sock"

#startup function

function_start_mysql()

{

if [ ! -e "$mysql_sock" ];then

printf "Starting MySQL...\n"

/bin/sh ${CmdPath}/mysqld_safe --defaults-file=/data/${port}/my.cnf 2>&1 > /dev/null &

else

printf "MySQL is running...\n"

exit

fi

}

#stop function

function_stop_mysql()

{

if [ ! -e "$mysql_sock" ];then

printf "MySQL is stopped...\n"

exit

else

printf "Stoping MySQL...\n"

${CmdPath}/mysqladmin -u ${mysql_user} -p${mysql_pwd} -S /data/${port}/mysql.sock shutdown

fi

}

#restart function

function_restart_mysql()

{

printf "Restarting MySQL...\n"

function_stop_mysql

sleep 2

function_start_mysql

}

case $1 in

start)

function_start_mysql

;;

stop)

function_stop_mysql

;;

restart)

function_restart_mysql

;;

*)

printf "Usage: /data/${port}/mysql {start|stop|restart}\n"

esac

3.4 增加3307实例

sed 's#3306#3307#g;s#server-id = 1#server-id = 3#g' /data/3306/my.cnf >/data/3307/my.cnf

sed 's#3306#3307#g' /data/3306/mysql >/data/3307/mysql

3.5 修改权限

chown -R mysql.mysql /data

chmod +x /data/{3306,3307}/mysql

3.6 初始化

/application/mysql/scripts/mysql_install_db --user=mysql --basedir=/application/mysql --datadir=/data/3306/data

/application/mysql/scripts/mysql_install_db --user=mysql --basedir=/application/mysql --datadir=/data/3307/data

3.7 启动

/data/3306/mysql start

/data/3307/mysql start

启动的时候报错

[root@db01 ~]# 180707 16:30:54 mysqld_safe error: log-error set to '/data/3306/mysql_3306.err', however file don't exists. Create writable for user 'mysql'.

手动创建文件并授权,再次启动成功

touch /data/3306/mysql_3306.err

chown mysql:mysql /data/3306/mysql_3306.err

检查

[root@db01 ~]# netstat -lntup|grep mysql

tcp6 0 0 :::3306 :::* LISTEN 2023/mysqld

tcp6 0 0 :::3307 :::* LISTEN 2505/mysqld

3.8 初始化密码登录

mysqladmin -uroot -S /data/3306/mysql.sock password '123456'

mysqladmin -uroot -S /data/3307/mysql.sock password '123456'

参考来源:

https://www.cnblogs.com/xuchenliang/p/6843990.html

https://blog.csdn.net/clevercode/article/details/47610619

https://blog.csdn.net/clevercode/article/details/47659457

mysql多实例介绍及配置的更多相关文章

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

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

  2. MySQL多实例介绍

    我们前面已经做了MySQL数据库的介绍以及为什么选择MySQL数据库,最后介绍了MySQL数据库在Linux系统下的多种安装方式,以及讲解了MySQL的二进制方式单实例安装.基础优化等,下面给大家讲解 ...

  3. MySQL多实例安装、配置、启动(四)

    一.规划信息 系统信息: cat /etc/redhat-release CentOS Linux release (Core) # uname -r -.el7.x86_64 数据库规划 PORT: ...

  4. Mysql 之多实例 安装以及配置

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

  5. linux下mysql多实例安装

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

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

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

  7. linux运维、架构之路-MySQL多实例

    一.MySQL多实例介绍            一台服务器上开启多个不同的服务端口(3306,3307,3308),运行多个MySQL服务进程,共用一套MySQL安装程序,多实例MySQL在逻辑上看是 ...

  8. Mysql多实例数据库安装应用

    第1章 MySQL多实例数据库企业级应用实践 1.1 MySQL多实例介绍 前文已经讲了为什么选择MySQL数据库,以及MySQL数据库在Linux系统下的多种安装方式,同时以单实例讲解了编译方式安装 ...

  9. Linux平台下源码安装mysql多实例数据库

    Linux平台下源码安装mysql多实例数据库[root@linux-node1 ~]# netstat -tlunp | grep 330tcp6 0 0 :::3306 :::* LISTEN 6 ...

随机推荐

  1. 使用dpkg命令卸载已经安装的软件包

    如何在Ubuntu中使用dpkg命令卸载软件 http://jingyan.baidu.com/article/f54ae2fc2724a71e92b849c4.html sudo dpkg -i x ...

  2. 谈谈对final的理解

    1.final修饰类 类不能被继承,类中的所有方法都是final的 2.final修饰方法 方法不能被覆盖,private修饰的方法隐性的添加了final 3.final修饰方法内参数 方法内的参数不 ...

  3. 四十九 常用内建模块 urllib

    urllib提供了一系列用于操作URL的功能. Get urllib的request模块可以非常方便地抓取URL内容,也就是发送一个GET请求到指定的页面,然后返回HTTP的响应: 例如,对豆瓣的一个 ...

  4. vue-music 关于基础组件 (Tab组件)

      定义在项目的基础组类别的 tab组件中,定义一个tab切换数量的数组 和一个currentIndex 当前高亮索引 的props,当前高亮(active)的类等于currentIndex === ...

  5. php漏洞tips

    1.php后缀限制 'php,php3,php4,php5,php6,php7,phpsh,inc,phtml','PHT'; 2.php木马 <?php echo shell_exec($_G ...

  6. 洛谷P1197 [JSOI2008] 星球大战 [并查集]

    题目传送门 星球大战 题目描述 很久以前,在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统治者整个星系. 某一天,凭着一个偶然的机遇,一支反抗军摧毁了帝国的超级武器,并攻下了星系中几乎所有的星球.这 ...

  7. 读书笔记(高性能javascript)(二)

    5. 字符串和正则表达式: (1) 在大多数浏览器中,数组项合并(Array.prototype.join)比其他字符串连接方法更慢,但它却在IE7及更早版本浏览器中合并大量字符串唯一高效的途径: ( ...

  8. HZAU 1205 Sequence Number(双指针)

    题目链接:http://acm.hzau.edu.cn/problem.php?id=1205 [题意]给你一串数,要求你找到两个数a[i],a[j],使得a[i]<=a[j]且j>=i且 ...

  9. 手机上编程,编写android apk

    韩梦飞沙 yue31313 韩亚飞 han_meng_fei_sha  313134555@qq.com C4Droid:在手机上直接编程,然后导出为apk

  10. Thupc2017"礼"?

    题面 先粘上gouzhi的题面,听说是thupc的题 [问题背景] 情人节要到了,zhx 要给女朋友买礼物. [问题描述] 橱窗里摆放了 n 种不同的玩偶,购买第 i 种玩偶需要价格 a[i],价值为 ...