SSHFS远程文件系统

为了像本地一样访问远程主机上的目录,通常我们会在远程主机上使用nfs来导出目录,并在本地主机上mount这个nfs文件系统。
但可能我们忽略了一个远程连接最通用的工具:ssh。其实很多和远程有关的行为,基于ssh都能完成,即使是实现像NFS一样的功能。
如何通过ssh来挂载远程目录?需要安装fuse-sshfs包,这个包在epel中提供。使用fuse-sshfs包提供的sshfs工具可以基于ssh直接挂载远程目录,不用像NFS一样还要export。

[root@node1 ~]# yum -y install epel-release
[root@node1 ~]# yum -y install fuse-sshfs

例如,挂载192.168.80.102上的根目录"/root/GBase"到本地的/mnt/GBase上。
注意:只能挂载远程目录,像普通文件、块设备(如/dev/sda2)等无法挂载。

[root@node1 ~]# sshfs root@192.168.80.102:/root/GBase /mnt/GBase

如此一来,以后可以直接访问本地/mnt/GBase来访问远程的根目录。例如复制文件、移动文件、新建文件等等操作。

如果要卸载挂载点。直接umount即可。

[root@node1 ~]#  umount /mnt/GBase

相比于NFS,sshfs更简洁,它是基于fuse模块来实现的,可以认为sshfs所挂载的文件系统是fuse文件系统的一种实现。
所谓fuse文件系统,它全称为filesystem in userspace,显然,它是用户空间的文件系统(其实是一个虚拟文件系统),其功能非常强大,可用于实现自己的文件系统。
详细信息可以sshfs -h,man sshfs,man fusermount,man mount.fuse。

但是NFS比sshfs要完整的多,nfs毕竟是"小型"分布式文件系统,对数据的一致性、完整性实现的都比较完美,访问权限控制也比sshfs要丰富的多。

总的来说,sshfs可以临时用来快速访问远程文件。

标签: sshfs, fuse-sshfs, 远程文件系统

添加新评论