mysql数据文件迁移(转)(亲测可用)

时间:2024-03-29 13:55:22

1、确定mysql数据库文件存放目录

一般默认是在/var/lib/mysql目录下。

先登录自己的mysql数据库,比如我用root账户登录,然后使用下面查询语句查询:

show variables like '%dir%';

得到数据库文件配置信息:

mysql数据文件迁移(转)(亲测可用)

 

可以看到其中datadir的值为/var/lib/mysql/即为当前数据库文件存放目录。

另外一个basedir参数表示mysql数据库的安装位置,迁移数据库文件位置不需要改动这个参数。

2、迁移数据库文件到新的目录下

先使用下面命令将mysql数据库服务停止:

sudo /etc/init.d/mysql stop

我新的数据盘挂载在/mnt/wintime/ 目录下,因此要将数据库迁移到/mnt/wintime/mysql/。

2.1 可以使用mv命令将原数据库目录文件移动到新的目录,好处是不会简单,不会修改原数据库文件的权限,以及用户和用户组归属:

sudo mv /var/lib/mysql /mnt/wintime/mysql/

2.2 也可以使用cp复制命令将原数据库目录文件复制到新的目录,好处是。。万一迁移失败,恢复工作相对简单一点,等确认迁移成功再来删掉原数据库目录文件也不迟。为了不影响复制过来数据库目录文件权限和用户用户组归属问题,使用cp命令时要加上-a参数:

sudo cp -a /var/lib/mysql /mnt/wintime/mysql/

注:由于/var/lib/mysql目录归属于mysql数据库创建的mysql用户和mysql用户组,所以迁移文件的时候需要使用root权限,命令要使用sudo

迁移成功后,可以看到/mnt/wintime/mysql/目录下已经将mysql数据库文件迁移过来了,并且目录文件的用户用户组归属还是mysql,没有变化:

3、修改配置文件

一共有三个配置文件需要修改:

3.1 my.cnf文件

mysql数据库会按顺序优先级从/etc/my.cnf、/etc/mysql/my.cnf、/usr/etc/my.cnf、~/.my.cnf四个位置找my.cnf配置文件,一旦找到就不再继续往下找。Ubuntu默认将my.cnf配置文件放在/etc/mysql/my.cnf位置,所以在/etc/my.cnf位置没有找到这个配置文件。

选择自己使用的文本编辑器编辑my.cnf配置文件,我用vim,所以sudo vim /etc/mysql/my.cnf。一样需要sudo,使用root权限编辑。将其中[mysqld]标签下的datadir属性值改为新数据库目录路径/mnt/wintime/mysql/mysql,如图:

 

 

mysql数据文件迁移(转)(亲测可用)

 

 

 

 

修改后保存并退出。

3.2 usr.bin.mysqld文件

由于Ubuntu使用了apparmor安全模块,就是类似于沙盒运行的一种机制,它可以限制软件在运行时的一些行为,比如对哪些目录和文件可以读写加锁等等。

由于修改了数据库文件路径,所以要修改mysql数据库的apparmor配置文件,在其中将新数据库文件目录和文件的读写及加锁权限添加上去,同时可以删除或者注释掉原先/var/lib/mysql数据库文件目录的权限。mysql数据库的apparmor配置文件路径在/etc/apparmor.d/usr.sbin.mysqld。使用下面命令编辑这个配置文件:

sudo vim /etc/apparmor.d/usr.sbin.mysqld

找到其中的

/var/lib/mysql/ r,

  /var/lib/mysql/** rwk,

两行权限声明,可以在前面加上#好注释掉。然后对照格式,加入新路径的权限声明:

如下所示

 

 

  /mnt/wintime/mysql/mysql/ r,

  /mnt/wintime/mysql/mysql/** rwk,

# /var/lib/mysql/ r,

# /var/lib/mysql/** rwk,

保存并关闭。

3.3 abstractions/mysql文件

由于usr.bin.mysqld文件中引用了abstractions/mysql文件,也就是会将abstractions/mysql文件中的权限声明导入进来。因此,也修改下这个文件:

sudo vim /etc/apparmor.d/abstractions/mysql

同样也是将新数据库文件路径中的socket文件权限添加进去,同时可以删除或者注释掉全路径中申请的权限,效果下所示:

 

  /mnt/wintime/mysql/mysql/mysql.sock  rw,

 #  /var/lib/mysql/mysql.sock rw,

   /{var/,}run/mysql/mysql.sock rw,

   /usr/share/{mysql,mysql-community-server,mariadb}/charsets/ r,

   /usr/share/{mysql,mysql-community-server,mariadb}/charsets/*.xml r,

保存后退出。

4、重启数据库

配置文件修改成功后就可以重启数据库,重启数据库之前需要先重新载入apparmor配置文件,使用下面命令重新载入:

sudo /etc/init.d/apparmor restart

重载成功就可以使用下面命令启动数据库:

sudo /etc/init.d/mysql start

5、权限问题

经过上诉步骤之后,你有可能数据库无法启动。忽略继续登录数据库出现下面关于sock的错误:

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)

查看数据库的启动错误日志,sudo vim /var/log/mysql/error.log,还能看到Table 'plugin' is read only这样的错误:

 

 

mysql数据文件迁移(转)(亲测可用)

 

出现这种情况的原因还是在于新数据库文件目录的权限。

mysql数据库启动的时候需要以mysql用户的身份执行,所以mysql用户需要具备能读写数据库文件目录的权限。虽然上面迁移数据库文件的时候无论是使用mv还是cp -a命令都没有更改mysql目录的用户和用户组,上面也看到了/mnt/data/mysql所属的用户和用户组都还是mysql。因此可以肯定mysql用户具备读写/mnt/data/mysql的权限,但是这并没有保证上级目录/mnt/data和上上级目录/mnt也具备让mysql用户读取的权限。如果mysql用户不具备上级目录/mnt/data和上上级目录/mnt的读取权限,mysql用户一样读写不了自己的/mnt/data/mysql目录,因此就会出现上面的问题。

可以过头来看看原本数据库文件目录/var/lib/mysql的结构:

 

mysql数据文件迁移(转)(亲测可用)

 

可以看出原本数据库文件目录/var/lib/mysql的上级目录/var/lib属于虽然属于root用户,但是它为同组用户和其它组用户都开放了’r'和‘x'权限,所以即使上级目录不属于mysql用户,mysql用户同样也能正常进入并访问到自己的数据库文件。

解决这个问题的方法说起来就是这么简单,只要保证mysql用户具备最终数据库文件目录的所有上级目录的'r'和‘x'权限就可以了。

例如,使用下面命令修改本文中/mnt/wintime/mysql的权限:

sudo chmod 755 /mnt/wintime/mysql

再上级目录/mnt是系统目录,归属于root用户,root用户默认的目录的权限都是755,所以不用修改。

权限修改后再次启动数据库sudo /etc/init.d/mysql start,应该就能成功启动了。

进入数据库,查看当前路径配置信息:

 

mysql数据文件迁移(转)(亲测可用)

 

 

数据库已经正常启动, 并且数据库文件路径也已经替换到/mnt/wintime/mysql目标路径,数据库文件迁移成功。

 

 

补充:以上这篇文章,照着做,基本大差不差。

如果不行,还要执行下面的这条语句,用来初始化某些设置。

 

 mysql_install_db --user=mysql --ldata=/mnt/wintime/mysql/mysql/ (这里要改成你的新目录,注意,前面user也要写mysql,不要写别的root什么的)

 

  

  我修改的时候,是把datadir迁移到了 /mnt/attachments/new_mysql_datadir/mysql这个文件夹下面。

然后socket就是 /mnt/attachments/new_mysql_datadir/mysql/mysql.sock。

然后我使用的时候,发现root下可以直接登记去,lenovo下要使用-h参数。  (登录mysql的账号都是root账号),最后发现是 /mnt/attachments/new_mysql_datadir/mysql这个文件的权限问题,chmod 777 /mnt/attachments/new_mysql_datadir/mysql 就好了。

扯了一上午,啥事都干不了。气死了。

 

 

 

 

 补充:

关于权限问题

 

 

[email protected]:/mnt/wintime/mysql# ls -al

总用量 12

drwxr-xr-x  3 mysql mysql 4096 12月 16 14:02 .

drwxrwxrwx  9 root  root  4096 12月 13 10:29 ..

drwxr-xr-x 11 mysql mysql 4096 12月 16 14:52 mysql

[email protected]:/mnt/wintime/mysql# 

 

mysql数据文件迁移(转)(亲测可用)