端口转发¶
端口转发根据协议类型分为TCP和UDP端口转发,根据转发类型又分为本地转发和远程转发,总共有四种组合。
本地端口转发¶
TCP¶
可以设置单一的转发目标地址进行一对一端口转发
将本地的TCP端口8080映射到192.168.1.1的80端口,所有到本地8080端口的数据会被转发到192.168.1.1:80。
也可以设置多个目标地址进行一对多端口转发
在每次收到转发请求后,会利用转发器中的节点选择器在目标地址列表中选择一个节点作为本次转发的目标地址。
UDP¶
和TCP端口转发类似,也可以指定单个和多个目标转发地址。
keepalive
(bool, default=false)- 每一个客户端对应一条转发通道,当
keepalive
参数设置为false
时(默认情况),请求的响应数据返回给客户端后会立即关闭通道连接。 ttl
(duration, default=5s)- 当
keepalive
参数设置为true
时,转发服务一定时间内收不到转发目标主机数据,此转发通道会被标记为空闲状态。转发服务内部会按照ttl
参数(默认值5秒)指定的周期检查转发通道是否空闲,如果空闲则此通道将被关闭。一个空闲通道最多会在两个检查周期内被关闭。 readBufferSize
(int, default=4096)- UDP读缓冲区大小,同时也是UDP数据包大小的上限,如果数据包大小超过此设定值,数据会被截断。
转发链¶
端口转发可以配合转发链进行间接转发。
将本地的TCP端口8080通过转发链映射到192.168.1.1的80端口。
将本地的UDP端口10053通过转发链映射到192.168.1.1的53端口。
限制
当UDP本地端口转发中使用转发链时,转发链末端最后一个节点必须是以下类型:
- GOST HTTP代理服务并开启了UDP转发功能,采用UDP-over-TCP方式。
- GOST SOCKS5代理服务并开启了UDP转发功能,采用UDP-over-TCP方式。
- Relay服务,采用UDP-over-TCP方式。
- SSU服务。
UDP-over-TCP
UDP-over-TCP是指使用TCP连接来传输UDP数据包。在GOST中这个说法可能并不太准确,例如使用SOCKS5进行UDP端口转发,SOCKS5服务可以是基于TCP类型的传输通道(TLS, Websocket等),也可以是基于UDP类型的传输通道(KCP, QUIC等),这里使用UDP-over-Stream更合适一些(相对于UDP不可靠的数据报式传输来说),任何可靠的流式传输协议均可以用在此处。
SSH¶
TCP端口转发可以借助于标准SSH协议的端口转发功能进行间接转发
services:
- name: service-0
addr: :8080
handler:
type: tcp
chain: chain-0
listener:
type: tcp
forwarder:
nodes:
- name: target-0
addr: 192.168.1.1:80
chains:
- name: chain-0
hops:
- name: hop-0
nodes:
- name: node-0
addr: 192.168.1.2:22
connector:
type: sshd
dialer:
type: sshd
auth:
username: user
password: pass
这里的192.168.1.2:22服务可以是系统本身的标准SSH服务,也可以是GOST的sshd类型服务
远程端口转发¶
TCP¶
将本地的TCP端口8080映射到192.168.1.1的80端口,所有到本地8080端口的数据会被转发到192.168.1.1:80。
UDP¶
注意
在不使用转发链的情况下,远程端口转发与本地端口转发没有区别。
转发链¶
根据rtcp服务指定的地址,通过转发链在主机192.168.1.2上监听8080TCP端口。当收到请求后再通过转发链将数据转发给rtcp服务,rtcp服务再将请求转发到192.168.1.1:80端口。
根据rudp服务指定的地址,通过转发链在主机192.168.1.2上监听10053端口。当收到请求后再通过转发链将数据转发给rudp服务,rudp服务再将请求转发到192.168.1.1:53端口。
注意
远程端口转发上的转发链默认设置在监听器上,此时处理器上也可以再设置另外的转发链。
远程端口转发服务中的监听地址,在使用转发链时将监听在转发链末端最后一个节点服务所在的主机上。
限制
当远程端口转发中使用转发链时,转发链末端最后一个节点必须是以下类型:
- GOST SOCKS5代理服务并开启了BIND功能,采用UDP-over-TCP方式。
- Relay服务并开启了BIND功能,采用UDP-over-TCP方式。
SSH¶
TCP远程端口转发可以借助于标准SSH协议的远程端口转发功能进行间接转发
services:
- name: service-0
addr: :8080
handler:
type: rtcp
listener:
type: rtcp
chain: chain-0
forwarder:
nodes:
- name: target-0
addr: 192.168.1.1:80
chains:
- name: chain-0
hops:
- name: hop-0
nodes:
- name: node-0
addr: 192.168.1.2:22
connector:
type: sshd
dialer:
type: sshd
auth:
username: user
password: pass
这里的192.168.1.2:22服务可以是系统本身的标准SSH服务,也可以是GOST的sshd类型服务。
端口范围¶
命令行模式下支持使用端口范围格式。
多对一转发¶
等价于
services:
- name: service-0
addr: :8000
handler:
type: tcp
listener:
type: tcp
forwarder:
nodes:
- name: target-0
addr: 192.168.1.1:8000
- name: service-1
addr: :8001
handler:
type: tcp
listener:
type: tcp
forwarder:
nodes:
- name: target-0
addr: 192.168.1.1:8000
- name: service-2
addr: :8002
handler:
type: tcp
listener:
type: tcp
forwarder:
nodes:
- name: target-0
addr: 192.168.1.1:8000
- name: service-3
addr: :8003
handler:
type: tcp
listener:
type: tcp
forwarder:
nodes:
- name: target-0
addr: 192.168.1.1:8000
多对多转发¶
多对多转发会根据定义的端口范围按顺序进行一对一映射。如果目标端口范围大于监听端口范围,则多余部分会被忽略。
在下面的例子中,8000-8003端口会按顺序依次映射到192.168.1.1:8000-8003,而192.168.1.1:8004-8010会被忽略。
等价于
services:
- name: service-0
addr: :8000
handler:
type: tcp
listener:
type: tcp
forwarder:
nodes:
- name: target-0
addr: 192.168.1.1:8000
- name: service-1
addr: :8001
handler:
type: tcp
listener:
type: tcp
forwarder:
nodes:
- name: target-1
addr: 192.168.1.1:8001
- name: service-2
addr: :8002
handler:
type: tcp
listener:
type: tcp
forwarder:
nodes:
- name: target-2
addr: 192.168.1.1:8002
- name: service-3
addr: :8003
handler:
type: tcp
listener:
type: tcp
forwarder:
nodes:
- name: target-3
addr: 192.168.1.1:8003
服务端转发¶
以上的转发方式可以看作是客户端转发,由客户端来控制转发的目标地址。目标地址也可以由服务端指定。
服务端¶
客户端¶
forward类型连接器和处理器
这里服务的处理器和转发链的连接器必须为forward
类型,由于目标地址由服务端指定,因此客户端无需指定目标地址。forward
连接器不做任何逻辑处理。
这里的tcp://:8080
等同于tcp://:8080/:0
,转发目标地址:0
在这里作为占位符。仅当配合forward
连接器使用时,这种用法才是有效的。