https://github.com/ys928/stab
一个简单、小巧、用户友好、高性能的TCP隧道工具,可轻松将本地端口暴露给远程服务器。A simple, compact, user-friendly, high-performance TCP tunneling tool that easily exposes local ports to remote servers 。
https://github.com/ys928/stab
cli localhost network proxy rust tcp tunnel
Last synced: 9 months ago
JSON representation
一个简单、小巧、用户友好、高性能的TCP隧道工具,可轻松将本地端口暴露给远程服务器。A simple, compact, user-friendly, high-performance TCP tunneling tool that easily exposes local ports to remote servers 。
- Host: GitHub
- URL: https://github.com/ys928/stab
- Owner: ys928
- License: mit
- Created: 2024-03-31T01:55:05.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2025-02-06T09:07:33.000Z (11 months ago)
- Last Synced: 2025-04-24T05:14:28.646Z (9 months ago)
- Topics: cli, localhost, network, proxy, rust, tcp, tunnel
- Language: Rust
- Homepage:
- Size: 116 KB
- Stars: 9
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
README
中文
•
English
# stab
这是一个现代、简单、小巧的高性能 TCP 隧道工具,可轻松将本地端口暴露给远程服务器。
主要特点:
- 人性化
- 性能极高
- 心跳检测
- 流量统计
- 允许手动断开链接
- 允许暴露多个本地端口
下图为stab与[bore](https://github.com/ekzhang/bore)之间的性能对比:

环境为wsl ubuntu 24.04,压测命令为:
```bash
ab -n 100000 -c 5000 http://127.0.0.1:2000/
```
### 1.安装
如果你安装了 rust 开发环境,那么使用 cargo 命令是最简单的方式:
```bash
cargo install stab
```
如果没有 cargo,那么你可以直接去[release](https://github.com/ys928/stab/releases)下载已经编译好的程序使用。
### 2.服务器
你可以在你的服务器上运行下面这个命令:
```bash
stab server
```
这将启动 stab 的服务器模式,其默认的控制端口为 5746,但您可以修改:
```bash
stab server -c 7777
```
运行成功后,你将看到下面这样的输出:
```bash
15:52:21 [INFO] stab::server:62 => server listening 0.0.0.0:5656
15:52:21 [INFO] stab::web:29 => web server:http://localhost:3400
```
其中`0.0.0.0:5656`代表控制端口,而`http://localhost:3400`则代表 web 服务,你可以打开该链接查看当前所有连接到本服务器的客户端信息,并可以主动手动断开该链接:

### 3.本地
然后你可以在本地运行下面这条命令:
```bash
stab local -l 8000=server.com
```
上面命令为简写形式,其完整的格式为:
```bash
stab local --link 127.0.0.1:8000=server.com:0
```
该命令会把你的本地`127.0.0.1:8000`端口与你的`server.com:0`进行链接,这是默认行为,此时端口将由服务器自动分配。
当然你也可以指定服务器需要暴露端口:
```bash
stab local --link 127.0.0.1:8000=server.com:7878
```
如果你的服务器更改了默认的控制端口,那么这里也应该更改:
```bash
stab local -c 7777 --link 8000=server.com
```
### 4.示例
假设你在`server.com`中启动了 stab 服务器模式:
```bash
stab server
```
并且你在本地端口 8000 启动了一个 web 服务器,之后你就可以通过`stab`连接到服务器来暴露本地的 web 服务:
```bash
stab local -l 8000=server.com
```
当你成功连接到服务器后,你将得到类似下面这样的日志输出:
```bash
15:54:59 [INFO] stab::client:101 => 127.0.0.1:8000 link to server.com:1024
```
此时,你就能通过 `server.com:1024` 访问到你的本地 web 服务。
### 5.密钥
为了防止被别人滥用,你可以添加一个密钥:
```bash
stab server -s test
```
此时客户端就必须填入密钥才能连接到服务器:
```bash
stab local -l 8000=your.server.com -s test
```
### 6.Toml 配置(推荐)
除了使用命令行参数外,你可以通过 toml 配置文件的方式配置所有选项。
服务器配置文件实例`server.toml`:
```toml
mode = "Server" # 选择服务器模式
port = 5959 # 设置控制端口
secret = "test secret" # 设置密钥
log = 5 # 设置日志等级:1-5,默认为5
log_path = "logs" # 设置日志保存位置,默认为当前目录下的logs目录
[server]
web_port = 80 # 设置web端口
port_range = "2000-3000" # 设置允许使用的端口范围
pool_size = 8 # 设置连接池大小,默认8个
```
应用该配置文件:
```bash
stab -f server.toml
```
本地配置文件实例`local.toml`:
```toml
mode = "Local" # 选择本地模式
port = 5959 # 设置控制端口
secret = "test secret" # 设置密钥
log = 5 # 设置日志等级:1-5,默认为5
log_path = "logs" # 设置日志保存位置,默认为当前目录下的logs目录
[local]
to = "server.com" # 设置默认服务器
links = [
"127.0.0.1:8080=server.com:2000", # 完整写法
"8080=server.com:1900", # 等价于:127.0.0.1:8080=server.com:1900
"8081=server.com", # 等价于:127.0.0.1:8081=server.com:0
"8082=2001", # 等价于:127.0.0.1:8082={to}:2001
"8083", # 等价于:127.0.0.1:8083={to}:0
] # 设置将要与服务器建立的链接,支持同时建立多个链接
```
应用该配置文件:
```bash
stab -f local.toml
```