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

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

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这个终端文本编辑器来编辑配置文件即可。

默认安装吗?

如果是的话,应该是在/var/lib/mysql

表项就在对应的数据库database名称的文件夹下

如果不是你可以查看配置文件,找到它

/etc/rc.d/init.d/mysql

datadir项的值就是了

默认

datadir=/var/lib/mysql

可以修改你想要存放到的目录,就是修改mysql的配置文件/etc/rc.d/init.d/mysql的

datadir项

如果真的需要改再追问吧,你也没问这个,呵呵

很多时候,mysql的数据会非常大,数据默认放在/var/lib/mysql,由于/var所划分的

空间不够大,所以我们需要将mysql数据存放路径修改一下,放到大分区里面,以便

可以应付mysql数据增长。

www.2cto.com

1.设置新的存放路径

mkdir -p /data/mysql

2.复制原有数据

cp -R /var/lib/mysql/* /data/mysql

3.修改权限

chown -R mysql:mysql /data/mysql

www.2cto.com

4.修改配置文件

vim /etc/mysql/my.cnf

datadir         = /data/mysql

5.修改启动文件

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

#把

/var/lib/mysql r,

/var/lib/mysql/** rwk,

#改成

/data/mysql r,

/data/mysql/** rwk,

6.重启服务

重启apparmor

/etc/init.d/apparmor restart

/etc/init.d/mysql restart

完成


欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/sjk/6460010.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-03-22
下一篇2023-03-22

发表评论

登录后才能评论

评论列表(0条)

    保存