如何单机部署多个 MySQL 8.0 实例 ?

在服务器资源有限的情况下,可利用该方案快速搭建各类 mysql 架构方案。各 MySQL 实例共享一个 mysqld 主程序,但各实例数据目录是独立的,存放在不同的文件夹中;好了、废话不多说,直接上干货,具体搭建步骤如下

原文链接

环境介绍

实例 主机 mysql port mysqlx port datadir
mysql1 192.168.31.100 3306 33060 /var/lib/mysql1/
mysql2 192.168.31.100 3307 33070 /var/lib/mysql2/
mysql3 192.168.31.100 3308 33080 /var/lib/mysql3/

部署 MySQL 主程序

1、通过官方二进制包解压安装

wget https://cdn.mysql.com/archives/mysql-8.0/mysql-8.0.30-el7-x86_64.tar.gz
tar xzf mysql-8.0.30-el7-x86_64.tar.gz
mv mysql-8.0.30-el7-x86_64 /usr/local/mysql

# vim /etc/profile 添加环境变量,执行 source /etc/profile 使配置在当前 shell 下生效
export PATH=$PATH:/usr/local/mysql/bin/

# 创建各 mysql 服务器实例的数据目录 datadir
useradd -r -M mysql -s /bin/false
mkdir -p /var/lib/mysql{1..3} && chown mysql.mysql /var/lib/mysql{1..3}

修改 MySQL 实例配置

设置各 mysql 实例的配置文件

cat > /etc/my.cnf << EOF
[mysqld_multi]
mysqld = /usr/local/mysql/bin/mysqld_safe
mysqladmin = /usr/local/mysql/bin/mysqladmin
user = root
pass = root             # 后续变更各 mysql 实例 root 账号的初始随机密码为简单密码 root,因为停止各 mysql 实例时需使用此密码
log = /var/log/mysql_multi.log

# mysql 实例一
[mysqld1]
server-id = 1
socket = /var/lib/mysql1/mysql.sock
port = 3306
bind_address = 0.0.0.0
datadir = /var/lib/mysql1
user = mysql
performance_schema = off
innodb_buffer_pool_size = 32M
skip_name_resolve = 1
log_error = error.log
pid-file = /var/lib/mysql1/mysql.pid
mysqlx = 1        # 设置 0 则禁用 mysqlx, 其默认监听端口 33060
mysqlx-port = 33060

# mysql 实例二
[mysqld2]
server-id = 2
socket = /var/lib/mysql2/mysql.sock
port = 3307
bind_address = 0.0.0.0
datadir = /var/lib/mysql2
user = mysql
performance_schema = off
innodb_buffer_pool_size = 32M
skip_name_resolve = 1
log_error = error.log
pid-file = /var/lib/mysql2/mysql.pid
mysqlx = 1
mysqlx-port = 33070

# mysql 实例三
[mysqld3]
server-id = 3
socket = /var/lib/mysql3/mysql.sock
port = 3308
bind_address = 0.0.0.0
datadir = /var/lib/mysql3
user = mysql
performance_schema = off
innodb_buffer_pool_size = 32M
skip_name_resolve = 1
log_error = error.log
pid-file = /var/lib/mysql3/mysql.pid
mysqlx = 1
mysqlx-port = 33080
EOF

初始化 MySQL 实例

1、初始化 MySQL 实例,记录各实例的初始随机密码

/usr/local/mysql/bin/mysqld --initialize --user=mysql --datadir=/var/lib/mysql1
#> 2023-03-15T01:22:52.092218Z 0 [System] [MY-013169] [Server] /usr/local/mysql/bin/mysqld (mysqld 8.0.30) initializing of server in progress as process 15026
#> 2023-03-15T01:22:52.119703Z 1 [System] [MY-013576] [InnoDB] InnoDB initialization has started.
#> 2023-03-15T01:22:55.237170Z 1 [System] [MY-013577] [InnoDB] InnoDB initialization has ended.
#> 2023-03-15T01:23:00.616679Z 6 [Note] [MY-010454] [Server] A temporary password is generated for root@localhost: lqYujqcue7*_

# 同理,初始化其它 mysql 实例(mysql2、mysql3)
/usr/local/mysql/bin/mysqld --initialize --user=mysql --datadir=/var/lib/mysql2
/usr/local/mysql/bin/mysqld --initialize --user=mysql --datadir=/var/lib/mysql3

启动 mysql 实例

设置多实例启动程序

cp /usr/local/mysql/support-files/mysqld_multi.server /etc/init.d/mysqld_multid
chmod +x /etc/init.d/mysqld_multid

# 启动 各 mysql 实例
/etc/init.d/mysqld_multid start
chkconfig mysqld_multid on              # 可选,设置开机启动

/etc/init.d/mysqld_multid 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

netstat -ntlp | grep mysqld
#> 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      19867/mysqld
#> tcp        0      0 0.0.0.0:3307            0.0.0.0:*               LISTEN      19869/mysqld
#> tcp        0      0 0.0.0.0:3308            0.0.0.0:*               LISTEN      19876/mysqld
#> tcp6       0      0 :::33080                :::*                    LISTEN      19876/mysqld
#> tcp6       0      0 :::33060                :::*                    LISTEN      19867/mysqld
#> tcp6       0      0 :::33070                :::*                    LISTEN      19869/mysqld

# 停止 各 mysql 实例,需先更新 root 账号密码为 root,因为其实现原理是通过 mysqladmin 登录到各 mysql 实例执行 shutdown
/etc/init.d/mysqld_multid stop

更新 root 账号密码

1、使用初始随机密码登录各 MySQL 实例

mysql -u root -p -P3306 -S /var/lib/mysql1/mysql.sock
mysql -u root -p -P3307 -S /var/lib/mysql2/mysql.sock
mysql -u root -p -P3308 -S /var/lib/mysql3/mysql.sock

2、设置 MySQL root 账号为简单密码 root,且允许从任意主机访问数据库

-- 做任何操作前,需按照默认安全策略配置一个密码,才允许后续操作
alter user user() identified by 'Admin@123';
-- 设置密码策略,否则报错提示不满足现有密码策略,如 ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
show global variables like "validate_password%";
set global validate_password.policy=0;              -- validate_password_policy 设置 0 低级 1 中级 2 高级
set global validate_password.length=4;
set global validate_password.check_user_name = 0
set global validate_password.mixed_case_count = 0;
set global validate_password.number_count=0;
set global validate_password.special_char_count=0;

-- 修改 root 账号为简单密码 root
alter user user() identified by 'root';
update mysql.user set host='%' where user='root';
flush privileges;
exit;

参考

MySQL-5.7.x 二进制包,官方下载地址

原文链接:https://www.cnblogs.com/ywjsbang/p/17262761.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:如何单机部署多个 MySQL 8.0 实例 ? - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • mysql5.7以上版本配置my.ini的详细步骤

    当MySQL版本升级至5.7及以上时,需要对my.ini文件进行配置。下面是步骤: 打开MySQL的安装目录,找到my-default.ini文件并复制一份; 将复制出来的my-default.ini文件重命名为my.ini; 打开my.ini文件进行编辑; 在[mysql]下添加default-character-set=utf8mb4 找到[mysqld…

    MySQL 2023年5月18日
    00
  • mysql启动报错:The server quit without updating PID file的几种解决办法汇总

    下面我就介绍一下关于”mysql启动报错:The server quit without updating PID file的几种解决办法汇总”的完整攻略。 问题描述 在使用MySQL时,可能会遇到”The server quit without updating PID file”的错误信息,这个错误信息通常会伴随着MySQL启动失败。可能的错误原因包括:…

    MySQL 2023年5月18日
    00
  • 深入了解MySQL中的慢查询

    深入了解MySQL中的慢查询攻略 MySQL是广泛使用的开源关系型数据库管理系统,在处理大量数据时常常遇到慢查询的情况。本文将介绍如何深入了解MySQL中的慢查询问题,引导你从以下几个方面进行优化。 使用慢查询日志功能 MySQL提供了慢查询日志功能来记录执行时间超过指定时间的SQL语句。启用慢查询日志可以帮助我们找到执行时间较长的SQL语句,进而进行优化。…

    MySQL 2023年5月19日
    00
  • Mysql安装注意事项、安装失败的五个原因分析

    Mysql安装注意事项 在安装MySQL之前,有一些需要注意的事项,以便确保安装的成功和顺利。以下是一些需要注意的事项: 操作系统版本和位数需与mysql版本对应首先,需要下载与你的操作系统版本和位数相对应的MySQL版本。如果你的操作系统是64位,那么你需要下载64位的MySQL版本。 确认服务器端口默认情况下,MySQL使用3306端口。我们需要确保该端…

    MySQL 2023年5月18日
    00
  • MySQL 查询速度慢的原因

    MySQL 查询速度慢,可能由以下几个方面的原因导致: 1. 查询语句不够优化 查询语句的效率很大程度上取决于其表达式的完整性与合理性,能否充分利用优化器的功能。比如: 1.1. 索引使用不正确 可以使用 explain 命令查看查询语句的执行计划,确定是否使用了索引,以及使用的是哪个索引。通过 index 列可以查看MySQL优化器是否有效地使用索引,如果…

    MySQL 2023年5月19日
    00
  • MySQL修改和删除索引(DROP INDEX)方法详解

    修改索引 1.修改单个索引列: ALTER TABLE table_name MODIFY INDEX index_name(column_name_new); 2.修改多列组成的联合索引列: ALTER TABLE table_name DROP INDEX index_name, ADD INDEX index_name(column_name_new1…

    MySQL 2023年3月10日
    00
  • MySQL如何基于Explain关键字优化索引功能

    MySQL的优化索引功能是基于Explain关键字实现的,Explain语句可以将优化器的执行计划以文本形式展示出来,从而帮助我们更好地理解和调优查询语句的执行过程。下面是基于Explain关键字优化索引的详细攻略: 索引介绍 索引是数据库中重要的数据结构之一,用于快速查找数据。MySQL支持多种索引类型,包括普通索引、唯一索引、全文索引等。索引的优点是可以…

    MySQL 2023年5月19日
    00
  • 数据库系统原理之数据库应用设计与开发实例

    数据库应用设计与开发实例 第一节 需求描述与分析 在此,结合某高校个性化课程在线选课的实际需求,给出一个简化的需求分析 一、功能性需求 1 管理员后台模块 学生信息管理 教师信息管理 课程信息管理 班级信息管理 2 学生使用模块 查询课程 浏览所选课程 查询成绩 3 教师使用模块 我的课程 登分 二、非功能性需求 在线选课系统 浏览器/服务器(B/S) 结构…

    MySQL 2023年4月17日
    00
合作推广
合作推广
分享本页
返回顶部