linux 不改变目录结构移动 home 目录到新分区的操作方法
问题提出
公司的开发测试服务器部署在阿里云, 阿里云给出的实例一般都是只有一个分区, 20G到40G的样子, 然后再买存储挂载到其他目录.
而 home 目录是在这个 20G 的跟目录分区下的. 随着开发人员增多, 根目录分区很快被大家填满了.
因为是多地研发, 因此需要一个无感知的给大家的 home 搬家的方案.
基本原理
接到这个任务, 首先想到的就是 bind mount 方式:
mount --bind /some/where /else/where
可以实现无感知搬家 home.
感觉搜索中文没有对这个命令解释太清楚的. 讲的比较清楚, 英文好的同学可以参考下.
当然, 也可以问"男人": man mount
具体操作
首先选个夜深人静的时候, 使用 who 命令查看还有那些小朋友赖在服务器不肯走, 打电话一一清场:
$ who Frodo pts/0 2017-04-17 09:07 (xx.xxx.xxx.xx) Sam pts/1 2017-04-18 08:45 (xx.xxx.xxx.xx) Pippin pts/3 2017-04-18 09:06 (xx.xxx.xxx.xx) Merry pts/4 2017-04-18 09:07 (xx.xxx.xxx.xx)
确定四下无人后, 开始搬家(复制). 使用 cp 命令复制时, 记得带上 -p 参数, 保留文件权限设置. 使用 root 权限, 假设目标分区为 /new_disk :
# cp -p -r /home /new_disk/
新家已经建好, 我们先给老家弄个另外的门牌号, 以免把门牌号给新家后, 找不到老家了. 利用 mount --bind 把原 home 目录挂载到一个新目录:
# mkdir /home_bkp # mount --bind /home /home_bkp
这时我们就可以在 /home_bkp 这个目录下找到老家的所有文件. 可以把 /home 这个门牌给新家了:
# mount --bind /new_disk/home /home
搬家完成! 可以通知小伙伴们愉快的工作了. 事实上, 可以不通知大家, 搬家这个事情对大家其实是无感知的.
当然有同学会问, 新家老家门牌一样, 都是 /home, 我怎么知道搬家是否成功? 可以使用 df 命令确认:
# cd /home_bkp # df -h . Filesystem Size Used Avail Use% Mounted on /dev/xvda1 20G 17G 2.1G 90% / # cd /home # df -h . Filesystem Size Used Avail Use% Mounted on /dev/xvdb1 296G 42G 240G 15% /new_disk
-h 为 human-readable, 不加的话也可以, 那列出的就是"反人类"的块为单位了.
上面的命令, 先去老家看看, 挂载点是 / ; 再去新家看看, 挂载点是 /new_disk . 这下可以放心了.
持久化
工作还没完. 上面的工作只是保证了当前新家换地址. 但重启后, 这个信息会丢失, 家地址会换回去. 我们需要想办法保留这个信息.
修改 /etc/fstab 文件即可. 打开这个文件, 在最后面加入下面两行:
/home /home_bkp none bind 0 0 /new_disk/home /home none bind 0 0
这样整个 home 切换分区工作就完成了.
后记
这个方案是心血来潮想出来的, 并没有找到前车之鉴, 不知道会不会有坑... 目前该方案下服务器已运行近一年, 还没出现啥问题, 大家工作的都很愉快, 甚至很多人都不知道有这件事情.
老家的目录 /home_bkp 在该方案实施1个月后, 看没啥问题, 就清空了, 腾空间出来.