乐趣区

关于mysql: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

2.2 批改 MySQL 配置文件

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

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

批改以下的配置信息:

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

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

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

show VARIABLES like 'datadir'

三、小结

MySQL 迁徙数据目录其实很简略,只须要有对应的目录门路,并批改对应的配置信息即可。
这是在 Linux 零碎里的操作,Windows 零碎大体也是一样的。Windows 零碎的简便性远超 Linux 零碎,甚至在 Windows 零碎你还能够间接复制某一个数据库文件到数据目录中(相当于复制了一个数据库到指定的数据库系统中),这也是能失效的。

我是陈冰安,在常识宇宙中摸爬滚打,分享个人所得,也期待气味相投。

退出移动版