ubuntu mysql数据储存在哪里_如何更改在Ubuntu下的MySQL数据库存储位置?

本文介绍了如何在Ubuntu系统中更改MySQL数据库的默认存储位置。首先,停止MySQL服务,然后复制原有数据库到新位置(例如/home/mysql)。接着,编辑配置文件/etc/mysql/my.cnf,修改datadir指向新路径。由于AppArmor的存在,还需要更新其配置,允许MySQL访问新的数据库路径。完成这些步骤后,重新加载AppArmor配置并启动MySQL服务,数据库存储位置的变更就完成了。
摘要由CSDN通过智能技术生成

在默认的数据库存储位置下就会有个文件夹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。

并且也无法启动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这个终端文本编辑器来编辑配置文件即可。

全部

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值