阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

mysqld_multi 多实例启动工具

441次阅读
没有评论

共计 3865 个字符,预计需要花费 10 分钟才能阅读完成。

一、MySQL 多实例简介

MySQL 多实例,简单地说,就是在一台服务器上同时开启多个不同的服务端口(如:3306、3307),同时运行多个 MySQL 服务进程,这些服务进程通过不同的 socket 监听来自不同的端口来提供服务;多实例不仅节省物理主机成本,还有效提升了单台物理主机的 CPU、磁盘 I / O 使用效率,而且还可以在多实例之间做部署数据库 HA 方案。

随着实例数量的增加,就面临统一管理问题,这样我们就需要用 MySQL 自带的管理程序 mysqld_multi 来进行管理 …

二、MySQL 启动流程

mysqld_multi 多实例启动工具

mysqld_multi    #多实例管理程序
mysqld      #以前老版本的 MySQL 最主要的启动方式,里面有很多参数;现在使用多实例就需要用新的 mysql_safe 来启动 mysql
mysql_safe    #实则还是调用 mysqld,并且会读取 mysqld 中的 my.cnf 配置参数来启动 mysql,mysql_safe 本身也有很多参数,但是这些参数会优先于 my.cnf
my.cnf      #mysql 的配置文件
my.sock    #mysql 创建的 sock 文件,开启、停止、登陆和管理 mysql 都是通过这个接口文件

三、接下来,利用 mysqld_multi  配置一个多实例 …

安装环境:CentOS 6.7 _64
下载 mysql-5.5.32.tar.gz 编译安装包
yum install -y ncurses-devel libaio-devel
yum install -y cmake
tar zxf mysql-5.5.32.tar.gz
cd mysql-5.5.32
cmake .-DCMAKE_INSTALL_PREFIX=/application/mysql-5.5.32 \
-DMYSQL_DATADIR=/application/mysql-5.5.32/data \
-DMYSQL_UNIX_ADDR=/application/mysql-5.5.32/tmp/mysql.sock \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DEXTRA_CHARSETS=gbk,gb2312,utf8,ascii \
-DENABLED_LOCAL_INFILE=ON \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_FEDERATED_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 \
-DWITHOUT_PARTITION_STORAGE_ENGINE=1 \
-DWITH_FAST_MUTEXES=1 \
-DWITH_ZLIB=bundled \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_READLINE=1 \
-DWITH_EMBEDDED_SERVER=1 \
-DWITH_DEBUG=0

 

make && make install
ln -s /application/mysql-5.5.32/ /application/mysql
mkdir -p /data/{3306,3307,3308}/data #创建单独实例数据文件夹
useradd mysql -s /sbin/nologin -M
chown -R mysql.mysql /data
cp /application/mysql/bin/* /usr/local/sbin/      #添加环境变量
cd /application/mysql/scripts/ #初始化数据库
./mysql_install_db –basedir=/application/mysql/ –datadir=/data/3306/data/ –user=mysql
./mysql_install_db –basedir=/application/mysql/ –datadir=/data/3307/data/ –user=mysql
./mysql_install_db –basedir=/application/mysql/ –datadir=/data/3308/data/ –user=mysql
/bin/cp /application/mysql/support-files/my-medium.cnf /etc/my.cnf  #拷贝 my.cnf 配置文件
cp /application/mysql/support-files/mysql.server /etc/init.d/mysqld.server #拷贝启动文件

cp /application/mysql/support-files/mysqld_multi.server /etc/init.d/mysqld_multi.server 
# 拷贝 mysqld_multi 程序文件
# 修改 mysqld_multi.server 路径配置
sed -i ‘s#basedir=/usr/local/mysql#basedir=/application/mysql#g’ /etc/init.d/mysqld_multi.server
sed -i ‘s#bindir=/usr/local/mysql/bin#bindir=/application/mysql/bin#g’ /etc/init.d/mysqld_multi.server

# 添加 mysqld_multi 用到的 /etc/mysqld_multi.cnf 配置文件
# 这个模板文件可以用命令 mysqld_multi –example 导出来
[root@lb01 scripts]# vim /etc/mysqld_multi.cnf 
[mysqld_multi]
mysqld    = /application/mysql-5.5.32/bin/mysqld_safe
mysqladmin = /application/mysql-5.5.32/bin/mysqladmin
#user      = multi_admin
#password  = my_password
[mysqld2]
socket    = /data/3306/mysql.sock
port      = 3306
pid-file  = /data/3306/mysql.pid
datadir    = /data/3306/data
#language  = /application/mysql-5.5.32/share/mysql/english
user      = mysql
[mysqld3]
socket    = /data/3307/mysql.sock
port      = 3307
pid-file  = /data/3307/mysql.pid
datadir    = /data/3307/data
#language  = /application/mysql-5.5.32/share/mysql/english

 

user      = mysql
[mysqld4]
socket    = /data/3308/mysql.sock
port      = 3308
pid-file  = /data/3308/mysql.pid
datadir    = /data/3308/data
#language  = /application/mysql-5.5.32/share/mysql/english
user      = mysql

然后就是启动多实例:
# 查看数据库状态 
mysqld_multi –defaults-extra-file=/etc/mysqld_multi.cnf report
[root@lb01 etc]# mysqld_multi –defaults-extra-file=/etc/mysqld_multi.cnf report
Reporting MySQL servers
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@lb01 etc]# mysqld_multi –defaults-extra-file=/etc/mysqld_multi.cnf start 2,3,4
[root@lb01 etc]# mysqld_multi –defaults-extra-file=/etc/mysqld_multi.cnf report
Reporting MySQL servers
MySQL server from group: mysqld2 is running
MySQL server from group: mysqld3 is running
MySQL server from group: mysqld4 is running
# 停止数据库
[root@lb01 etc]# mysqld_multi –defaults-extra-file=/etc/mysqld_multi.cnf stop 2,3,4
# 登陆数据库
mysql -uroot -h127.0.0.1 -P3306
或者指定 socket 登陆
[root@lb01 etc]# mysql -S /data/3306/mysql.sock

本文永久更新链接地址 :http://www.linuxidc.com/Linux/2016-07/133516.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计3865字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19348
评论数
4
阅读量
7804658
文章搜索
热门文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
150元打造低成本NAS小钢炮,捡一块3865U工控板

150元打造低成本NAS小钢炮,捡一块3865U工控板

150 元打造低成本 NAS 小钢炮,捡一块 3865U 工控板 一块二手的熊猫 B3 工控板 3865U,搭...
零成本上线!用 Hugging Face免费服务器+Docker 快速部署HertzBeat 监控平台

零成本上线!用 Hugging Face免费服务器+Docker 快速部署HertzBeat 监控平台

零成本上线!用 Hugging Face 免费服务器 +Docker 快速部署 HertzBeat 监控平台 ...
每天一个好玩的网站-手机博物馆-CHAZ 3D Experience

每天一个好玩的网站-手机博物馆-CHAZ 3D Experience

每天一个好玩的网站 - 手机博物馆 -CHAZ 3D Experience 一句话介绍:一个用 3D 方式重温...
Prometheus:监控系统的部署与指标收集

Prometheus:监控系统的部署与指标收集

Prometheus:监控系统的部署与指标收集 在云原生体系中,Prometheus 已成为最主流的监控与报警...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞...
手把手教你,购买云服务器并且安装宝塔面板

手把手教你,购买云服务器并且安装宝塔面板

手把手教你,购买云服务器并且安装宝塔面板 前言 大家好,我是星哥。星哥发现很多新手刚接触服务器时,都会被“选购...
星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛 NAS 硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话? 前言 在选择 NAS 用预...
星哥带你玩飞牛NAS硬件02:某鱼6张左右就可拿下5盘位的飞牛圣体NAS

星哥带你玩飞牛NAS硬件02:某鱼6张左右就可拿下5盘位的飞牛圣体NAS

星哥带你玩飞牛 NAS 硬件 02:某鱼 6 张左右就可拿下 5 盘位的飞牛圣体 NAS 前言 大家好,我是星...
颠覆 AI 开发效率!开源工具一站式管控 30+大模型ApiKey,秘钥付费+负载均衡全搞定

颠覆 AI 开发效率!开源工具一站式管控 30+大模型ApiKey,秘钥付费+负载均衡全搞定

  颠覆 AI 开发效率!开源工具一站式管控 30+ 大模型 ApiKey,秘钥付费 + 负载均衡全...