在Linux系统上更改默认MySQL数据目录的全步骤

 更新时间:2025年09月24日 08:58:07   作者:鸠摩智首席音效师  
MySQL 是一个广泛使用的开源关系数据库管理系统(RDBMS),为无数的 web 应用程序和服务提供支持,在本指南中,我们将引导您完成在 Linux 系统上更改默认 MySQL 数据目录的过程,确保以最小的停机时间顺利过渡,需要的朋友可以参考下

引言

MySQL 是一个广泛使用的开源关系数据库管理系统(RDBMS),为无数的 web 应用程序和服务提供支持。默认情况下,MySQL 将其数据存储在预定义的目录中,这可能并不总是适合您的需求。您可能希望将数据目录移动到另一个位置以获得更好的性能和安全性,或者利用单独的磁盘或分区。

在本指南中,我们将引导您完成在 Linux 系统上更改默认 MySQL 数据目录的过程,确保以最小的停机时间顺利过渡。

Step 1: 准备新的数据目录

第一步是创建一个新目录,用于存储 MySQL 数据,确保新位置有足够的存储空间以满足当前和未来的数据要求,用您所需的路径替换 /new/mysql/data 路径。

sudo mkdir -p /new/mysql/data

接下来,设置新目录的所有权和权限,以匹配默认 MySQL 数据目录的所有权和权限。

sudo chown -R mysql:mysql /new/mysql/data 
sudo chmod 750 /new/mysql/data

Step 2: 停止 MySQL 服务

在更改 MySQL 配置之前,必须先停止 MySQL 服务,以避免数据损坏或丢失。

sudo systemctl stop mysqld

Step 3: 将现有数据复制到新目录

MySQL 服务停止后,可以安全地将现有数据复制到新目录中。需要保留文件的权限和所有权。

sudo rsync -av /var/lib/mysql/* /new/mysql/data

如果原有数据目录有所不同,则将 /var/lib/mysql 替换为当前的 MySQL 数据目录路径。

Step 4: 更新 MySQL 配置

要通知 MySQL 新数据目录,您必须更新配置文件,打开 MySQL 配置文件。

sudo nano /etc/my.cnf

更新 datadir 和 socket 选项以指向新目录

[mysqld]
datadir=/new/mysql/data
socket=/new/mysql/data/mysql.sock

如果这些选项不存在,将它们添加到 [mysqld] 部分,保存并关闭配置文件。

Step 5: 更新 systemd 配置 (可选)

如果您的系统使用 systemd 来管理 MySQL 服务,则可能需要更新 systemd 配置以反映新数据目录。打开

MySQL systemd 服务文件,通常位于 /usr/lib/systemd/system/mysqld.service

/lib/systemd/system/mysql.service

sudo nano /usr/lib/systemd/system/mysqld.service

找到 ExecStart 行并添加 --datadir--socket 选项

ExecStart=/usr/sbin/mysqld --datadir=/new/mysql/data --socket=/new/mysql/data/mysql.sock

保存并关闭该文件,重新加载 systemd 配置。

sudo systemctl daemon-reload

Step 6: 更新 MySQL 客户端配置

为了确保 MySQL 客户端可以使用新的 socket 文件,需要更新客户端配置。

sudo nano /etc/my.cnf

找到 [client] 部分并更 socket 选项以指向新目录

[client]
socket=/new/mysql/data/mysql.sock

如果 socket 选项不存在,将其添加到 [client] 部分。保存并关闭配置文件。

Step 7: 重启 MySQL 服务

重启 MySQL 服务,使更改生效。

sudo systemctl start mysqld

Step 8: 验证更改

查看 mysql 服务状态

sudo systemctl status mysqld

此外,您可以使用客户端连接到 MySQL 服务器,并验证是否正在使用新的数据目录

mysql -u root -p -e 'SHOW VARIABLES WHERE Variable_Name = "datadir";'

Step 9: 删除或备份旧数据目录 (可选)

一旦确认 MySQL 正在使用新的数据目录并且一切正常,可以执行以下操作:

删除旧数据目录

sudo rm -rf /var/lib/mysql

或者,创建数据备份

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

到此这篇关于在Linux系统上更改默认MySQL数据目录的全步骤的文章就介绍到这了,更多相关Linux更改默认MySQL目录内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Linux中Curl参数详解实践应用

    Linux中Curl参数详解实践应用

    在现代网络开发和运维工作中,curl 命令是一个不可或缺的工具,它是一个利用 URL 语法在命令行下工作的文件传输工具,支持多种协议,如 HTTP、HTTPS、FTP 等,本文给大家介绍了Linux中Curl参数详解实践应用,需要的朋友可以参考下
    2025-01-01
  • Vmware虚拟机中CentOS安装 CentOS安装Qt的教程图解

    Vmware虚拟机中CentOS安装 CentOS安装Qt的教程图解

    这篇文章主要介绍了Vmware虚拟机中CentOS安装,CentOS安装Qt的教程,本文图文并茂给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-10-10
  • Linux之软件包管理器yum详解

    Linux之软件包管理器yum详解

    文章介绍了现代类Unix操作系统中软件包管理和包存储库的工作原理,以及如何使用包管理器如yum来安装、更新和卸载软件,文章还介绍了如何配置yum源,更新系统软件包和查看已安装的软件
    2025-01-01
  • 类Linux环境安装jdk1.8及环境变量配置详解

    类Linux环境安装jdk1.8及环境变量配置详解

    如何在linux系统中安装jdk1.8?很多小伙伴都不知道在linux系统中怎么安装jdk,下面,小编就为大家介绍下在linux系统中安装jdk1.8方法。
    2019-09-09
  • Apache虚拟目录简单知识汇总

    Apache虚拟目录简单知识汇总

    本文给大家汇总介绍了Apache的虚拟目录的简单使用方法的知识,非常的简单实用,有需要的小伙伴可以参考下
    2018-08-08
  • 修改linux文件权限命令:chmod命令详解

    修改linux文件权限命令:chmod命令详解

    本篇文章主要介绍了修改linux文件权限命令:chmod,Linux系统中的每个文件和目录都有访问许可权限,用它来确定谁可以通过何种方式对文件和目录进行访问和操作。
    2016-12-12
  • CentOS7安装GUI界面及远程连接的实现

    CentOS7安装GUI界面及远程连接的实现

    这篇文章主要介绍了CentOS7安装GUI界面及远程连接的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • Kafka使用入门教程

    Kafka使用入门教程

    Kafka是一个分布式的、可分区的、可复制的消息系统。它提供了普通消息系统的功能,但具有自己独特的设计。这个独特的设计是什么样的呢
    2015-12-12
  • Apache Doris 中Compaction问题分析和典型案例分析

    Apache Doris 中Compaction问题分析和典型案例分析

    这篇文章主要介绍了Apache Doris 中Compaction问题分析和典型案例,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-08-08
  • Ubuntu配置静态IP的两种方法

    Ubuntu配置静态IP的两种方法

    在本教程中,您将了解有关 Ubuntu 静态 IP 地址配置的所有信息,我们将为读者Ubuntu配置静态IP的两种方法以及详细的配置过程,通过图文介绍的非常详细,需要的朋友可以参考下
    2024-10-10

最新评论