hugo-teek is loading...

Centos7配置mysql多实例-mysql-5-7-42

最后更新于:

实战:Centos7配置mysql多实例(mysql-5.7.42)-2024.4.20(测试成功)

image-20240420162318911

目录

[toc]

实验环境

1centos7 1810
2mysql-5.7.42-linux-glibc2.12-x86_64.tar.gz

实验软件

链接:https://pan.baidu.com/s/1zFL_PF2J_cEJBCUUPbf3Hg?pwd=0elw 提取码:0elw 2024.4.20-实战:Centos7配置mysql多实例-2024.4.20(测试成功)

image-20240420163002029

下载mysql安装包

进入官网下载专用的mysql安装包,专用的才支持多实例

https://downloads.mysql.com/archives/community/

image-20240420160232244

确保无旧的mysql环境

配置mysql安装环境,首先确保你已经卸载全部之前安装过的mysql文件

1# 卸载方法
2yum list installed | grep mysql
3yum remove -y mysql-server

上传安装包并解压

  • 上传安装包到你的虚拟机或者服务器:
1[root@vm-template ~]#ll -h
2total 647M
3-rw-rw-rw- 1 root root 647M Apr 20 15:12 mysql-5.7.42-linux-glibc2.12-x86_64.tar.gz
  • 解压然后移动到本地要安装的文件夹
1tar -xf mysql-5.7.42-linux-glibc2.12-x86_64.tar.gz
2mv mysql-5.7.42-linux-glibc2.12-x86_64 /usr/local/mysql

编写my.cnf配置文件

 1#先备份
 2cp /etc/my.cnf{,.bak}
 3
 4vim /etc/my.cnf
 5
 6[mysqld_multi]
 7mysqld = /usr/local/mysql/bin/mysqld_safe
 8mysqladmin = /usr/local/mysql/bin/mysqladmin
 9user = root
10
11[mysqld1]
12datadir = /mysqlmul/mysqld1
13port = 3306
14log-error = /mysqlmul/mysqld1/mysqld1.err
15pid-file = /mysqlmul/mysqld1/mysqld1.pid
16socket = /mysqlmul/mysqld1/mysqld1.sock
17
18[mysqld2]
19datadir = /mysqlmul/mysqld2
20port = 3307
21log-error = /mysqlmul/mysqld2/mysqld2.err
22pid-file = /mysqlmul/mysqld2/mysqld2.pid
23socket = /mysqlmul/mysqld2/mysqld2.sock

创建工作目录

1mkdir -p /mysqlmul/mysqld1
2mkdir -p /mysqlmul/mysqld2

将mysql添加到环境变量

1vim /etc/profile
2
3export PATH=/usr/local/mysql/bin:$PATH
4
5##生效
6source /etc/profile

新建MySQL用户

1useradd -M -s /sbin/nologin mysql

启动第一台

1mysqld_multi start 1

image-20240420161212272

接下来 拿着这个生成的密码登录mysql:

1 mysql -uroot -p'gFIA/htj*7ho' -S /mysqlmul/mysqld1/mysqld1.sock

在修改当前的用户密码 就可以:

1alter user 'root'@'localhost' identified by 'xyy520';
2flush privileges;

image-20240420161406856

启动第二台

1mysqld_multi start 2

image-20240420161440774

同样,修改密码即可:

1mysql -uroot -p'J%oRIn&8sdpX' -S /mysqlmul/mysqld2/mysqld2.sock
2
3
4alter user 'root'@'localhost' identified by 'xyy520';
5flush privileges;

image-20240420161406856

验证

接下来验证 可以看到3306,3307 端口都在listen 实验成功:

image-20240420161719808

再测试

  • 关闭mysql实例
1[root@vm-template ~]#mysqld_multi stop 1
2[root@vm-template ~]#mysqld_multi stop 2
3[root@vm-template ~]#mysqld_multi stop 3

image-20240420162425284

这个方法无法停止mysql实例哦……,只能使用mysqladmin来停止实例了……😒

  • 业务开机自启脚本😒

  • 且这些实例都是以root身份运行的……

image-20240420161719808

以上3个问题后续再看吧,本次到此结束。😂

扩展

在原基础上添加一个或多个实例

 1 1,首先编辑/etc/my.cnf文件,添加新的实列配置就可以,配置如下
 2 vim /etc/my.cnf
 3 
 4 [mysqld_multi]
 5mysqld = /usr/local/mysql/bin/mysqld_safe
 6mysqladmin = /usr/local/mysql/bin/mysqladmin
 7user = root
 8
 9[mysqld1]   
10datadir = /mysqlmul/mysqld1
11port = 3306 
12log-error = /mysqlmul/mysqld1/mysqld1.err
13pid-file = /mysqlmul/mysqld1/mysqld1.pid
14socket = /mysqlmul/mysqld1/mysqld1.sock
15              
16[mysqld2] 
17datadir = /mysqlmul/mysqld2
18port = 3307 
19log-error = /mysqlmul/mysqld2/mysqld2.err
20pid-file = /mysqlmul/mysqld2/mysqld2.pid
21socket = /mysqlmul/mysqld2/mysqld2.sock
22
23[mysqld3] 
24datadir = /mysqlmul/mysqld3
25port = 3308 
26log-error = /mysqlmul/mysqld3/mysqld3.err
27pid-file = /mysqlmul/mysqld3/mysqld3.pid
28socket = /mysqlmul/mysqld3/mysqld3.sock
29
30##创建目录
31mkdir -p /mysqlmul/mysqld3
32
332,再重新按照以下命令启动就可以 密码配置同上面的配置就可以
34mysqld_multi start  3
35
36mysql -uroot -p'tz?jL>ul3x%%' -S /mysqlmul/mysqld3/mysqld3.sock
37
38
39alter user 'root'@'localhost' identified by 'xyy520';
40flush privileges;

验证 可以看见由两台实例变为三台实例:

image-20240420162056943

FAQ

参考文档

感谢这位博主的详细文档哦:😘

https://blog.csdn.net/m0_56796630/article/details/132433854

image-20240420160137662

其它

以下方法,自己测试一直有问题,这里仅仅做记录:

  • 实战案例:CentOS 7 实现MySQL的多实例

image-20240420163439785

 1yum install mariadb-server
 2Systemctl start mariadb
 3
 4mkdir  -pv /mysql/{3306,3307,3308}/{data,etc,socket,log,bin,pid} 
 5chown  -R mysql.mysql /mysql
 6
 7mysql_install_db  --datadir=/mysql/3306/data --user=mysql
 8mysql_install_db  --datadir=/mysql/3307/data --user=mysql
 9mysql_install_db  --datadir=/mysql/3308/data --user=mysql
10
11cp /etc/my.cnf /mysql/3306/etc/
12vim /mysql/3306/etc/my.cnf
13[mysqld]
14#加此行,如果port是3306可省略此行
15port=3306  
16datadir=/mysql/3306/data/
17socket=/mysql/3306/socket/mysql.sock
18[mysqld_safe]
19log-error=/mysql/3306/log/mariadb.log
20pid-file=/mysql/3306/pid/mariadb.pid
21#重复上面步骤设置3307,3308
22
23
24vim /mysql/3306/bin/mysqld 
25#!/bin/bash
26port=3306
27mysql_user="root"
28mysql_pwd="magedu"
29cmd_path="/usr/bin"
30mysql_basedir="/mysql"
31mysql_sock="${mysql_basedir}/${port}/socket/mysql.sock"
32function_start_mysql()
33{
34    if [ ! -e "$mysql_sock" ];then
35     printf "Starting MySQL...\n"
36      ${cmd_path}/mysqld_safe --defaultsfile=${mysql_basedir}/${port}/etc/my.cnf &> /dev/null &
37    else
38     printf "MySQL is running...\n"
39      exit
40    fi
41}
42function_stop_mysql()
43{
44    if [ ! -e "$mysql_sock" ];then
45       printf "MySQL is stopped...\n"
46       exit
47    else
48       printf "Stoping MySQL...\n"
49       ${cmd_path}/mysqladmin -u ${mysql_user} -p${mysql_pwd} -S ${mysql_sock}
50shutdown
51   fi
52}
53function_restart_mysql()
54{
55   printf "Restarting MySQL...\n"
56   function_stop_mysql
57    sleep 2
58   function_start_mysql
59}
60case $1 in
61start)
62   function_start_mysql
63;;
64stop)
65   function_stop_mysql
66;;
67restart)
68   function_restart_mysql
69;;
70*)
71   printf "Usage: ${mysql_basedir}/${port}/bin/mysqld {start|stop|restart}\n"
72esac
73#重复上述过程,分别建立3307,3308的启动脚本     
74     
75     
76     
77/mysql/3306/bin/mysqld  start
78/mysql/3307/bin/mysqld  start
79/mysql/3308/bin/mysqld  start
80
81
82/mysql/3306/bin/mysqld  start
83mysql -uroot -S /mysql/3306/socket/mysql.sock
84mariadb>show variables like ‘port’  #确认连接的端口
85
86mysqladmin -uroot -S /mysql/3306/socket/mysql.sock password 'magedu'  #加上新口令
87#或者登录mysql,执行下面也可以
88Mariadb>update mysql.user set password=password(“centos”) where user=’root’;
89Mariadb>flush privileges;
90#重复步骤,分别修改别外两个实例3307,3308对应root口令
91
92
93mysql -uroot -S /mysql/3306/socket/mysql.sock –p #提示输入口令才能登录

关于我

我的博客主旨:

  • 排版美观,语言精炼;
  • 文档即手册,步骤明细,拒绝埋坑,提供源码;
  • 本人实战文档都是亲测成功的,各位小伙伴在实际操作过程中如有什么疑问,可随时联系本人帮您解决问题,让我们一起进步!

🍀 微信二维码

x2675263825 (舍得), qq:2675263825。

image-20230107215114763

🍀 微信公众号

《云原生架构师实战》

image-20230107215126971

🍀 个人博客站点

https://onedayxyy.cn/

🍀 语雀

https://www.yuque.com/xyy-onlyone

🍀 csdn

https://blog.csdn.net/weixin_39246554?spm=1010.2135.3001.5421

image-20230107215149885

🍀 知乎

https://www.zhihu.com/people/foryouone

image-20230107215203185

最后

好了,关于本次就到这里了,感谢大家阅读,最后祝大家生活快乐,每天都过的有意义哦,我们下期见!

推荐使用微信支付
微信支付二维码
推荐使用支付宝
支付宝二维码
最新文章

文档导航