V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
通过以下 Referral 链接购买 DigitalOcean 主机,你将可以帮助 V2EX 持续发展
DigitalOcean - SSD Cloud Servers
zwpaper
V2EX  ›  VPS

树莓派连 vps 对公网开放端口的问题

  •  
  •   zwpaper · 2016-10-13 14:07:38 +08:00 · 466 次点击
    这是一个创建于 2957 天前的主题,其中的信息可能已经有所发展或是发生改变。

    场景是这样的,我在内网,也就是路由器下,树莓派跑着一个 aria2 服务

    然后我在公网有一台 vps ,我希望通过树莓派能连到这台 vps 后,我可以通过 vps 向树莓派下发下载任务。

    现在使用的方案:

    使用 ssh 代理中转:

    • 树莓派对 vps 正向代理:
    ssh -fNR vps_port:127.0.0.1:pi_port user@vps
    

    但是 vps_port 只能在 vps 本地访问到,已经试过在 vps_port 前加 vps 的 ip ,也是只能本地访问。

    • 所以在 vps 加反向代理:
    ssh -fNL *:remote_port:localhost:target_port localhost
    

    这样连接就正常了。

    • 考虑到 ssh 时间长了会断,又写了个脚本, 300 秒看一下,断了就再运行。

    看起来一切都正常了。

    但是,问题来了。

    晚上还是正常的东西,睡一晚上起来,端口就连不上了!

    所有东西看起来都很正常,调试我也不知道从哪里下手了。

    • 手动把树莓派上的 ssh 杀了,然后再启动,一切又正常了。

    这,我就有点不会了。有人对 ssh 代理比较了解的吗?

    求助!

    第 1 条附言  ·  2016-10-13 23:32:49 +08:00

    用了 autossh 也会出问题。

    研究了一下,发现问题应该如下:

    • 假设树莓派使用 A 端口连接 vps 的 B 端口。
    • 在 vps 上 B 端口在一定时间以后,进入了 close_wait 状态,是 sshd 占用着这个端口。
    • 因为 B 端口被占用,所以树莓派这边做反向代理时,无法绑定到 B 端口上。

    不知道有没有人知道为什么会出现 close_wait 状态呢,而且这个 close_wait 占用了很长时间?

    8 条回复    2016-10-15 15:41:03 +08:00
    cq65617875
        1
    cq65617875  
       2016-10-13 16:44:20 +08:00
    为何不考虑 VPN
    zwpaper
        2
    zwpaper  
    OP
       2016-10-13 17:20:15 +08:00
    @cq65617875 树莓派只能单向连 vps ,如果用 vpn 的话,要怎么设置呢?
    roychan
        3
    roychan  
       2016-10-13 20:35:16 +08:00
    用 autossh ,设置 'ServerAliveInterval' 参数。
    roychan
        4
    roychan  
       2016-10-13 20:35:42 +08:00
    准确地说是:用 autossh ,并设置 'ServerAliveInterval' 参数。
    zwpaper
        5
    zwpaper  
    OP
       2016-10-13 22:29:43 +08:00
    @roychan 好东西!我试一下,明天早上看看效果,先谢谢了!
    roychan
        6
    roychan  
       2016-10-14 10:18:28 +08:00
    你有设置那个参数吗?
    zwpaper
        7
    zwpaper  
    OP
       2016-10-14 10:44:42 +08:00
    @roychan Ops ,自己查了一下 autossh ,把这个参数给忘了,我的锅,今晚再试试!
    zwpaper
        8
    zwpaper  
    OP
       2016-10-15 15:41:03 +08:00
    @roychan 太感谢了,加了参数之后果然可以用了!
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1036 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 19:00 · PVG 03:00 · LAX 11:00 · JFK 14:00
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.