前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL 知识:迁移数据目录到其他路径

MySQL 知识:迁移数据目录到其他路径

原创
作者头像
用户10449202
发布2023-05-05 21:56:05
6100
发布2023-05-05 21:56:05
举报
文章被收录于专栏:Centos 操作手册Centos 操作手册

一、系统环境

操作系统:Centos 7

已安装环境:MySQL 8.0.26

二、开始操作

2.1 关闭SELinux

为了提高 Linux 系统的安全性,在 Linux 上通常会使用 SELinux 或 AppArmor 实现强制访问控制(Mandatory Access Control MAC)。对于 MySQL 数据库的强制访问控制策略通常是激活的,如果用户采用默认的配置,并不会感到强制访问控制策略对 MySQL 数据库的影响,一旦用户修改了 MySQL 数据库的默认配置,例如默认的数据目录或监听端口,MySQL 数据库的活动就会被 SELinux 或 AppArmor 阻止,导致数据库无法启动。

因此,为了此次操作顺利执行,我们需要把SELinux 关了。

代码语言:shell
复制
setenforce 0
image.png
image.png

2.2 修改MySQL 配置文件

修改配置文件前先进行备份,这是一个好习惯。

代码语言:shell
复制
cp /etc/my.cnf /etc/my.cnf_old
vi /etc/my.cnf
image.png
image.png

修改以下的配置信息:

代码语言:text
复制
datadir=/opt/mysql/mysql
socket=/opt/mysql/mysql/mysql.sock

log-error=/opt/mysql/log/mysqld.log
pid-file=/opt/mysql/run/mysqld/mysqld.pid

2.3 创建新的数据目录

根据上一步的配置文件,创建对应的目录:

代码语言:shell
复制
mkdir /opt/mysql
cp -ar /var/lib/mysql/ /opt/mysql/
mkdir /opt/mysql/log/
touch /opt/mysql/log/mysqld.log
mkdir -p /opt/mysql/run/mysqld/

并修改其权限:

代码语言:shell
复制
chown -R mysql:mysql /opt/mysql/
chmod 777 /opt/mysql/

2.4 验证

重启 MySQL 数据库:

代码语言:shell
复制
service mysqld stop
service mysqld start

往数据库添加数据,查看是否切换到了新数据目录:

image.png
image.png

或者在SQL 执行界面执行以下语句:

代码语言:txt
复制
show VARIABLES like 'datadir'
image.png
image.png

三、小结

MySQL 迁移数据目录其实很简单,只需要有对应的目录路径,并修改对应的配置信息即可。

这是在Linux 系统里的操作,Windows 系统大体也是一样的。Windows 系统的简便性远超Linux 系统,甚至在Windows 系统你还可以直接复制某一个数据库文件到数据目录中(相当于复制了一个数据库到指定的数据库系统中),这也是能生效的。

我是陈冰安,在知识宇宙中摸爬滚打,分享个人所得,也期待志同道合。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、系统环境
  • 二、开始操作
    • 2.1 关闭SELinux
      • 2.2 修改MySQL 配置文件
        • 2.3 创建新的数据目录
          • 2.4 验证
          • 三、小结
          相关产品与服务
          云数据库 MySQL
          腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
          http://www.vxiaotou.com