Linux centos 变更MySQL数据存储路径

Linux centos 变更MySQL数据存储路径

登录mysql,查看数据存储路径

bash 复制代码
mysql -u root -p
bash 复制代码
show global variables like "%datadir%";

创建新目录

查看磁盘空间

bash 复制代码
df -h

选取最大磁盘,此处以/data目录为例,创建mysql数据存储的新目录:new_mysql_data

bash 复制代码
cd /data
bash 复制代码
mkdir new_mysql_data
bash 复制代码
cd new_mysql_data
bash 复制代码
pwd

准备迁移数据

停止mysql运行

bash 复制代码
systemctl stop mysql

复制原存储数据到新存储目录(如果原库数据较大,此过程执行较长,请耐心等待完成)

bash 复制代码
cp -a -r /app/mysql/data/* /data/new_mysql_data

mysql授权

bash 复制代码
chown -R mysql:mysql /data/new_mysql_data

修改MySQL配置文件

bash 复制代码
vi /etc/my.cnf

按键盘i键进入编辑状态,注释datadir 原路径配置,配置新路径:

bash 复制代码
datadir = /data/new_mysql_data

注:如果MySQL配置文件中涉及原数据目录指向的,均要修改为新目录,最好使用notepad++打开配置文件,全局搜索一下原数据目录/app/mysql/data有哪些涉及,比如

bash 复制代码
# datadir = /app/mysql/data
datadir = /data/new_mysql_data
# log-error=/app/mysql/data/master.err
log-error=/data/new_mysql_data/master.err
# pid-file=/app/mysql/data/master.pid
pid-file=/data/new_mysql_data/master.pid

按键盘esc键,输入:eq!保存并退出编辑

检查是否配置成功

启动mysql,登录数据库,再次查看数据路径

bash 复制代码
systemctl start mysql

创建测试数据库,进入目录,发现数据已在新目录成功创建,说明迁移全部成功完成

bash 复制代码
CREATE DATABASE database_temp;

新开连接窗口或者退出mysql,前往目录,无异常则说明配置成功

bash 复制代码
cd /data/new_mysql_data/database_temp/

验证完成,删除测试数据库

bash 复制代码
DROP DATABASE database_temp;

退出数据库

bash 复制代码
quit;

重启数据库,再次检查无误,则可以删掉原数据目录的占用

bash 复制代码
systemctl restart mysql

至此完成;

相关推荐
成为大佬先秃头38 分钟前
数据库连接池:Druid
数据库·mysql·druid
我爱学习好爱好爱1 小时前
Ansible 常用模块详解:lineinfile、replace、get_url实战
linux·python·ansible
吴声子夜歌2 小时前
TypeScript——基础类型(三)
java·linux·typescript
DA02213 小时前
系统移植-STM32MP1启动详解(BootROM)
linux·bsp·系统移植
春日见3 小时前
自驾算法的日常工作?如何提升模型性能?
linux·人工智能·机器学习·计算机视觉·自动驾驶
李彦亮老师(本人)3 小时前
【Linux系统】Rocky Linux 9.7操作系统简介
linux·运维·服务器·docker·kubernetes
minji...3 小时前
Linux 进程信号(二)信号的保存,sigset_t,sigprocmask,sigpending
linux·运维·服务器·网络·数据结构·c++·算法
A.A呐3 小时前
【Linux第二十章】socket
linux
何中应3 小时前
Grafana如何重置密码
linux·运维·服务器·grafana
charlie1145141914 小时前
2026年正点原子开发板移植方案——从0开始的Rootfs之路(3)inittab 与 init 系统:Linux 启动的“第一号进程“全解析
linux·驱动开发·学习·嵌入式开发·嵌入式linux