利用ssh反向代理以及autossh实现从外网连接内网服务器

1. 背景

如何在公司外面,就可以访问公司内部的服务器;
如果在不能控制网络配置的情况下,将内网的服务器,向外提供网络服务(就是让外网的人,可以访问内网的服务器)

这些都可以用一个简单的代理来实现;

2. 场景

 

机器 ip用户名备注
A192.168.1.100user1需要提供服务的服务器,处于内网
B123.123.123.123 user2外网服务器,相当于桥梁的作用

3. 解决方法

就是在机器A上做到B机器的反向代理;然后在B机器上做正向的代理实现本地端口的转发.

3.1 环境

内外网的OS都是centos7;
每台都要安装autossh的客户端(安装命令:yum install autossh)

3.2 介绍一下ssh参数:

反向代理 ssh -fNR

-f 后台执行ssh指令
-C 允许压缩数据
-N 不执行远程指令
-R 将远程主机(服务器)的某个端口转发到本地端指定机器的指定端口
-L 将本地机(客户机)的某个端口转发到远端指定机器的指定端口
-p 指定远程主机的端口

3.3 介绍一下autossh参数:

usage: autossh [-V] [-M monitor_port[:echo_port]] [-f] [SSH_OPTIONS]

    -M specifies monitor port. May be overridden by environment
       variable AUTOSSH_PORT. 0 turns monitoring loop off.
       Alternatively, a port for an echo service on the remote
       machine may be specified. (Normally port 7.)
    -f run in background (autossh handles this, and does not
       pass it to ssh.)
    -V print autossh version and exit.

Environment variables are:
    AUTOSSH_GATETIME    - how long must an ssh session be established
                          before we decide it really was established
                          (in seconds). Default is 30 seconds; use of -f
                          flag sets this to 0.
    AUTOSSH_LOGFILE     - file to log to (default is to use the syslog
                          facility)
    AUTOSSH_LOGLEVEL    - level of log verbosity
    AUTOSSH_MAXLIFETIME - set the maximum time to live (seconds)
    AUTOSSH_MAXSTART    - max times to restart (default is no limit)
    AUTOSSH_MESSAGE     - message to append to echo string (max 64 bytes)
    AUTOSSH_PATH        - path to ssh if not default
    AUTOSSH_PIDFILE     - write pid to this file
    AUTOSSH_POLL        - how often to check the connection (seconds)
    AUTOSSH_FIRST_POLL  - time before first connection check (seconds)
    AUTOSSH_PORT        - port to use for monitor connection
    AUTOSSH_DEBUG       - turn logging to maximum verbosity and log to
                          stderr

autossh 可以理解为一个带有自动重连的ssh。只有3个使用参数,其他的为环境变量。 使用上和ssh基本一致。 

3. 具体操作:

3.1 首先实现A无密码登录到B机器

将需要穿透的服务器A生成公钥发送至外网服务器B上,作用是执行autossh不用输入密码

a. 在A服务器上生成公钥

ssh-keygen 
一路回车即可生成$home/.ssh/id_rsa.pub。

b.发送至外网服务器B上

将公钥追加至外网服务器$home/.ssh/authorized_keys
ssh-copy-id root@123.123.123.123
输入密码回车,即可!

3.2 在A服务器上建立A机器到B机器的反向代理

具体指令:

ssh -fNR [B机器IP或省略]:[B机器端口]:[A机器的IP]:[A机器端口] [登陆B机器的用户名@服务器IP]

在这里我使用了B机器的2222端口,以及A机器的22端口,按照上面的指令就是这样子的操作

ssh -fNR 2222:localhost:22 root@123.123.123.123

autossh的指令:

autossh -M 1111 -fNR 2222:localhost:22 root@123.123.123.123

这里的增加了一个参数【-M 1111】,这个是autossh的监控端口,用来监控2222端口是否连接正常,如果不正常,则进行重连。

4. 测试代理

至此我们都配置好了AB机器,那么我们就可以从一部外网的电脑登陆到内网里面去啦。鉴于我目前的电脑在内网,而服务器都是外网的(也就是配置的B机器),所以可以通过B机器连接到我内网的A中,具体指令为:

ssh -p 2222 user1@123.123.123.123 

在此-p参数为指定登陆的IP,我们在上面指定了2222端口为转发端口,故用2222端口登陆,然后user1是内网A机器的用户名,123.123.123.123为外网B机器的IP地址。

5. 稳定性

ssh反向链接会因为超时而关闭,如果关闭了那从外网连通内网的通道就无法维持了。一种方式就是修改默认的超时和心跳参数,另外一种做发就是用autossh连接。
不过依然会有一些假死的问题,存在。 这个就是需要推销一下前面介绍autossh里面的那些环境变量了。
以下提供的是一个完整的连接配置:

export AUTOSSH_PIDFILE=/root/autossh.pid
export AUTOSSH_LOGFILE=/root/autossh.log
export AUTOSSH_LOGLEVEL=DEBUG
export AUTOSSH_POLL=60
export AUTOSSH_FIRST_POLL=30
export AUTOSSH_GATETIME=0
export AUTOSSH_DEBUG=1
autossh -M 29998 -fNR 29999:localhost:80 root@118.178.180.139 -o "ServerAliveInterval 60" -o "ServerAliveCountMax 3" -o BatchMode=yes -o StrictHostKeyChecking=no
echo "autossh is started!"

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值