はじめに
最近、後輩や友人が練習するために研究室にサーバーを立てました それならイントラネットに直接接続しても問題ありません。しかし、寮に戻ると問題が発生します。キャンパスネットワークを使用している子供用の靴はまだ接続できますが、外部ネットワークを使用している若い富裕層はイントラネットに接続できません。外部ネットワーク経由でイントラネットサーバーに接続する方法はありますか?答えは「はい」ですが、次の条件が必要です: 外部ネットワークからアクセスできるサーバー。
1. 現在のマシンのステータスを説明して整理します:
A | 10.21.32.10 6 | gdut728 | ターゲットサーバー、 内部ネットワーク
|
B | 123.123.123.123 | root |
外部ネットワークサーバーにあり、ブリッジの役割に相当します
|
追記: 123.123.123.123 は私がランダムに選択したものです。他の人のサーバーを攻撃しないでください。
簡単に言えば、マシン A をマシン B のリバース プロキシとして使用することです。ローカル ポート フォワーディングを実装するためのマシン B 上のフォワード プロキシ2.1 実装前の準備各マシンに ssh クライアントをインストールする必要があります
。 2.2 使用される ssh パラメータを紹介します: リバースプロキシ
ssh -fCNR
フォワードプロキシssh -fCNR
正向代理
ssh -fCNL
-f 后台执行ssh指令
-C 允许压缩数据
-N 不执行远程指令
-R 将远程主机(服务器)的某个端口转发到本地端指定机器的指定端口
-L 将本地机(客户机)的某个端口转发到远端指定机器的指定端口
-p 指定远程主机的端口
******************区分大小写啊各位亲******************
ログイン後にコピー
3. 首先在A上面操作:
建立A机器到B机器的反向代理,具体指令为
ssh -fCNR [B机器IP或省略]:[B机器端口]:[A机器的IP]:[A机器端口] [登陆B机器的用户名@服务器IP]
ログイン後にコピー
在这里我使用了B机器的7280端口,以及A机器的22端口,按照上面的指令就是这样子的操作
ssh -fCNR 7280:localhost:22 root@123.123.123.123
ログイン後にコピー
检验是否已经启动了可以使用ps aux | grep ssh
指令来查看:
4. 接着在B上面操作:
建立B机器的正向代理,用来做转发,具体指令为
ssh -fCNL [A机器IP或省略]:[A机器端口]:[B机器的IP]:[B机器端口] [登陆B机器的用户名@B机器的IP]
ログイン後にコピー
按照第3那里输入的指令,这里的B机器的端口和上面的B机器的端口是一致的,端口1234的也是B机器的。
ssh -fCNL *:1234:localhost:7280 localhost
ログイン後にコピー
检验是否已经启动了可以使用ps aux | grep ssh
指令来查看:
在此1234端口为本地转发端口,负责和外网进行通信,并将数据转发的7280这个端口,实现了可以从其他机器访问的功能。同时,*号表示可以接受任何IP的访问。
5. 展现奇迹的时候到了
至此我们都配置好了AB机器,那么我们就可以从一部外网的电脑登陆到内网里面去啦。鉴于我目前的电脑在内网,而服务器都是外网的(也就是配置的B机器),所以可以通过B机器连接到我内网的A中,具体指令为:
ssh -p1234 gdut728@123.123.123.123
ログイン後にコピー
在此-p参数为指定登陆的IP,我们在上面指定了1234端口为转发端口,故用1234端口登陆,然后gdut728是内网A机器的用户名,123.123.123.123为外网B机器的IP地址。
6. 这种反向代理的方式是不稳定的
不幸的是这种ssh反向链接会因为超时而关闭,如果关闭了那从外网连通内网的通道就无法维持了,为此我们需要另外的方法来提供稳定的ssh反向代理隧道。
6.1 ssh每次重连都需要键入密码,故在此首先设置免密码登陆到内网
在内网的机器A上面执行:
ssh-copy-id 内网用户名@外网IP -p指定转发的端口
ログイン後にコピー
按照之前我设定的端口,这个指令就是如下
ssh-copy-id gdut728@123.123.123.123 -p1234
ログイン後にコピー
那以后这台内网的A机器ssh登陆我外网的B机器就可以免密码登陆啦~
检验是否已经可以使用免密码登陆可以使用如下指令来检验:
ssh root@123.123.123.123
ログイン後にコピー
6.2 用autossh建立稳定隧道
centos7上没有默认安装autossh
的,所以使用一下命令安装
yum install autossh
ログイン後にコピー
来看看具体的autossh的指令为
autossh -M 7281 -fCNR 7280:localhost:22 root@123.123.123.123
ログイン後にコピー
autossh
的参数与ssh的参数是一致的,但是不同的是,在隧道断开的时候,autossh会自动重新连接而ssh不会。另外不同的是我们需要指出的-M参数,这个参数指定一个端口,这个端口是外网的B机器用来接收内网A机器的信息,如果隧道不正常而返回给A机器让他实现重新连接。
7. 最后配置在Linux上配置开机自动启动autossh,免去了重启Linux后要自己启动的autossh的麻烦
输入:
vi /etc/rc.d/rc.local
添加内容:
autossh -M 7281 -fCNR 7280:localhost:22 root@123.123.123.123
因为centos7之后,原来直接修改/etc/rc.d/rc.local
启动脚本自动生效的功能因为修改了需要重新赋予可执行权限
再输入 <a href="http://www.php.cn/wiki/1294.html" target="_blank">chmod</a> +x /etc/rc.d/rc.local
ssh -fCNL
rrreee
3 最初に操作します。 A:
マシン A からマシン B へのリバース プロキシを確立します。具体的な手順は rrreee です。ここではマシン B のポート 7280 とマシン A のポート 22 を使用しました。上記の手順に従ってください。これでサブ操作 rrreee は完了です。 開始されているかどうかを確認するには、ps aux | grep ssh
コマンドを使用して確認できます:
4. 次に、B を操作します: 転送のために B マシンのフォワード プロキシを確立します。具体的な手順は次のとおりです。🎜rrreee🎜 入力コマンドのセクション 3 に従います。 、ここでのマシン B のポートは上記のマシン B のポートと一致しており、ポート 1234 もマシン B のポートです。 🎜rrreee🎜 開始されているかどうかを確認するには、ps aux | grep ssh
コマンドを使用できます: 🎜🎜🎜🎜ポート 1234 はローカル転送ポートで、外部ネットワークとの通信とポート 7280 へのデータ転送を担当し、他のマシンからアクセスできる機能を実装します。 。同時に、* 記号は、任意の IP からのアクセスを受け入れることができることを示します。 🎜🎜🎜5. 奇跡を見せる時が来ました🎜🎜 AB マシンの設定が完了したので、外部ネットワーク上のコンピューターからイントラネットにログインできます。現在のコンピューターは内部ネットワーク上にあり、サーバーは外部ネットワーク (つまり、構成された B マシン) 上にあるため、B マシンを介して内部ネットワーク上の A に接続できます。具体的なコマンドは次のとおりです: 🎜rrreee🎜ここ - p パラメータは指定されたログイン IP です。上で転送ポートとしてポート 1234 を指定したため、ログインにポート 1234 を使用します。gdut728 は内部ネットワーク上のマシン A のユーザー名で、123.123.123.123 は IP アドレスです。外部ネットワーク上のマシン B の。 🎜🎜🎜🎜🎜6. 残念ながら、このリバース プロキシ方式は不安定です。この ssh リバース リンクはタイムアウトにより閉じられます。このリンクが閉じられると、外部ネットワークから内部ネットワークへのチャネルを維持できなくなります。このため、安定した ssh リバース プロキシ トンネルを提供するための別の方法が必要になります。 🎜🎜6.1 SSH で再接続するたびにパスワードを入力する必要があるため、ここではまずイントラネットへのパスワードなしのログインを設定します🎜🎜イントラネット上のマシン A で実行します:🎜rrreee🎜以前に設定したポートによると、このコマンドは次のとおりです 🎜rrreee🎜🎜🎜それではログインします。イントラネット上のマシン A から SSH 経由で外部ネットワーク上のマシン B はパスワードなしでログインできます~
パスワードなしでログインできるかどうかを確認するには、次のコマンドを使用して確認できます: 🎜rrreee🎜🎜🎜6.2 autossh を使用して安定したトンネルを確立する🎜🎜centos7 には autossh がありません
はデフォルトでインストールされるので、次のコマンドを使用してインストールします🎜rrreee🎜 具体的な autossh の手順を見てみましょう: 🎜rrreee🎜 autossh
のパラメータは ssh のパラメータと同じですただし、違いは、トンネルが切断されると、autossh は自動的に再接続しますが、ssh 会議は行わないことです。もう 1 つの違いは、-M パラメータです。このパラメータは、トンネルが正常でない場合に、外部ネットワーク上のマシン B が情報を受信するために使用するポートを指定します。再接続するためにマシン A に戻されます。 🎜🎜🎜🎜🎜7. 最後に、起動時に autossh を自動的に開始するように Linux を設定します。 , Linux の再起動後に自分で autossh を起動する手間が省けます🎜🎜Input:🎜🎜vi /etc/rc.d/rc.local
🎜🎜Add content:🎜🎜autossh - M 7281 - fCNR 7280:localhost:22 root@123.123.123.123
🎜🎜🎜centos7以降は、/etc/rc.d/rc.local
起動スクリプトを直接変更すると自動的に有効になるためが変更されている場合は、実行権限を再度付与する必要があります🎜🎜🎜し、<a href="http://www.php.cn/wiki/1294.html" target="_blank">chmod🎜を入力する必要があります+x /etc/rc.d/rc.local</a>
🎜🎜🎜 8. 結論: 🎜🎜🎜 が最終的に設定されるかどうかは不明ですが、明日どうなるか見てみましょう🎜。 。何か間違っている場合は、修正してください~🎜🎜🎜🎜以下のWebサイトを参照してください🎜🎜外部ネットワークからLANにSSH接続する、リバースプロキシ+フォワードプロキシソリューション🎜イントラネット侵入に SSH リバース トンネルを使用する
以上がssh リバース プロキシと autossh を使用して外部ネットワークから内部ネットワークに接続するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。