赞
踩
内网穿透是指在内部网络(内网)中实现穿透外网(公网)的通信。内网通常是指公司、组织或家庭等内部网络,而外网则是指互联网,也就是公共网络。内网穿透的目的是让位于内网中的设备或应用程序能够访问外部网络中的资源,实现内外网的通信。
实现内网穿透的方法有很多,以下是一些常见的内网穿透技术:
frp是一款免费开源的专注于内网穿透的高性能的反向代理应用,支持 TCP、UDP、HTTP、HTTPS、Websocket、P2P 等多种协议。可以将内网服务以安全、便捷的方式通过具有公网 IP 节点的中转暴露到公网。
frp是基于C/S模式实现的内网穿透服务代理应用,通过在公网IP上部署服务器端应用,客户端部署在内网上。当访问服务端暴露的应用时,反向代理到内网的服务实现内网穿透的代理。
在frp中,分为客户端frpc
和服务端fprs
,frp应用支持以toml
配置文件的方式和参数的方式进行服务部署。frp应用通过-c
参数指定配置文件进行读取
frps -c frps.toml
frpc -c frpc.toml
在部署frps
时,需要指定绑定端口用于接收客户端连接,默认情况下绑定端口为7000
,当需要修改用于客户端连接的端口时,可以修改此配置。在配置文件中通过bindPort
参数进行配置
# frps.toml
bindPort = 7000
通过docker compose部署
version: '3.9'
services:
frps:
image: fatedier/frps:v0.53.2
hostname: frps
container_name: frps
volumes:
- "./frps.toml:/frps.toml"
command:
- "-c"
- "/frps.toml"
ports:
- "7000:7000"
同样的,frp也支持在启动时直接以参数的方式进行服务部署,通过--bind_port
可以设置frps
的绑定端口
frps --bind_port 7000
通过docker compose部署
version: '3.9'
services:
frps:
image: fatedier/frps:v0.53.2
hostname: frps
container_name: frps
command:
- "--bind_port"
- "7000"
ports:
- "7000:7000"
在frpc
客户端中,主要配置为
frps
连接信息在frpc
中需要配置的内容相对较多,推荐以文件的方式进行配置,以下是frpc.toml
的简单示例
# 服务端地址
serverAddr = "x.x.x.x"
# 服务端配置的bindPort
serverPort = 7000
[[proxies]]
# 代理应用名称,根据自己需要进行配置
name = "ssh"
# 代理类型
type = "tcp"
# 客户端代理应用IP
localIP = "127.0.0.1"
# 客户端代理应用端口
localPort = 8080
# 服务端反向代理端口
remotePort = 7001
如上述示例所示,为客户端frpc
代理配置,通过tcp协议的方式将本地8080端口服务代理到serverAddr:7001
上,代理后,可以通过serverAddr:7001
直接在公网上访问到本地服务。
通过docker compose部署frpc应用:
version: '3.9'
services:
frpc:
image: fatedier/frpc:v0.53.2
hostname: frpc
container_name: frpc
volumes:
- "./frpc.toml:/frpc.toml"
command:
- "-c"
- "/frpc.toml"
network_mode: "host"
fatedier/frpc
镜像在启动时,直接运行frpc
命令,frpc
命令到默认配置文件默认参数为./frpc.ini
文件,所以必须要挂载配置文件到容器内,否则无法直接启动frpc
服务frpc
进行内网穿透,frpc
需要可以直接访问到需要内网穿透代理到应用,所以采用network_mode: host
参数将frpc
服务到网络设置为宿主机网络,否则容器内无法直接访问宿主机上的应用,网络根据代理应用进行配置
network_mode: host
对应的网络为虚拟机网络,而不是宿主机网络,所以该参数在Mac、Windows系统上不受支持,可以考虑直接以应用的方式在以上系统部署serverAddr:remotePort
,bindPort
仅用于frp交互使用,所以在上面的frps
通过docker方式中,需要将内网对应的remotePort
和宿主机关联配置好
frps
指定ports
时可以考虑给定范围的方式进行部署更多frp部署应用方式请参考frp 官方文档
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。