Frp官方中文文档

举报
正本清源 发表于 2019/03/26 14:59:06 2019/03/26
【摘要】 FRP官方中文文档

frp 是一个可用于内网穿透的高性能的反向代理应用,支持 tcp, udp, http, https 协议。

frp 的作用

  • 利用处于内网或防火墙后的机器,对外网环境提供 http 或 https 服务。

  • 对于 http, https 服务支持基于域名的虚拟主机,支持自定义域名绑定,使多个域名可以共用一个80端口

  • 利用处于内网或防火墙后的机器,对外网环境提供 tcp 和 udp 服务,例如在家里通过 ssh 访问处于公司内网环境内的主机。

架构

architecture

使用示例

将 frps 及 frps.ini 放到具有公网 IP 的机器上。

将 frpc 及 frpc.ini 放到处于内网环境的机器上。


通过 ssh 访问公司内网机器

修改 frps.ini 文件,这里使用了最简化的配置:

        # frps.ini
        [common]
        bind_port = 7000

启动 frps:./frps -c ./frps.ini


修改 frpc.ini 文件,假设 frps 所在服务器的公网 IP 为 x.x.x.x;

        # frpc.ini
        [common]
        server_addr = x.x.x.x
        server_port = 7000
        
        [ssh]
        type = tcp
        local_ip = 127.0.0.1
        local_port = 22
        remote_port = 6000

启动 frpc:./frpc -c ./frpc.ini


通过 ssh 访问内网机器,假设用户名为 test:ssh -oPort=6000 test@x.x.x.x


通过自定义域名访问部署于内网的 web 服务

有时想要让其他人通过域名访问或者测试我们在本地搭建的 web 服务,

但是由于本地机器没有公网 IP,无法将域名解析到本地的机器,

通过 frp 就可以实现这一功能,

以下示例为 http 服务,https 服务配置方法相同, vhost_http_port 替换为 vhost_https_port, type 设置为 https 即可


修改 frps.ini 文件,设置 http 访问端口为 8080:

# frps.ini
[common]
bind_port = 7000
vhost_http_port = 8080


启动 frps;./frps -c ./frps.ini

修改 frpc.ini 文件,假设 frps 所在的服务器的 IP 为 x.x.x.x,local_port 为本地机器上 web 服务对应的端口, 绑定自定义域名 www.yourdomain.com:

# frpc.ini
[common]
server_addr = x.x.x.x
server_port = 7000

[web]type = http
local_port = 80
custom_domains = 
www.yourdomain.com

启动 frpc:./frpc -c ./frpc.ini

将 www.yourdomain.com 的域名 A 记录解析到 IP x.x.x.x

如果服务器已经有对应的域名,也可以将 CNAME 记录解析到服务器原先的域名。

通过浏览器访问 http://www.yourdomain.com:8080 即可访问到处于内网机器上的 web 服务。


转发 DNS 查询请求

DNS 查询请求通常使用 UDP 协议,frp 支持对内网 UDP 服务的穿透,配置方式和 TCP 基本一致。


修改 frps.ini 文件:

# frps.ini
[common]
bind_port = 7000


启动 frps:./frps -c ./frps.ini

修改 frpc.ini 文件,设置 frps 所在服务器的 IP 为 x.x.x.x,转发到 Google 的 DNS 查询服务器 8.8.8.8 的 udp 53 端口:

# frpc.ini
[common]
server_addr = x.x.x.x
server_port = 7000

[dns]
type = udp
local_ip = 8.8.8.8
local_port = 53
remote_port = 6000


启动 frpc:./frpc -c ./frpc.ini

通过 dig 测试 UDP 包转发是否成功,预期会返回 www.google.com 域名的解析结果:

dig @x.x.x.x -p 6000 www.google.com



转发 Unix域套接字

通过 tcp 端口访问内网的 unix域套接字(例如和 docker daemon 通信)。

frps 的部署步骤同上。

启动 frpc,启用 unix_domain_socket 插件,配置如下:

# frpc.ini
[common]
server_addr = x.x.x.x
server_port = 7000

[unix_domain_socket]
type = tcp
remote_port = 6000
plugin = unix_domain_socket
plugin_unix_path = /var/run/docker.sock


通过 curl 命令查看 docker 版本信息 curl http://x.x.x.x:6000/version



对外提供简单的文件访问服务

通过 static_file 插件可以对外提供一个简单的基于 HTTP 的文件访问服务。

frps 的部署步骤同上。

启动 frpc,启用 static_file 插件,配置如下:

要对外暴露的文件目录


访问 url 中会被去除的前缀,
保留的内容即为要访问的文件路径

通过浏览器访问 http://x.x.x.x:6000/static/ 

来查看位于 /tmp/file 目录下的文件,

会要求输入已设置好的用户名和密码。


安全地暴露内网服务

对于某些服务来说如果直接暴露于公网 上将会存在安全隐患。

使用 stcp(secret tcp) 类型的代理可以避免让任何人都能访问到要穿透的服务,

但是访问者也需要运行另外一个 frpc。

以下示例将会创建一个只有自己能访问到的 ssh 服务代理。

frps 的部署步骤同上。


启动 frpc,转发内网的 ssh 服务,

配置如下,不需要指定远程端口:

# frpc.ini
[common]
server_addr = x.x.x.x
server_port = 7000

[secret_ssh]
type = stcp#
只有 sk 一致的用户才能访问到此服务
sk = abcdefg
local_ip = 127.0.0.1
local_port = 22


在要访问这个服务的机器上启动另外一个 frpc,配置如下:

# frpc.ini
[common]
server_addr = x.x.x.x
server_port = 7000

[secret_ssh_visitor]
type = stcp
# stcp 的访问者

role = visitor
# 要访问的 stcp 代理的名字

server_name = secret_ssh
sk = abcdefg
# 绑定本地端口用于访问 ssh 服务

bind_addr = 127.0.0.1
bind_port = 6000


通过 ssh 访问内网机器,假设用户名为 test:

ssh -oPort=6000 test@127.0.0.1


https://www.cnblogs.com/sanduzxcvbnm/p/8508741.html

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。