记一次,mysql数据库迁移到新的磁盘(业务停止的场景下)

记一次,mysql数据库迁移到新的磁盘(业务停止的场景下)

技术教程gslnedu2025-03-19 14:07:316A+A-

描述:

(1) 主从数据库,主库(1台)+从库(1台)

(2) 将mysql数据库目录移动到新挂载的目录下/data2

(3) 在新挂载目录/data2/下创建log目录:作为mysql-bin日志文件存放目录

(4) 修改配置文件my.cnf中datadir和socket路径指向以及mysql-bin日志文件路径指向,指向新的目录

目录:

(1) mysql数据库原目录:/var/lib/mysql

(2) mysql数据库新挂载目录: /data2/mysql

(3) mysql数据库二进制日志文件目录: /data2/log

1. 主库db1导出mysql数据库全量数据做备份

mysqldump -u用户名 -p密码 -h127.0.0.1 -P3306 --socket=/var/lib/mysql/mysql.sock --single-transaction -B -R 数据库名 > /tmp/mysql_bak/数据库名_日期_01.sql

2.主库db1和从库db2分别停止mysql数据库服务

systemctl stop mysqld

#检查是否已停止mysql服务

ps -ef | grep mysqld

3. 主库db1和从库db2分别在新挂载目录/data2/下,创建mysql-bin日志文件存放log目录

cd /data2/

mkdir log

4. 主库db1和从库db2分别移动mysql目录到新挂载的目录/data2/下

cd /var/lib

#先备份

cp -r mysql mysql_bak_日期_01

#移动mysql目录到/data2/下面

mv mysql /data2/

#检查是否移动成功,进入目录查看是否有内容

cd /data2/mysql

#检查mysql目录的用户和用户组权限是否是mysql.mysql

5. 主库db1和从库db2分别复制mysql-bin.*日志文件到新挂载的目录/data2/log/下,修改log目录权限

cd /var/log

cp mysql-bin.* /data2/log

#进入目录执行查看内容,检查是否拷贝成功

cd /data2/log/

#修改log目录的权限

cd /data2/

chown -R mysql:mysql log

#查看权限是否修改成功

6. 主库db1和从库db2分别修改配置文件my.cnf中datadir和socket路径指向以及mysql-bin.*日志文件路径指向

#先备份

cd /etc

cp my.cnf my.cnf.bak_日期_01

#编辑配置

vi /etc/my.cnf

#修改datadir路径指向到新挂载目录
datadir=/data2/mysql
#修改mysql.sock的路径指向到新挂载目录下的mysql.sock文件
socket=/data2/mysql/mysql.sock
#修改mysql-bin日志文件的路径指向到新挂载目录
log-bin=/data2/log/mysql-bin
#添加配置
binlog-ignore-db=net_loan_db#按Esc键退出编辑模式,英文模式下输入的:wq,即可保存退出

7. 主库db1和从库db2分别启动mysql数据库服务

systemctl start mysqld

#查看mysql是否启动成功

ps -ef | grep mysqld

8. 从库db2查看主从复制状态

#从库db2数据库服务器

mysql -u pro -p

#查看主从状态

show slave status \G;

查看到这两个是yes,表示主从正常


9. 迁移完成

测试数据库运行是否正常

点击这里复制本文地址 以上内容由朽木教程网整理呈现,请务必在转载分享时注明本文地址!如对内容有疑问,请联系我们,谢谢!
qrcode

朽木教程网 © All Rights Reserved.  蜀ICP备2024111239号-8