Ubuntu 2004上迁移MySQL8.0的数据
1、停止MySQL服务
systemctl stop mysql
2、将MySQL的数据文件拷贝到迁移后的目录下
mv /var/lib/mysql /mysqldata/
3、将二进制日志也拷贝到对应的目录下
mv mysql-bin.* /mysqldata/binlog/
4、修改mysql-bin.index中的路径,否则仍然会去旧目录下查找二进制日志文件
%s#/var/log/mysql#/mysqldata/binlog/#g
5、修改MySQL的配置文件,修改其中数据目录和二进制存储路径
vim /etc/mysql/mysql.conf.d/mysqld.cnf
[mysqld]
datadir = /mysqldata/mysql
log_bin = /mysqldata/binlog/mysql-bin.log
6、修改 AppArmor 的配置文件 或停用AppArmor 服务
debian
系列发行版的操作系统中,存在一个和SELinux
功能类似的安全程序,叫作AppArmor,作用都是用于实现强制访问控制;
修改了MySQL数据库的默认配置,MySQL的活动会被阻止,导致MySQL没法启动,会一直提示没有权限。
7、修改MySQL的AppArmor配置方法:
(1)修改配置
root@node1:~# vim /etc/apparmor.d/usr.sbin.mysqld
/mysqldata/ r, # 只允许读取目录结构,不能在 /mysqldata 目录本身(根级)创建或删除文件
/mysqldata/** rwk, # 允许对目录下文件和子目录进行读写和锁定操作
(2)重新加载生效
sudo apparmor_parser -r /etc/apparmor.d/usr.sbin.mysqld
8、重新启动MySQL即可