最近发现服务器的目录空间快满了,所以我想迁移数据源到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,问题解决! ! !