我想解决一个有趣的问题。我有一个JumpBox服务器,为了安全地将ssh插入客户机的服务器。这是我的客户端唯一打开端口22的服务器。但是,这个JumpBox服务器非常小,没有足够的空间容纳大型文件(大于5GB)。
因此,我已经为此目的设置了另一个具有更大磁盘的服务器,但我不希望客户端随后不得不将端口22打开到另一个IP地址。
服务器T=传输箱
服务器J= Jumpbox
服务器C= Clientbox
从服务器J,我可以将服务器T上的文件传输到服务器C吗?
谢谢,如果我需要澄清什么,请告诉我
发布于 2011-09-13 20:35:04
遗憾的是,scp目前不支持这一点。但是您可以在J、挂载T和C上使用sshfs,然后在J上复制(使用cp)从挂载点T到挂载点C。
如果您以/net (与可执行的自动地图)的方式组合了autofs和sshfs,那么您很可能会得到一个有效的自动解决方案。
我在某个地方看到了一个用于CentOS的sshfs解决方案。
发布于 2011-09-13 19:49:07
从"T“开始,您应该在"J”上打开一个ssh隧道,将其转发到"C“上的SSH。从那里你可以跳过J从T通过SSH在C上做任何事情。有关更多信息,请参见SSH隧道使
因此,在您的"T“服务器上,您可能会这样做:
ssh -f J-user@addr-of-J-server -L 2000:addr-of-C-server:22 -N
ssh C-user@localhost -p 2000
发布于 2011-09-13 19:54:39
为什么不使用拆分、tar或zip实用程序将您的文件收集成较小的部分,然后通过J单独传输每一段,当所有片段都在C上时,只需展开tar/zip归档。
您的另一个选择是在T和J之间创建某种VPN,然后您可以尝试从T安装一个文件共享/导出,就像它是一个本地文件系统(NFS、FUSE等)。
其他选项是让客户端SSH进入J并设置一个隧道(-L,-R),然后从J允许他们登录T,因此他们创建了一个隧道C->J->T,在T上有一个可用的文件传输系统(FTP,HTTP)。SSH隧道将根据需要发送数据包。
最好的解决方案是在JumpBox上获得更多的资源。如果你的客户给你钱,你应该把其中的一部分投资到适当的基础设施上,这样你/他们就不用浪费时间了。
https://serverfault.com/questions/311038
复制相似问题