在Ubuntu下 安装的MySQL默认配置下的数据库文件存储位置是在/var/lib/mysql,若是你没有为 /var挂载在一个足够大的分区中,那么/var将和根目录/同在一个分区共享使用可用空间。大多数用户一般会为/home挂载一个独立的分区,因此这篇 文章就是准备讲如何更改MySQL数据库存储位置到其它挂载位置的。mysql
MySQL数据库的文件结构是怎么样的呢,对于这样子建立的数据库命令:linux
CREATE DATABASE mysqldbsql
在默认的数据库存储位置下就会有个文件夹mysqldb。要操做数据库首先得中止数据库进程:数据库
$sudo /etc/init.d/mysql stopubuntu
本文以转移到/home/mysql这个位置为例,下面命令将原有数据库转移到新位置:安全
$sudo cp –R –p /var/lib/mysql /home/mysqlapp
编辑MySQL配置文件:编辑器
$gksu gedit /etc/mysql/my.cnfspa
在gedit中找到datadir这一行,将后面等于号以后的内容更改成/home/mysql而后保存退出。自Ubuntu 7.10开始,Ubuntu就开始使用一种安全软件叫作AppArmor,http://ubuntuone.cn这个安全软件会在你的文件系统中建立一个容许应用程序访问的区域(专业术语:应用程序访问控制)。若是不为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.
而且也没法启动MySQL服务,怎么办呢?
A:出现这个问题多是由于你使用了$sudo gedit或$gksu gedit这样子的命令来编辑usr.sbin.mysqld这个配置文件的,这两个图形界面文本编辑器会在相同位置生成一个 usr.sbin.mysqld~的文件,从而影响了AppArmor读取配置文件,出现这个问题先删除这个usr.sbin.mysqld~文件:
$sudo rm /etc/apparmor.d/usr.sbin.mysqld~
而后使用$sudo nano这个终端文本编辑器来编辑配置文件便可。