首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在不同硬盘上的Mysql Datadir

在不同硬盘上的Mysql Datadir
EN

Ask Ubuntu用户
提问于 2013-05-14 20:07:45
回答 1查看 7K关注 0票数 2

我目前正在运行Ubuntu13.04和MySQL 5.5。我一直在使用InnoDB,以及安装的默认位置。问题是我的主OS分区相当小(36 2TB ),我需要将数据库移动到我的2TB驱动器。

我正在尝试将MySQL数据从以下位置更改:

代码语言:javascript
复制
/var/lib/mysql

至:

代码语言:javascript
复制
/path/to/new/directory

但我遇到了各种各样的问题。MySQL拒绝启动,并且通常告诉我权限存在问题。不过,这对我来说没有任何意义。以下是我尝试过的工作:

我复制了文件:

代码语言:javascript
复制
cp -R /var/lib/mysql /path/to/new/directory

我编辑了/etc/mysql/my.cnf

代码语言:javascript
复制
datadir=/path/to/new/directory

更新了权限:

代码语言:javascript
复制
chown -R mysql:mysql /path/to/new/directory

更新后的主管:

代码语言:javascript
复制
/path/to/new/directory/ r,
/path/to/new/directory/** rwk,

我确保重置Apparmor:

代码语言:javascript
复制
service apparmor restart

但它还是会给我带来错误。我不知道我还需要做什么。有没有人在Ubuntu13.04、MySQL 5.5和InnoDB下有明确的指南来完成这项工作?

EN

回答 1

Ask Ubuntu用户

回答已采纳

发布于 2013-07-27 23:18:33

我也面临着同样的问题,但我找到了一个更好的替代方案,它确实对我有效,因为将用户更改为根目录在my.cnf文件中对我不起作用。

  1. 首先转到MySQL数据目录,并将所有ibdata文件和所有ib_logfile文件移动到临时文件夹(应该类似于mv /path_to_mysql_data_directory/ib* /path_to_temp_folder/)。
  2. 运行sudo service mysqld start,它应该会启动。
  3. 运行sudo service mysqld stop,它应该停止。
  4. 将您移动到临时文件夹的文件放到MySQL数据目录中(应该类似于mv /path_to_temp_folder/ib* /path_to_mysql_data_directory/)。
  5. 再次运行sudo service mysqld start,一切都应该启动。

这个解决方案确实对我有用,但我还没有在其他地方测试过。

票数 1
EN
页面原文内容由Ask Ubuntu提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://askubuntu.com/questions/295457

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档