要修改Linux系统上MySQL数据库的存放路径,您可以按照以下步骤进行操作:
1. 停止MySQL服务:
打开终端,并使用root或具有管理员权限的用户执行以下命令停止MySQL服务:
```
sudo service mysql stop
```
2. 复制数据库目录:
通过以下命令将当前的MySQL数据库目录复制到新的位置,例如将数据库目录从 `/var/lib/mysql` 复制到 `/new/path/mysql`:
```
sudo rsync -av /var/lib/mysql /new/path/
```
3. 更新MySQL配置文件:
使用文本编辑器(如vi或nano)打开MySQL的配置文件,通常位于 `/etc/mysql/my.cnf` 或 `/etc/mysql/mysql.conf.d/mysqld.cnf`:
```
sudo vi /etc/mysql/my.cnf
```
4. 修改数据库路径:
在配置文件中,找到名为 `[mysqld]` 的部分,在该部分下添加或修改以下行,将数据库路径设置为新的路径:
```
datadir = /new/path/mysql
```
5. 保存并关闭文件:
在编辑完配置文件后,保存并关闭它。
6. 修改文件权限:
使用以下命令修改新的数据库目录的权限,确保MySQL可以访问它:
```
sudo chown -R mysql:mysql /new/path/mysql
```
7. 启动MySQL服务:
使用以下命令启动MySQL服务:
```
sudo service mysql start
```
完成以上步骤后,MySQL数据库的存放路径应该已经修改成功。请确保在进行任何系统或数据库更改之前备份重要数据,以防止意外数据丢失。
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然后保存退出。
自Ubuntu7.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 返回ReloadingAppArmorprofiles:done.即可以重启MySQL服务: $sudo /etc/init.d/mysql start 至此MySQL数据库存储位置就更改完毕了。
FAQ: Q:当我运行$sudo/etc/init.d/apparmorreload却返回信息 Skipping profile /etc/apparmor.d/usr.sbin.mysqld~ : Warning. gedit这样子的命令来编辑usr.sbin.mysqld这个配置文件的,这两个图形界面文本编辑器会在相同位置生成一个 usr.sbin.mysqld~的文件,
从而影响了AppArmor读取配置文件,出现这个问题先删除这个usr.sbin.mysqld~文件: 然后使用$sudonano这个终端文本编辑器来编辑配置文件即可。