利用SSH Filesystem实现远程文件系统

远程文件系统的访问有很多种不同的实现方式,一些常见的连接方式比其它特定情况下的更有用。最著名的一个例子就是微软的通用互联网文件系统(CIFS),它可以容许微软Windows“映射网络驱动器”并利用资源管理器对网络进行“浏览”。另一个是最早由太阳计算机系统开发的网络文件系统(NFS),作为美国电话电报公司开发的UNIX系统配置已经有15年的历史了。尽管还存在几十种其他的选择,但这两种系统占据了网络文件系统的主流。NFS 默认要在拥有 root 权限下才能挂载 (mount) 进来,另外则是使用 NFS 使用 RPC ( portmap 或 rpcbind ) 服务来做端口映射 (Port Mapping),也代表防火墙也要多一层设置,为了安全总有那么一点不方便。对于安装了Openssh的系统来说,实际上这包含了几乎所有的开源类Unix操作系统,SSH Filesystem—作为可验证的方便安全的网络文件系统,是用来访问远程计算机上存储数据的完美选择,甚至于连在 Windows 下都可以自由挂载远程 Linux 账号下的任意一个文件夹,真的非常方便。

SSH Filesystem是基于ssh的,所以需要在客户端计算机上安装和使用sshFS的话,就需要安装Openssh。几乎所有的Linux主要发行版本和BSD Unix操作系统,在默认配置下都已经安装了Openssh的,所以你不会需要单独安装它。此外,服务器端—你希望能够从本地客户端系统访问的计算机中的文件系统—需要运行Openssh服务器进程。

SSH Filesystem也是基于FUSE,也就是所谓的“用户空间文件系统”。FUSE在类Unix系统中提供了一个API,可以用于建立高级别的文件系统,并且可以实现不需要root权限连接的安全管理。幸运的是,主要的开放源代码类Unix操作系统的软件管理系统都应该为你提供了自动处理功能。

如何在 Linux 下通过 sshfs 挂载远程目录

  1. 安装 sshfs

CentOS 6.3 ( 在CentOS 下,使用者必须加入 fuse组才能使用 FUSE 功能 )

yum install fuse-sshfs

usermod -a -G fuse username

  1. 建立挂载点 (也就是要从远程对应到本机哪个文件夹)

请注意: 如果用一般使用者身分执行时,该挂载点目录的拥有者必须为使用者自己!

sshfs username@hostname:/path/to/folder /path/to/local/folder

  1. 卸载 sshfs 挂载

fusermount -u /path/to/local/folder

下面演示Azure上2台CentOS主机上加载sshfs文件

[azureuser@mono ~]$ sudo yum install fuse-sshfs

[sudo] password for azureuser:

Not using downloaded repomd.xml because it is older than what we have:

Current : Fri Apr 26 20:58:04 2013

Downloaded: Fri Apr 26 20:48:40 2013

Setting up Install Process

Resolving Dependencies

--> Running transaction check

---> Package fuse-sshfs.x86_64 0:2.4-1.el6 will be installed

--> Processing Dependency: fuse >= 2.2 for package: fuse-sshfs-2.4-1.el6.x86_64

--> Processing Dependency: libfuse.so.2(FUSE_2.7)(64bit) for package: fuse-sshfs-2.4-1.el6.x86_64

--> Processing Dependency: libfuse.so.2(FUSE_2.6)(64bit) for package: fuse-sshfs-2.4-1.el6.x86_64

--> Processing Dependency: libfuse.so.2(FUSE_2.5)(64bit) for package: fuse-sshfs-2.4-1.el6.x86_64

--> Processing Dependency: libfuse.so.2(FUSE_2.4)(64bit) for package: fuse-sshfs-2.4-1.el6.x86_64

--> Processing Dependency: libfuse.so.2(FUSE_2.2)(64bit) for package: fuse-sshfs-2.4-1.el6.x86_64

--> Processing Dependency: libfuse.so.2()(64bit) for package: fuse-sshfs-2.4-1.el6.x86_64

--> Running transaction check

---> Package fuse.x86_64 0:2.8.3-4.el6 will be installed

---> Package fuse-libs.x86_64 0:2.8.3-4.el6 will be installed

--> Finished Dependency Resolution

Dependencies Resolved

================================================================================

Package Arch Version Repository Size

================================================================================

Installing:

fuse-sshfs x86_64 2.4-1.el6 epel 52 k

Installing for dependencies:

fuse x86_64 2.8.3-4.el6 base 71 k

fuse-libs x86_64 2.8.3-4.el6 base 74 k

Transaction Summary

================================================================================

Install 3 Package(s)

Total download size: 198 k

Installed size: 553 k

Is this ok [y/N]: y

Downloading Packages:

(1/3): fuse-2.8.3-4.el6.x86_64.rpm | 71 kB 00:00

(2/3): fuse-libs-2.8.3-4.el6.x86_64.rpm | 74 kB 00:00

(3/3): fuse-sshfs-2.4-1.el6.x86_64.rpm | 52 kB 00:00



Total 236 kB/s | 198 kB 00:00

warning: rpmts_HdrFromFdno: Header V3 RSA/SHA256 Signature, key ID 0608b895: NOKEY

Retrieving key from file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6

Importing GPG key 0x0608B895:

Userid : EPEL (6) epel@fedoraproject.org

Package: epel-release-6-8.noarch (installed)

From : /etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6

Is this ok [y/N]: y

Running rpm_check_debug

Running Transaction Test

Transaction Test Succeeded

Running Transaction

Installing : fuse-2.8.3-4.el6.x86_64 1/3

Installing : fuse-libs-2.8.3-4.el6.x86_64 2/3

Installing : fuse-sshfs-2.4-1.el6.x86_64 3/3

Verifying : fuse-sshfs-2.4-1.el6.x86_64 1/3

Verifying : fuse-libs-2.8.3-4.el6.x86_64 2/3

Verifying : fuse-2.8.3-4.el6.x86_64 3/3

Installed:

fuse-sshfs.x86_64 0:2.4-1.el6

Dependency Installed:

fuse.x86_64 0:2.8.3-4.el6 fuse-libs.x86_64 0:2.8.3-4.el6

Complete!

[azureuser@mono ~]$ sudo usermod -a -G fuse azureuser

[azureuser@mono ~]$ sudo mkdir /usr/local/youhaoda

[azureuser@mono ~]$ sudo sshfs azureuser@youhaoda.cloudapp.net:/usr/local/src /usr/local/youhaoda

The authenticity of host 'youhaoda.cloudapp.net (168.63.212.151)' can't be established.

RSA key fingerprint is c7:fb:53:84:ac:13:74:0b:08:55:b4:06:34:57:22:7c.

Are you sure you want to continue connecting (yes/no)? y

Please type 'yes' or 'no': yes

azureuser@youhaoda.cloudapp.net's password:

[azureuser@mono ~]$ ls /usr/local/youhaoda -l

ls: ÎÞ·¨·ÃÎÊ/usr/local/youhaoda: ȨÏÞ²»¹»

[azureuser@mono ~]$ sudo ls /usr/local/youhaoda -l

×ÜÓÃÁ¿ 82004

drwxr-xr-x. 1 root root 4096 8ÔÂ 2 17:21 jexus-5.4.3

-rw-r--r--. 1 root root 179047 8ÔÂ 6 07:44 jexus-5.4.3.tar.gz

  1. 1 1000 users 4096 9ÔÂ 21 03:21 libgdiplus-2.10

-rw-r--r--. 1 root root 1962898 2ÔÂ 14 2011 libgdiplus-2.10.tar.bz2

drwxr-xr-x. 1 1000 users 4096 9ÔÂ 21 03:27 mono-3.2.3

-rw-r--r--. 1 root root 81810387 9ÔÂ 17 23:08 mono-3.2.3.tar.bz2

如何在 Windows 下通过 sshfs 加载远程目录

  1. 安装 sshfs 相关软件

安装 Dokan library ( 直接下载 DokanInstall_0.6.0.exe 安装文件 )
安装 win-sshfs 工具 ( 下载链接 )
安装步骤可参考文章 SSHFS in Windows。目前 Dokan library ( v0.6.0 ) 可支持 Windows 8 操作系统,但你必须在应用程序启动时以系统管理员身分执行,才可以正常安装!

  1. 加载SSHFS 网络驱动器

运行 Sshfs Manager 之后,会在系统里出现一个黄色图示

时间: 2024-10-07 19:23:35

利用SSH Filesystem实现远程文件系统的相关文章

如何在 Linux 上使用 SSHfs 挂载一个远程文件系统

如何在 Linux 上使用 SSHfs 挂载一个远程文件系统 你曾经想过用安全 shell 挂载一个远程文件系统到本地吗?如果有的话,SSHfs 也许就是你所需要的.它通过使用 SSH 和 Fuse(LCTT 译注:Filesystem in Userspace,用户态文件系统,是 Linux 中用于挂载某些网络空间,如 SSH,到本地文件系统的模块) 允许你挂载远程计算机(或者服务器)到本地. 注意: 这篇文章假设你明白SSH 如何工作并在你的系统中配置 SSH. 准备 在使用 SSHfs 挂

Linux如何利用ssh传送文件至FTP空间进行备份

  在Linux系统中,可通过ssh将文件传送到FPT空间中,将一些重要的数据进行备份,那么要如何实现文件的传送呢?小编给大家具体介绍下Linux利用ssh传送文件到FTP空间的方法. 步骤: 假设要备份的目录为 /home/wwwroot/aaa/ ,远程FTP空间的 IP 为 55.44.33.22 1.进入到 /home/wwwroot/ 目录 cd /home/wwwroot 2.然后将 aaa 目录压缩为 tar.gz 文件包 aaa.tar.gz tar cfz aaa.tar.gz

《树莓派开发实战(第2版)》——2.7 利用SSH远程控制树莓派

2.7 利用SSH远程控制树莓派 面临问题 你想要从另一台计算机上,通过SSH连接一台远程树莓派. 解决方案 要想使用SSH连接树莓派,必须首先启用SSH.对于较新版本的Raspbian来说,你可以使用树莓派的Configuration tool(见图2-7)来完成这项工作,该软件位于主菜单的Preferences中.点选SSH的复选框,单击OK,系统将提示重新启动树莓派. 如果你使用的Raspbian版本较旧的话,可以使用raspi_config程序.为了启动该程序,只需在终端中键入下列命令即

利用curl抓取远程页面内容的示例代码

利用curl抓取远程页面内容的一个小示例,需要的朋友可以过来参考下   最基本的操作如下 复制代码 代码如下: $curlPost = 'a=1&b=2';//模拟POST数据 $ch = curl_init(); curl_setopt($ch, CURLOPT_HTTPHEADER, array('X-FORWARDED-FOR:0.0.0.0', 'CLIENT-IP:0.0.0.0'));  //构造IP curl_setopt($ch, CURLOPT_REFERER, "ht

SSH服务如何远程管理RHEL 5

Linux提供了多种方式让用户进行远程管理,如Telnet,它的基本应用就是提供远程管理,共享远程系统中的资源.Telnet使用户坐在自己的电脑前通过网络进入另一台电脑,并把用户输入的每个字符传递给主机.再将主机输出的每个信息回显在屏幕上,这样的连接可以发生在同一个房间,也可以发生在地球的两端.但Telnet服务在本质上是不安全的,原因在于在Telnet整个通信过程中采用明文传送数据,在当今的网络环境下这样的操作如果发现在Internet上无异于自杀. SSH(Secure Shell)则不同,

请问ubuntu16.04下ssh连接到远程服务器出现奇怪的乱码

问题描述 请问ubuntu16.04下ssh连接到远程服务器出现奇怪的乱码 但是在ubuntu下的虚拟机下的centos下连接是不会出现乱码的, 而在mysql下的数据库下的都不会乱码,请问这是怎么回事,谢谢.

pwntools如何用利用Pwnlib.gdb进行远程调试?

问题描述 pwntools如何用利用Pwnlib.gdb进行远程调试? 1C 这几天在学习pwn,在调试一些交互程序的时候,需要输入信息,可是无法在调试过程中输入内存地址无法观察输入字符串是否覆盖到了栈地址(比如在测试栈溢出的到时候利用python可以python -c ""print 'A'*123 +'x12x12x12.......'"")因此想进行远程调试,从网上找到pwntools,其中pwnlib.gdb的gdb.debug可以用来远程调试,就是用gdb

SSH使用ssh-keygen远程登录主机免输入密码

   SSH使用ssh-keygen远程登录主机免输入密码 分类: Linux2013-02-19 21:48 660人阅读 评论(2) 收藏 举报 linuxLinuxLINUX   目录(?)[+]   环境: 本地主机名:ha01 eth0: 192.168.1.100 //对外IP地址 远程主机名:ha02 eth0: 192.168.1.200 //对外IP地址 本地主机ha01配置: [root@ha01 /]# cd /etc/ssh [root@ha01 ssh]# ssh-ke

Linux VPS利用SSH重置ROOT密码的方法_Linux

鉴于我们的VPS安全性,老左建议大家为了维护VPS的安全性,也有必要在一段时间修改ROOT密码.VPS管理平台用户后台如果没有修改ROOT密码,也不要紧,我们可以利用SSH直接修改,一个单词命令就可以完成.只需要两步就可以完成. 第一步,登录我们的SSH,一般老左喜欢用PUTTY软件直接登录,这个我相信大家不要我再截图给大家看了吧. 第二步,用root用户名和密码登录. 输入"passwd"命令回车后然后会提示我们输入新密码,然后回车再输入一次.回车后我们就设置完毕,以后我们就用新的R