MySQL 知识:迁移数据目录到其他路径

一、系统环境

操作系统:Centos 7
已安装环境:MySQL 8.0.26

二、开始操作

2.1 关闭SELinux

为了提高 Linux 系统的安全性,在 Linux 上通常会使用 SELinux 或 AppArmor 实现强制访问控制(Mandatory Access Control MAC)。对于 MySQL 数据库的强制访问控制策略通常是激活的,如果用户采用默认的配置,并不会感到强制访问控制策略对 MySQL 数据库的影响,一旦用户修改了 MySQL 数据库的默认配置,例如默认的数据目录或监听端口,MySQL 数据库的活动就会被 SELinux 或 AppArmor 阻止,导致数据库无法启动。

因此,为了此次操作顺利执行,我们需要把SELinux 关了。

setenforce 0

image.png

2.2 修改MySQL 配置文件

修改配置文件前先进行备份,这是一个好习惯。

cp /etc/my.cnf /etc/my.cnf_old
vi /etc/my.cnf

image.png

修改以下的配置信息:

datadir=/opt/mysql/mysql
socket=/opt/mysql/mysql/mysql.sock

log-error=/opt/mysql/log/mysqld.log
pid-file=/opt/mysql/run/mysqld/mysqld.pid

2.3 创建新的数据目录

根据上一步的配置文件,创建对应的目录:

mkdir /opt/mysql
cp -ar /var/lib/mysql/ /opt/mysql/
mkdir /opt/mysql/log/
touch /opt/mysql/log/mysqld.log
mkdir -p /opt/mysql/run/mysqld/

并修改其权限:

chown -R mysql:mysql /opt/mysql/
chmod 777 /opt/mysql/

2.4 验证

重启 MySQL 数据库:

service mysqld stop
service mysqld start

往数据库添加数据,查看是否切换到了新数据目录:

image.png

或者在SQL 执行界面执行以下语句:

show VARIABLES like 'datadir'

image.png

三、小结

MySQL 迁移数据目录其实很简单,只需要有对应的目录路径,并修改对应的配置信息即可。
这是在Linux 系统里的操作,Windows 系统大体也是一样的。Windows 系统的简便性远超Linux 系统,甚至在Windows 系统你还可以直接复制某一个数据库文件到数据目录中(相当于复制了一个数据库到指定的数据库系统中),这也是能生效的。

我是陈冰安,在知识宇宙中摸爬滚打,分享个人所得,也期待志同道合。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

暗星涌动

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值