如何在 Ubuntu 16.04 上将 MySQL 数据目录更改为另一个位置
来到golang学习网的大家,相信都是编程学习爱好者,希望在这里学习数据库相关编程知识。下面本篇文章就来带大家聊聊《如何在 Ubuntu 16.04 上将 MySQL 数据目录更改为另一个位置》,介绍一下,希望对大家的知识积累有所帮助,助力实战开发!
在本文中,我们将学习如何更改MySQL数据目录或将MySQL数据库数据重新定位到新位置,这种情况可能会在数据库增长非常快时使用,或者出于某些安全原因我们想要移动将数据目录复制到新位置。
先决条件
- 一台 Ubuntu 计算机,且非 root 用户具有 Sudo 权限。
- MySQL已安装并正在运行。
- 我们想要将数据库数据位置移动到的新卷或位置,新位置将是/mnt/data_vol/MySQL,因为data_vol是连接到计算机的新卷
更改 MySQL 数据文件夹位置
在继续之前,我们首先找到数据目录的当前位置
$ mysql –u root –p Output: Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 472 Server version: 5.6.30-0ubuntu0.14.04.1 (Ubuntu) Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql>
当提示输入 MySQL 的 root 密码时,请输入密码。运行以下命令即可了解MySQL当前的工作数据目录。
Mysql> select @@datadir; Output: +-----------------+ | @@datadir | +-----------------+ | /var/lib/mysql/ | +-----------------+ 1 row in set (0.00 sec)
如输出所示,MySQL 数据库使用 /var/lib/MySQL 作为默认文件夹作为数据目录。在我们修改任何内容之前,我们将检查数据的完整性,我们将停止 MySQL 并检查状态
$ sudo systemctl stop mysql
因为 systemctl 不会显示 services 命令的任何内容
$ sudo systemctl status mysql Output: 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/ OutPut: sending incremental file list 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.frmmysql/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 sent 199,384,083 bytes received 6,858 bytes 132,927,294.00 bytes/sec total size is 199,307,568 speedup is 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 Output: [mysqld_safe] socket = /var/run/mysqld/mysqld.sock nice = 0 [mysqld] # # * Basic Settings # 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 Output: # ------------------------------------------------------------------ # # Copyright (C) 2010 Canonical Ltd. # # This program is free software; you can redistribute it and/or # modify it under the terms of version 2 of the GNU General Public # License published by the Free Software Foundation. # # ------------------------------------------------------------------ # Alias rules can be used to rewrite paths and are done after variable # resolution. For example, if '/usr' is on removable media: # alias /usr/ -> /mnt/usr/, # # Or if mysql databases are stored in /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 Output: mysql.service - MySQL Community Server Loaded: loaded (/lib/systemd/system/mysql.service; enabled; vendor preset: enabled) Active: active (running) since Mon 2016-09-12 14:17:27 IST; 23s ago Process: 18481 ExecStartPost=/usr/share/mysql/mysql-systemd-start post (code=exited, status=0/SUCC Process: 18477 ExecStartPre=/usr/share/mysql/mysql-systemd-start pre (code=exited, status=0/SUCCES Main PID: 18480 (mysqld) Tasks: 28 (limit: 512) Memory: 137.3M CPU: 329ms CGroup: /system.slice/mysql.service └─18480 /usr/sbin/mysqld Sep 12 14:17:26 ubuntu-16 systemd[1]: Starting MySQL Community Server... Sep 12 14:17:27 ubuntu-16 systemd[1]: Started MySQL Community Server.
为了确保新的数据目录已更改,我们将运行以下命令
$ mysql -uroot -p Output: Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 3 Server version: 5.7.13-0ubuntu0.16.04.2 (Ubuntu) Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> select @@datadir +----------------------+ | @@datadir | +----------------------+ | /mnt/data_vol/mysql/ | +-----------------+ 1 row in set (0.00 sec) mysql>
一旦我们确认数据目录发生更改,我们将删除默认的数据目录,该目录位于/var/lib/mysql_backup,下面是删除旧数据库目录的命令。
$ sudo rm –rf /var/lib/mysql_backup
在上面的配置和步骤中,我们学会了将 MySQL 数据目录重新定位到新位置,这将有助于我们保护或将更多数据存储到不同的位置。
到这里,我们也就讲完了《如何在 Ubuntu 16.04 上将 MySQL 数据目录更改为另一个位置》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

- 上一篇
- MySQL 的文档编写者和翻译者

- 下一篇
- 允许优化和修复的最低 MySQL 用户权限是多少?
-
- 数据库 · MySQL | 1小时前 |
- 主外键关系详解:MySQL主键外键关联全解析
- 360浏览 收藏
-
- 数据库 · MySQL | 1小时前 |
- MySQL联合索引怎么创建?使用规则详解
- 431浏览 收藏
-
- 数据库 · MySQL | 1小时前 |
- MySQL创建带主键表的教程
- 201浏览 收藏
-
- 数据库 · MySQL | 3小时前 |
- MySQL入门命令详解新手必学操作指南
- 216浏览 收藏
-
- 数据库 · MySQL | 7小时前 |
- MySQL建表语法详解及示例
- 277浏览 收藏
-
- 数据库 · MySQL | 7小时前 |
- MySQL存储过程编写教程及优势解析
- 396浏览 收藏
-
- 数据库 · MySQL | 8小时前 |
- MySQL缓存优化技巧与设置方法
- 243浏览 收藏
-
- 数据库 · MySQL | 9小时前 |
- MySQL命令行建表完整步骤详解
- 250浏览 收藏
-
- 数据库 · MySQL | 9小时前 |
- MySQL索引优化与性能提升技巧
- 210浏览 收藏
-
- 数据库 · MySQL | 15小时前 |
- MySQL设置外键的建表教程
- 208浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL读写分离方案与中间件解析
- 413浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- 主键与唯一键区别,如何选主键?
- 367浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 511次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 498次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 千音漫语
- 千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
- 105次使用
-
- MiniWork
- MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
- 98次使用
-
- NoCode
- NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
- 118次使用
-
- 达医智影
- 达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
- 109次使用
-
- 智慧芽Eureka
- 智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
- 114次使用
-
- MySQL主从切换的超详细步骤
- 2023-01-01 501浏览
-
- Mysql-普通索引的 change buffer
- 2023-01-25 501浏览
-
- MySQL高级进阶sql语句总结大全
- 2022-12-31 501浏览
-
- Mysql报错:message from server: * is blocked because of many
- 2023-02-24 501浏览
-
- 腾讯云大佬亲码“redis深度笔记”,不讲一句废话,全是精华
- 2023-02-22 501浏览