如何更改在Ubuntu下的MySQL的默认数据库存储位置

 我来答
TA0492
推荐于2017-11-29 · 超过67用户采纳过TA的回答
知道答主
回答量:116
采纳率:0%
帮助的人:148万
展开全部
  CREATE DATABASE mysqldb
  在默认的数据库存储位置下就会有个文件夹mysqldb。要操作数据库首先得停止数据库进程:
  $sudo /etc/init.d/mysql stop
本文以转移到/home/mysql这个位置为例,下面命令将原有数据库转移到新位置:
  $sudo cp –R –p /var/lib/mysql /home/mysql
  编辑MySQL配置文件:
  $gksu gedit /etc/mysql/my.cnf
  在 gedit中找到datadir这一行,将后面等于号之后的内容更改为/home/mysql然后保存退出。自Ubuntu 7.10开始,
  Ubuntu就开始使用一种安全软件叫做AppArmor,这个安全软件会在你的文件系统中创建一个允许应用程序访问的区域(专业术语:应 用程序访问控制)。如果不为MySQL修改AppArmor配置文件,永远也无法为新设置的数据库存储位置启动
  数据库服务。配置AppArmor:
  $sudo nano /etc/apparmor.d/usr.sbin.mysqld
  在gedit中找到/var/lib/mysql/这两行,注释掉这两行,在这两行前分别添加一个符号#即可注释,在这两行之前或
  之后加上下面内容:
  /home/mysql/ r, 
  /home/mysql/** rwk,
  保存后退出,执行命令:
  $sudo /etc/init.d/apparmor reload
  返回Reloading AppArmor profiles : done.即可以重启MySQL服务:
  $sudo /etc/init.d/mysql start
  至此MySQL数据库存储位置就更改完毕了。  FAQ:
  Q:当我运行$sudo /etc/init.d/apparmor reload却返回信息
  Skipping profile /etc/apparmor.d/usr.sbin.mysqld~ 
  : Warning.
gedit这样子的命令来编辑usr.sbin.mysqld这个配置文件的,这两个图形界面文本编辑器会在相同位置生成一个
usr.sbin.mysqld~的文件,从而影响了AppArmor读取配置文件,出现这个问题先删除这个usr.sbin.mysqld~文件:
  然后使用$sudo nano这个终端文本编辑器来编辑配置文件即可。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式