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

yumo66610个月前 (03-28)技术文章102

描述:

(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. 迁移完成

测试数据库运行是否正常

相关文章

数据库迁移有什么技巧?|分享强大的database迁移和同步工具

概述DBConvert Studio 是一款强大的跨数据库迁移和同步软件,可在不同数据库格式之间转换数据库结构和数据。它将成熟、稳定、久经考验的 DBConvert 和 DBSync 核心与改进的现代...

从SSH输入命令备份/还原恢复MySQL数据库教程

有时候你需要把你的网站从一个服务器迁移到另一个服务器,在迁移网站的同时,你也需要移动网站的数据库。不过一些网站可能有GB级别大小的数据库(2GB或更大),如果通过PHPMyAdmin导出或导入非常难。...

Mysql和Hive之间通过Sqoop进行数据同步

文章回顾理论大数据框架原理简介大数据发展历程及技术选型实践搭建大数据运行环境之一搭建大数据运行环境之二本地MAC环境配置CPU数和内存大小查看CPU数sysctl machdep.cpu # 核数为...