MySQL 如何将Ubuntu 16.04上数据目录更改为其他位置

MySQL 如何将Ubuntu 16.04上数据目录更改为其他位置

在本文中,我们将学习如何更改MySQL数据目录或将MySQL数据库数据重定位到新位置,当数据库增长非常快或出于某些安全原因时,我们希望将数据目录移动到新位置。

阅读更多:MySQL 教程

先决条件

  • 具有Sudo权限的非根用户的Ubuntu机器。
  • 已安装并运行MySQL
  • 处于新位置或容量的新卷,我们要移动数据库数据位置,新位置将为/mnt/data_vol/MySQL,其中data_vol是附加到机器或服务器的新卷。

更改MySQL数据文件夹位置

在我们进一步操作之前,我们将首先找到数据目录的当前位置。

$ mysql –u root –p
输出:
输入密码:
欢迎来到MySQL监视器。 命令以 ; 或 \g 结尾。
您的MySQL连接ID为472
服务器版本:5.6.30-0ubuntu0.14.04.1(Ubuntu)
版权所有(c)2000, 2016, Oracle及其附属公司。保留所有权利。
Oracle是Oracle Corporation和/或其
附属公司的注册商标。其他名称可能是其各自所有者的商标。
键入“help;”或“\h”获取帮助。 键入“\c”以清除当前输入语句。
mysql>

当提示MySQL的根密码时,请输入密码。 运行以下命令以了解MySQL当前的工作数据目录。

Mysql> select @@datadir;
输出:
+-----------------+
| @@datadir       |
+-----------------+
| /var/lib/mysql/ |
+-----------------+
共1行(0.00秒)

输出将显示MySQL数据库使用/var/lib/mysql作为默认文件夹作为数据目录。 在修改任何内容之前,我们将首先检查数据的完整性,我们将停止MySQL并检查状态。

$ sudo systemctl stop mysql

由于systemctl不会为服务命令显示任何内容。

$ sudo systemctl status mysql
输出:
mysql.service - MySQL Community Server
   Loaded: loaded (/lib/systemd/system/mysql.service; enabled; vendor preset: enabled)
   Active: inactive (dead) since Mon 2016-09-12 13:57:43 IST; 1s ago
   Process: 17669 ExecStartPost=/usr/share/mysql/mysql-systemd-start post (code=exited, status=0/SUCCESS)
   Process: 17668 ExecStart=/usr/sbin/mysqld (code=exited, status=0/SUCCESS)
   Process: 17664 ExecStartPre=/usr/share/mysql/mysql-systemd-start pre (code=exited, status=0/SUCCESS)
   Main PID: 17668 (code=exited, status=0/SUCCESS)
Sep 12 13:55:14 ubuntu-16 systemd[1]: Starting MySQL Community Server...
Sep 12 13:55:15 ubuntu-16 systemd[1]: Started MySQL Community Server.
Sep 12 13:57:40 ubuntu-16 systemd[1]: Stopping MySQL Community Server...
Sep 12 13:57:43 ubuntu-16 systemd[1]: Stopped MySQL Community Server。

一旦我们确认MySQL已停止,我们将将数据移动到新位置。 为了移动数据,我们将使用带-a选项的Rsync,该选项保留数据文件的权限和带-v的详细输出。

以下是将数据移动到新位置的完整命令:

$ rsync –av /var/lib/mysql /mnt/data_vol/
输出:
发送递增文件列表
mysql/
mysql/auto.cnf
mysql/debian-5.7.flag
mysql/ib_buffer_pool
mysql/ib_logfile0
mysql/ib_logfile1
mysql/ibdata1
mysql/mysql/
mysql/mysql/columns_priv.MYD
mysql/mysql/columns_priv.MYI
mysql/mysql/columns_priv.frm
mysql/mysql/db.MYD
mysql/mysql/db.MYI
mysql/mysql/db.frm
mysql/mysql/db.opt
...
mysql/sys/x@0024user_summary.frm
mysql/sys/x@0024user_summary_by_file_io.frm
mysql/sys/x@0024user_summary_by_file_io_type.frm
mysql/sys/x@0024user_summary_by_stages.frm
mysql/sys/x@0024user_summary_by_statement_latency.frm
mysql/sys/x@0024user_summary_by_statement_type.frm
mysql/sys/x@0024wait_classes_global_by_avg_latency.frm
mysql/sys/x@0024wait_classes_global_by_latency.frm
mysql/sys/x@0024waits_by_host_by_latency.frm
mysqlsys//x@0024waits_by_user_by_latency.frm
mysql/sys/x@0024waits_global_by_latency.frm
发送了 199,384,083 字节,收到了 6,858 字节 132,927,294.00 字节/秒
总大小为 199,307,568 速度为 1.00

移动数据文件夹到新位置后,成功完成rsync。由于安全原因,我们将保留数据文件夹,直到确认数据位于新位置后,我们将当前数据目录从 /var/lib/mysql 更名为 /var/lib/mysql_backup。以下是更改当前数据目录的命令。

以下是更改当前数据目录的命令 –

$ sudo mv /var/lib/mysql /var/lib/mysql_backup

现在,我们将更改默认数据目录,更改有很多方法,但我们将编辑位于 /etc/mysql/mysql.conf.d/mysqld.cnf 的mysqld.cnf文件。

编辑mysqld.cnf的命令如下

$ sudo vi /etc/mysql/mysql.conf.d/mysqld.cnf
输出:
[mysqld_safe]
socket    = /var/run/mysqld/mysqld.sock
nice      = 0
[mysqld]
#
# * 基本设置
#
user             = mysql
pid-file         = /var/run/mysqld/mysqld.pid
socket           = /var/run/mysqld/mysqld.sock
port             = 3306
basedir          = /usr
datadir          = /mnt/data_vol/mysql/
tmpdir           = /tmp
lc-messages-dir = /usr/share/mysql
skip-external-locking

更改Apparmor别名设置

还需编辑 /etc/apparmor.d/tunables/alias

在文件底部,我们需要在别名规则中添加以下行。

$ sudo vi /etc/apparmor.d/tunables/alias
输出:
# ------------------------------------------------------------------
#
# 版权所有 (C) 2010 Canonical Ltd.
#
# 本程序是自由软件;您可以重新分发它和/或
# 根据自由软件基金会发布的GNU通用公共许可证第2版修改它。
#
# ------------------------------------------------------------------
# 别名规则可用于重写路径,并在变量解析后完成。例如,如果 '/usr'在可移动介质上:
# alias /usr/ -> /mnt/usr/,
#
# 或者如果mysql数据库存储在 /home中:
# alias /var/lib/mysql/ -> /home/mysql/,
alias /var/lib/mysql/ -> /mnt/data_vol/mysql

编辑文件后,我们需要重新启动apparmor。

以下是重启apparmor的命令。

由于我们更改了默认数据目录,我们需要运行以下命令,该命令将创建最小的目录文件夹结构以通过脚本环境。

$ sudo mkdir /var/lib/mysql/mysql –p

现在,我们将重新启动mysql服务。

$ sudo systemctl start mysql

现在,我们将使用以下命令检查MySQL服务的状态:

$ sudo systemctl status mysql
输出:
mysql.service - MySQL社区服务器
    已加载:/lib/systemd/system/mysql.service; 已启用; 厂商预设:已启用
    活跃:自 2016-09-12 14:17:27 IST 以来运行中; 23s 前
    进程:18481 ExecStartPost=/usr/share/mysql/mysql-systemd-start post (状态=0/SUCC
    进程:18477 ExecStartPre=/usr/share/mysql/mysql-systemd-start pre (状态=0/SUCCES
    主进程:18480 (mysqld)
    任务数:28 (限制:512)
    内存:137.3M
    CPU:329ms
CGroup:/system.slice/mysql.service
       └─18480 /usr/sbin/mysqld
9月 12 14:17:26 ubuntu-16 systemd[1]: 正在启动 MySQL Community Server...
9月 12 14:17:27 ubuntu-16 systemd[1]: 已启动 MySQL Community Server。

为确保新数据目录已更改,我们将运行以下命令

$ mysql -uroot -p
输出:
输入密码:
欢迎使用 MySQL monitor。命令以分号或 \g 结尾。
您的 MySQL 连接 ID 是 3
服务器版本:5.7.13-0ubuntu0.16.04.2 (Ubuntu)
版权所有 (c) 2000, 2016, Oracle 及/或其附属公司。保留所有权利。
Oracle 是 Oracle Corporation 和/或其附属公司的注册商标。
其他名称可能是其各自所有者的商标。
键入“help;”或“\ h”获取帮助。键入"\ c"清除当前的输入语句。
mysql> select @@datadir
+----------------------+
| @@datadir            |
+----------------------+
| /mnt/data_vol/mysql/ |
+-----------------+
1 行记录,0.00 秒用时
mysql>

确认数据目录已更改后,我们将删除默认数据目录,即 /var/lib/mysql_backup,以下是删除旧数据库目录的命令。

$ sudo rm –rf /var/lib/mysql_backup

在上述配置和步骤中, 我们已经学会了将 MySQL 的数据目录重定位到新位置,这将帮助我们将更多数据安全地存储到不同的位置。

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程