quick_start_zh.md 4.5 KB

frp 使用文档

相比于其他项目而言 frp 更易于部署和使用,这里我们用两个简单的示例来演示 frp 的使用过程。

  1. 如何通过一台拥有公网IP地址的服务器B,访问处于公司内部网络环境中的服务器Assh端口,服务器B的IP地址为 x.x.x.x(测试时替换为真实的IP地址)。
  2. 如何利用一台拥有公网IP地址的服务器B,使通过 web01.yourdomain.com 可以访问内网环境中服务器A8000端口的web服务,web02.yourdomain.com 可以访问服务器A8001端口的web服务。

下载源码

推荐直接使用 go get github.com/fatedier/frp 下载源代码安装,执行命令后代码将会拷贝到 $GOPATH/src/github.com/fatedier/frp 目录下。

或者可以使用 git clone https://github.com/fatedier/frp.git $GOPATH/src/github.com/fatedier/frp 拷贝到相应目录下。

如果您想快速进行测试,也可以根据您服务器的操作系统及架构直接下载编译好的程序及示例配置文件,https://github.com/fatedier/frp/releases

编译

进入下载后的源码根目录,执行 make 命令,等待编译完成。

编译完成后, bin 目录下是编译好的可执行文件,conf 目录下是示例配置文件。

依赖

  • go 1.4 以上版本
  • godep (如果检查不存在,编译时会通过 go get 命令安装)

部署

  1. 将 ./bin/frps 和 ./conf/frps.ini 拷贝至服务器B任意目录。
  2. 将 ./bin/frpc 和 ./conf/frpc.ini 拷贝至服务器A任意目录。
  3. 根据要实现的功能修改两边的配置文件,详细内容见后续章节说明。
  4. 在服务器B执行 nohup ./frps & 或者 nohup ./frps -c ./frps.ini &
  5. 在服务器A执行 nohup ./frpc & 或者 nohup ./frpc -c ./frpc.ini &
  6. 通过 ssh -oPort=6000 {user}@x.x.x.x 测试是否能够成功连接服务器A({user}替换为服务器A上存在的真实用户),或通过浏览器访问自定义域名验证 http 服务是否转发成功。

tcp 端口转发

转发 tcp 端口需要按照需求修改 frps 和 frpc 的配置文件。

配置文件

frps.ini

[common]
bind_addr = 0.0.0.0
# 用于接收 frpc 连接的端口
bind_port = 7000
log_file = ./frps.log
log_level = info

# ssh 为代理的自定义名称,可以有多个,不能重复,和frpc中名称对应
[ssh]
auth_token = 123 
bind_addr = 0.0.0.0
# 最后将通过此端口访问后端服务
listen_port = 6000

frpc.ini

[common]
# frps 所在服务器绑定的IP地址
server_addr = x.x.x.x
server_port = 7000
log_file = ./frpc.log
log_level = info
# 用于身份验证
auth_token = 123 

# ssh 需要和 frps.ini 中配置一致
[ssh]
# 需要转发的本地端口
local_port = 22
# 启用加密,frpc与frps之间通信加密,默认为 false
use_encryption = true

http 端口转发,自定义域名绑定

如果只需要一对一的转发,例如服务器B80端口转发服务器A8000端口,则只需要配置 tcp 端口转发 即可,如果需要使服务器B80端口可以转发至多个web服务端口,则需要指定代理的类型为 http,并且在 frps 的配置文件中配置用于提供 http 转发服务的端口。

按照如下的内容修改配置文件后,需要将自定义域名的 A 记录解析到 [server_addr],如果 [server_addr] 是域名也可以将自定义域名的 CNAME 记录解析到 [server_addr]。

之后就可以通过自定义域名访问到本地的多个 web 服务。

配置文件

frps.ini

[common]
bind_addr = 0.0.0.0
bind_port = 7000
# 如果需要支持http类型的代理则需要指定一个端口
vhost_http_port = 80
log_file = ./frps.log
log_level = info

[web01]
# type 默认为 tcp,这里需要特别指定为 http
type = http
auth_token = 123
# 自定义域名绑定,如果需要同时绑定多个以英文逗号分隔
custom_domains = web01.yourdomain.com

[web02]
type = http
auth_token = 123
custom_domains = web02.yourdomain.com

frpc.ini

[common]
server_addr = x.x.x.x
server_port = 7000
log_file = ./frpc.log
log_level = info
auth_token = 123 


# 自定义域名在 frps.ini 中配置,方便做统一管理
[web01]
type = http
local_ip = 127.0.0.1
local_port = 8000
# 可选是否加密
use_encryption = true

[web02]
type = http
local_ip = 127.0.0.1
local_port = 8001