mysql 数据存储目录进行迁移

问题描述:由于前期安装系统的时候,运维人员没有考虑到mysql存储空间的问题,直接用root安装的,而根目录下的空间是很有限的,因此打算把mysql的数据存储目录进行迁移到home目录下


默认安装的数据库的data存放路劲为/var/lib/mysql,配置文件尾/etc/my.cnf,要迁移到/home/mylib/mysql下面。
系统是centos 6.4

下面的所有操作我都是用root用户操作的,如果不是root请在命令前面加上sudo。

1. 停止mysql服务:service mysql stop
2. 拷贝原来的data 到新目录下:cp -R -p /var/lib/mysql /home/mylib/
3. 编辑配置文件,vi /etc/my.cnf, 修改datadir
[mysqld]
character_set_server = utf8
datadir = /home/myllib/mysql

测试mysql是不是可以启动了? service mysql start 
出现错误了:
mysql Starting MySQL..The server quit without updating PID file
解决方法:
1. 没有配置好权限,chown -R mysql:mysql /home/mylib/mysql
    chmod -R 755 /home/mylib/mysql
2. 删除残留数据mysql-bin.index, rm -rf /home/mylib/mysql/mysql-bin.index
3.SELinux 的影响,
setenforce 0,点击打开链接
 
如果还是尝试其它一些解决办法,点击打开链接
如果是ubuntu,请参考下面的链接,点击打开链接

另外可以换一种思路,就是改变整个根目录的大小,无需进行任何其它的配置

下面是别人写的一篇博客忘记是那个地方的,希望博主看到了见谅!!!

一、目的

在使用CentOS6.3版本Linux系统的时候,发现根目录(/)的空间不是很充足,而其他目录空间有很大的空闲,所以本文主要是针对现在已有的空间进行调整。首先,先来查看一下系统的空间分配情况:

[root@CentOS-78/]# df -hFilesystem            Size  Used Avail Use%Mounted on/dev/mapper/vg_centos-lv_root                     50G  14G  34G  30% /tmpfs                1.9G   0  1.9G  0% /dev/shm/dev/sda1            485M  37M 423M  8% /boot/dev/mapper/vg_centos-lv_home                     404G  670M  382G  1% /home

下面的详细步骤部分将从vg_centos-lv_home分区下取出100G的空间添加到/vg_centos-lv_root分区上去。

二、详细步骤

1、卸载vg_centos-lv_home分区

[root@CentOS-78/]# umount /home

此时在用df命令查看将会发现/home目录已经看不见了,如下所示:

[root@CentOS-78/]# df -hFilesystem            Size  Used Avail Use%Mounted on/dev/mapper/vg_centos-lv_root                     50G  14G  34G  30% /tmpfs                1.9G   0  1.9G  0% /dev/shm/dev/sda1            485M  37M 423M  8% /boot

2、从新设定vg_home-lv_home的大小

[root@CentOS-78/]# resize2fs -p /dev/mapper/vg_centos-lv_home 282Gresize2fs 1.41.12 (17-May-2010)Please run 'e2fsck -f /dev/mapper/vg_centos-lv_home' first.

这一步设定vg_home-lv_home大小没有成功,系统提示我们先运行下面的命令,操作如下:

[root@CentOS-78/]# e2fsck -f /dev/mapper/vg_centos-lv_homee2fsck 1.41.12 (17-May-2010)Pass 1: Checking inodes, blocks, and sizesPass 2: Checking directory structurePass 3: Checking directory connectivityPass 4: Checking reference countsPass 5: Checking group summary information/dev/mapper/vg_centos-lv_home: 1386/26836992 files (0.9% non-contiguous),1855856/107344896 blocks

重新设定vg_home-lv_home的大小:

[root@CentOS-78/]# resize2fs -p /dev/mapper/vg_centos-lv_home 282Gresize2fs 1.41.12 (17-May-2010)Resizing the filesystem on /dev/mapper/vg_centos-lv_home to 73924608 (4k)blocks.Begin pass 2 (max = 43)Relocating blocks           XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXBegin pass 3 (max = 3276)Scanning inode table         XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXBegin pass 4 (max = 266)Updating inode references    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXThe filesystem on /dev/mapper/vg_centos-lv_home is now 73924608 blocks long.

检查是否成功:

[root@CentOS-78 /]# mount /home[root@CentOS-78 /]#[root@CentOS-78 /]# df -hFilesystem            Size  Used Avail Use%Mounted on/dev/mapper/vg_centos-lv_root                     50G  14G  34G  30% /tmpfs                1.9G   0  1.9G  0% /dev/shm/dev/sda1            485M  37M 423M  8% /boot/dev/mapper/vg_centos-lv_home                     278G  663M  263G  1% /home[root@CentOS-78 /]#

 

 

3、将lv_home逻辑分区减小到指定大小

[root@CentOS-78 /]#lvreduce -L 282G /dev/mapper/vg_centos-lv_home  WARNING: Reducing active and open logical volume to 282.00 GiB  THIS MAY DESTROY YOUR DATA (filesystem etc.)Do you really want to reduce lv_home? [y/n]: y  Reducing logical volume lv_home to 282.00 GiB  Logical volume lv_home successfully resized[root@CentOS-78 /]#

我认为这个命令是将已经减少的100G空间拿到系统公共的区域,可以被其他分区加载和利用。

查询卷组的信息:

[root@CentOS-78/]# vgdisplay  --- Volume group ---  VG Name              vg_centos  System ID  Format                lvm2  Metadata Areas        1  Metadata Sequence No  5  VG Access            read/write  VG Status            resizable  MAX LV                0  Cur LV                3  Open LV              3  Max PV                0  Cur PV                1  Act PV                1  VG Size              465.27 GiB  PE Size              4.00 MiB  Total PE              119109  Alloc PE / Size      86472 / 337.78 GiB  Free  PE / Size      32637 / 127.49 GiB  VG UUID             1k4ooN-RFV9-uyf1-uMYf-aERG-YaGs-ZNoSD6

FreePE / Size指定的应该是现在可在分配的空间。

4、增加vg_centos-lv_root分区的大小

将可用的空间添加到vg_centos-lv_root分区上面:

[root@CentOS-78/]# lvextend -L +127.40G /dev/mapper/vg_centos-lv_root  Rounding up size to full physical extent 127.40 GiB  Extending logical volume lv_root to 177.40 GiB  Logical volume lv_root successfully resized[root@CentOS-78 /]#

从新设定该分区的大小:

[root@CentOS-78/]# resize2fs -p /dev/mapper/vg_centos-lv_rootresize2fs 1.41.12 (17-May-2010)Filesystem at /dev/mapper/vg_centos-lv_root is mounted on /; on-line resizingrequiredold desc_blocks = 4, new_desc_blocks = 12Performing an on-line resize of /dev/mapper/vg_centos-lv_root to 46504960 (4k)blocks.The filesystem on /dev/mapper/vg_centos-lv_root is now 46504960 blocks long.

5、再次查看分区大小

[root@CentOS-78/]# df -hFilesystem            Size  Used Avail Use%Mounted on/dev/mapper/vg_centos-lv_root                     175G  14G  153G  9% /tmpfs                1.9G   0  1.9G  0% /dev/shm/dev/sda1            485M  37M 423M  8% /boot/dev/mapper/vg_centos-lv_home                     278G  663M  263G  1% /home

我们发现vg_centos-lv_root分区的空间已经增加了125G,之所以比lv_home减少的空间要多25G主要是由于我们把系统所有的可用的空间都加在了lv_root分区。

 

三、所遇到的问题

1、在卸载/home目录的时候失败

可先执行如下fuser命令,然后再umount即可:

[root@CentOS-78 /]# fuser-m /home

[root@CentOS-78/]#

2、设定完lv_home的大小,再次mount该分区时,发现用df命令无法看到给分区,此时只要在mount一次即可

3、在设定lv_root的大小时,不要把Free PE/ Size的空间全部都用上,这很可能会出现FreePE空间不足的现象,建议保留一点FreePE的空间。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值