rein 多平台支持的超便携端口转发与内网穿透工具
介绍
本程序主要用于进行反向代理IP地址和端口,功能类似于 nginx 的 stream 模式和rinetd 的功能;在(1.0.5)版本开始,rein支持内网穿透,这一功能类似于frp 和ngrok。由于rein使用了golang语言开发,并且提供已经编译好的可下载版本,在部署配置方面比它们要方便些。
功能列表:
- 反向代理
IP和端口(upstream模式)。 - 提供本地文件的快速网络(
http协议)分享(fileshare模式)。 - 内网穿透(
inps / inpc模式)
rein支持模式:
| 模式 | 说明 |
|---|---|
upstream |
反向代理模式 |
fileshare |
提供本地文件的快速网络(http协议)分享 |
inps |
内网穿透的服务器端,inps 需要部署在有公网地址服务器上(版本 >= 1.0.5) |
inpc |
内网穿透的客户机端,inpc 部署在能访问互联网,没有公网 IP 地址的 PC 或服务器上(版本 >= 1.0.5) |
inps和inpc模式图解:
1. 根据你的操作系统下载指定可执行文件
所有操作系统版本的压缩包下载网址: https://note.youdao.com/ynoteshare1/index.html?id=e11547282e63ce5920c5c2755a5cd89a&type=note
1.1 根据操作系统下载
- 1.1.1 在 CentOS/RHEL/Ubuntu 平台下载
cd ~
wget \
http://note.youdao.com/yws/public/resource/e11547282e63ce5920c5c2755a5cd89a/xmlnote/18F3E51677BC41B3B1FE0F6B7DE359F5/27478 -O rein.zip
unzip rein.zip
chmod +x rein
1.1.2 在 Windows 平台下载
打开浏览器,在地址栏输入下面的地址后下载
解压压缩包
rein-x.x.x-amd64-windows.zip
2. 简单部署
2.1 确定你需要的功能进行部署
- 三种模式说明
| 功能模式 | 说明 |
|---|---|
upstream |
反向代理 |
fileshare |
提供本地文件的快速网络(http协议)分享 |
inps/inpc |
内网穿透 (服务器端/客户端) (版本 >= 1.0.5) |
2.2 具体功能模式说明
说明: 不同操作系统的操作存在差异, 在后续的介绍中,CentOS/RHEL/Ubuntu,将会被作为默认操作。 不过 2.2.1 将仍然分开介绍。
下面是主要的差异操作部分:
# 在 CentOS/RHEL/Ubuntu下, 显示所有模式, 以 upstream 模式为例
./rein -e-detail
./rein -e-detail-upstream # 在 CentOS/RHEL/Ubuntu 下,生成配置文件,以 upstream 模式为例
./rein -e-detail-upstream > rein.json ##################################################### # 在 Windows 模式下, 显示所有模式, 以 upstream 模式为例
./rein.exe -e-detail
./rein.exe -e-detail-upstream # 在 CentOS/RHEL/Ubuntu 下,生成配置文件,以 upstream 模式为例
# 使用 Windows cmd
./rein.exe -e-detail-upstream > rein.json # 使用 Windows powershell
./rein.exe -e-detail-upstream | out-file -encoding ascii rein.json
2.2.1 使用
upstream模式使用
-e-detail-xxx选项,产生配置文件并运行。在 CentOS/RHEL/Ubuntu 下部署
# 显示所有模式
./rein -e-detail
Enter a mode, show specific example, as follow:
-e-detail-upstream
-e-detail-inps
-e-detail-inpc
-e-detail-fileshare # 生成配置文件,以 upstream 模式为例
./rein -e-detail-upstream > rein.json # 修改 rein.json 配置文件以符合你的需要
{
"upstream": [
{"source": "0.0.0.0:8150", "target": "127.0.0.1:9990"}
]
} # 运行 rein
./rein -c rein.json
在 Windows 下运行
# 显示所有模式
./rein.exe -e-detail
Enter a mode, show specific example, as follow:
-e-detail-upstream
-e-detail-inps
-e-detail-inpc
-e-detail-fileshare # 生成配置文件,以 upstream 模式为例
# 使用 windows cmd
./rein.exe -e-detail-upstream > rein.json # 使用 windows powershell
./rein.exe -e-detail-upstream | out-file -encoding ascii rein.json # 修改 rein.json 配置文件以符合你的需要
{
"upstream": [
{"source": "0.0.0.0:8150", "target": "127.0.0.1:9990"}
]
} # 运行 rein
./rein.exe -c rein.json
2.2.2 使用
fileshare模式# 显示默认的示例配置
./rein -e-detail-fileshare
{
"fileshare": [
{"port": "9990", "path": "."}
]
} # 生成配置文件
./rein -e-detail-fileshare > rein.json # 修改 rein.json 配置文件以符合你的需要
{
"fileshare": [
{"port": "9990", "path": "."}
]
} # 运行 rein
./rein -c rein.json2.2.3 使用
inps/inpc模式举例:假设你有一台服务器(A),有一个公网IP地址是
52.74.223.119, 然后你还有一台服务器或PC是(B),它的IP地址是192.168.1.122(这是一个局域网IP,它没有公网IP,不过它可以访问互联网).把
inps部署在服务器(A),把inpc部署在服务器或PC(B).用图来解释下:
- inps的部署命令
Put
inpsonto your server A with public IP.# 生成配置文件
./rein -e-detail-inps > rein.json # 修改 rein.json 配置文件以符合你的需要
{
"inps": [
{"ctrl": "0.0.0.0:17500"}
]
} # 运行 rein
./rein -c rein.json- inpc的部署命令
# 生成配置文件
./rein -e-detail-inpc > rein.json # 修改 rein.json 配置文件以符合你的需要
# 端口 17500 是部署在服务器(A)上开放的 'inps' 服务端口
# 端口 22 是服务器(B)本地端口
# 端口 9800 是通过 'inps' 服务开放的端口,直接映射到服务器(B)的22端口
{
"inpc": [
{
"ctrl": "52.74.223.119:17500",
"source": "0.0.0.0:9800",
"target": "127.0.0.1:22"
}
]
} # 运行 rein
./rein -c rein.json
rein 多平台支持的超便携端口转发与内网穿透工具的更多相关文章
- NAT、端口映射、内网穿透、公网IP都是啥
原文地址:https://wuter.cn/1756.html/ 一.IPv4地址 IP协议是为计算机网络相互连接进行通信而设计的协议,它是能使连接到网上的所有计算机网络实现相互通信的一套规则. 这里 ...
- LCX端口转发实现内网突破
工具:lcx.exe 原理:当目标主机仅开放了web服务,而该服务又仅能供内网用户使用,外网用户根本无法直接访问.因此想要让外网用户能能够访问局域网中的系统服务,必须进行端口映射等操作才行.其原理就是 ...
- Rinetd 通过ECS端口转发到内网RDS
前置条件 实现目的:开发本地电脑需要连接没有外网地址的RDS,通过ECS进行转发连接到RDS数据库 客户 PC 终端可以 ssh 登录有公网的 ECS 服务器. 有公网的 ECS 服务器可以通过内网访 ...
- 内网穿透神器(ngrok)服务端部署【分享一台自己的ngrok服务器】【多平台】
Ngrok为何物 “ngrok 是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道.ngrok 可捕获和分析所有通道上的流量,便于后期分析和重放.”这是百度百科上给Ng ...
- Frp内网穿透搭建,家庭主机对外提供接口,支持ssh访问
Frp内网穿透搭建,家庭主机对外提供接口,支持ssh访问 1.使用场景: 需求1.家中服务器 ubuntu 主机,跑接口服务,需要对外暴漏, 需求2.同时需要在外网ssh远程 关键词: frp内网 ...
- SSH 端口转发+内网穿透
用最直白的语言对本文所有内容进行定义: 端口转发(-L):用A机器(内网)登录B机器(公网), 在A机器打开端口,将收到的所有请求转发到B机器的某个端口 (在代理机上执行) 内网穿透(-R):用A机器 ...
- 感觉差不多了。CLOUDSTACK的NAT,端口转发和防火墙结合穿透
构架差不多OK啦. 测试也近尾声啦. 感觉它适合私有云,或是混合云,但结合了SDN的网络,真的很安全. 如果是纯公有云,也是更适合特定方案.或是要第二次开发,毕竟让ACCOUNT登陆到后台,结合GUE ...
- ssh 端口转发实现外网 80 端口映射到内网 80 端口
开发中经常需要外网服务映射到本机内网服务的需要,便于调试. 以前都是同事帮着配,这两天自己也看了一下 ssh 端口转发. 同事分分钟钟搞定的事情,自己折腾了 2 天, 真是弱爆了. 最初老想不明白一件 ...
- firewalld 实现nat 转发外网转发到内网 实现访问外网端口到内网
第0步骤: 开启转发生效 [root@node178.oldboy.com ~]# cat /proc/sys/net/ipv4/ip_forward1 [root@node178.oldboy.c ...
随机推荐
- 12、Linux磁盘设备基础知识(2)
12.4.计算磁盘容量: 磁盘的大小=盘面大小*磁头数 盘面的大小=磁道大小*磁道数 磁道大小=512字节*扇区数 磁盘的大小=512字节*扇区数*磁道数*磁头数 磁盘的大小=柱面大小*柱面数 柱面大 ...
- 收集雪花(map)
题目描述 不同的雪花往往有不同的形状.在北方的同学想将雪花收集起来,作为礼物送给在南方的同学们.一共有n个时刻,给出每个时刻下落雪花的形状,用不同的整数表示不同的形状.在收集的过程中,同学们不希望有重 ...
- js jquey 笔记
1.使用insertAfter 如果插入在tr后添加多行数据,数据会倒过来注意组字符串需要倒着循环 1).html方法,给元素添加html代码或者清空html代码(参数为空字符串): 2).appen ...
- ansible 常用命令
ansible 命令集 #Ansibe AD-Hoc 临时命令执行工具,常用于临时命令的执行 /usr/bin/ansible #Ansible 模块功能查看工具 /usr/bin/ansible-d ...
- Springboot:单元测试Junit基本注解@BeforeClass、@AfterClass、@Before、@After、@Test、
一.unit中集中基本注解,是必须掌握的. @BeforeClass – 表示在类中的任意public static void方法执行之前执行 @AfterClass – 表示在类中的任意public ...
- 记一次Struts中文乱码
起因 最近公司一个智能家具的项目,需要开发后端,APP/WEB的所有请求通过HTPP发送到后台,后台通过socket连接到智能设备.公司只有一个Java技术栈的同事,而他负责设备方面,我只能赶鸭子上架 ...
- leetcode1047
思路分析,这题是在栈分类的题目的,所以顺便复习下数据结构,先用java现成的,就当复习了. 1.判断栈顶和插入的元素是否相等,如果相等,那就出栈,不相等入栈结束 java版:
- gitlab用户,组,项目权限管控
前言:gitlab上的权限管控是非常重要的,尤其是很多研发人员开发一个项目.这个是我总结的权限管控. 1.这个是创建项目时开放权限设置 2.这个创建用户设置的权限 3.用户权限,5种类型用户是 ...
- windows服务器下MySQL配置字符集
这俩天公司使用.netcore微服务+mysql做项目,mysql在使用的时候总是出现一些字符集的问题,修改utf8或utf8mb4后mysql的服务就启动不了,这里做下记录如果把my.ini中的字符 ...
- python使用笔记22--mock接口开发
1.mock接口开发 mock是模拟一个接口的意思 为了不阻止测试,开发一个接口,返回你想要的数据,模拟各种场景 需要安装第三方模块flask,flask是web轻量级开发框架 1.1 flask p ...