Linux服务器下Mysql的数据目录迁移

最近发现服务器的目录空间快满了,所以我想迁移数据源到data目录下去

首先我们需要关闭MySQL,命令如下:

#service mysqld stop

然后我们去data目录下创建文件夹mysql_data

mkdir mysql_data

然后是转移数据,为了安全期间,我们采用复制的命令cp,先找到mysql的原目录

#cd /var/lib
#ls

运行这个命令之后就会看到mysql的目录了,然后执行cp命令
注:我这是移动到data目录下的mysql_data下,如果你想移到其他目录下 后面修改路径即可.

#cp -a mysql /data/mysql_data/

这样就把数据库复制到/home/mysql_data下面去了,注意-a这个参数一定要带着,否则复制过去的权限就不对了。如果数据库比较大的话,时间会比较长,可能会超时。

到此 我们的数据源已经迁移过去了, 接着我们要修改一些配置类

打开mysql的配置文件
具体以自己实际路径为主 ,有的可能是/etc/mysql/my.cnf

#vi /etc/my.cnf

打开配置文件进行以下修改

#datadir=/var/lib/mysql
datadir=/data/mysql_data/mysql
#socket=/var/lib/mysql/mysql.sock
socket=/data/mysql_data/mysql/mysql.sock

这是注释的是之前老的数据源,然后我们配置一下新的数据源路径

接着修改/etc/init.d/mysqd配置文件里相应的目录
注:这里有的mysql版本可能文件名称叫mysql

vim /etc/init.d/mysqld

进行修改

#get_mysql_option datadir “/var/lib/mysql” mysqld
get_mysql_option datadir “/data/mysql_data/mysql” mysqld

重点 ! ! !

如果找不到这一行代码,说明你的mysql版本这个配置文件是写活的,暂时不用修改即可,嗐,我在这卡了好久,最后发现版本不同配这里置文件的内容是不同的~

最后建立软连接

ln -s /data/mysql_data/mysql/mysql.sock /var/lib/mysql/mysql.sock

启动mysql服务

service mysqld start

补:如果启动报错请继续往下看

2017-09-15 16:01:01 2420 [Warning] Using unique option prefix myisam-recover instead of myisam-recover-options is deprecated and will be removed in a future release. Please use the full name instead.
2017-09-15 16:01:01 2420 [Note] Plugin ‘FEDERATED’ is disabled.
^G/usr/sbin/mysqld: Can’t find file: ‘./mysql/plugin.frm’ (errno: 13 - Permission denied)
2017-09-15 16:01:01 2420 [ERROR] Can’t open the mysql.plugin table. Please run mysql_upgrade to create it.
2017-09-15 16:01:01 2420 [Note] InnoDB: Using atomics to ref count buffer pool pages
2017-09-15 16:01:01 2420 [Note] InnoDB: The InnoDB memory heap is disabled
2017-09-15 16:01:01 2420 [Note] InnoDB: Mutexes and rw_locks use GCC atomic builtins
2017-09-15 16:01:01 2420 [Note] InnoDB: Memory barrier is not used
2017-09-15 16:01:01 2420 [Note] InnoDB: Compressed tables use zlib 1.2.8
2017-09-15 16:01:01 2420 [Note] InnoDB: Using Linux native AIO
2017-09-15 16:01:01 2420 [Note] InnoDB: Using CPU crc32 instructions
2017-09-15 16:01:01 2420 [Note] InnoDB: Initializing buffer pool, size = 128.0M
2017-09-15 16:01:02 2420 [Note] InnoDB: Completed initialization of buffer pool
2017-09-15 16:01:02 2420 [ERROR] InnoDB: ./ibdata1 can’t be opened in read-write mode
2017-09-15 16:01:02 2420 [ERROR] InnoDB: The system tablespace must be writable!
2017-09-15 16:01:02 2420 [ERROR] Plugin ‘InnoDB’ init function returned error.
2017-09-15 16:01:02 2420 [ERROR] Plugin ‘InnoDB’ registration as a STORAGE ENGINE failed.
2017-09-15 16:01:02 2420 [ERROR] Unknown/unsupported storage engine: InnoDB
2017-09-15 16:01:02 2420 [ERROR] Aborting

我的mysql版本在启动的时候报错 说是找不到plugin.frm这个文件,可是当我去目录下查看的时候发现是有这个文件的,这是什么原因 ! ! !

在我坚持不懈百度到半夜两点的时候,发现原因了! ! !

ubatu的mysql通过yum安装或者rpm安装的时候,会建一个/etc/apparmor.d/usr.sbin.mysqld 文件,如果数据目录不在这里面,则会报错

/usr/sbin/mysqld: Can’t find file: ‘./mysql/plugin.frm’ (errno: 13 - Permission denied)

解决方法:

所以解决办法是在里面加上新的datadir目录。

root@huayuan:/var/lib# vim /etc/apparmor.d/usr.sbin.mysqld 

# vim:syntax=apparmor
# Last Modified: Tue Jun 19 17:37:30 2007
#include <tunables/global>

/usr/sbin/mysqld {
 #include <abstractions/base>
 #include <abstractions/nameservice>
 #include <abstractions/user-tmp>
 #include <abstractions/mysql>
 #include <abstractions/winbind>

 capability dac_override,
 capability sys_resource,
 capability setgid,
 capability setuid,

 network tcp,

 /run/mysqld/mysqld.pid rw,
 /run/mysqld/mysqld.sock w,

 /sys/devices/system/cpu/ r,
 #.........这里面写新的datadir目录,写2行,一行r,一行rwk。
 /data/mysql_data/mysql/ r,
 /data/mysql_data/mysql/** rwk,
 # Site-specific additions and overrides. See local/README for details.
 #include <local/usr.sbin.mysqld>
}

重启Mysql

service mysql start

OK,问题解决! ! !

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值