百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

实测可用:nginx代理frp实现80、443端口二级泛域名内网穿透服务

off999 2025-03-11 19:52 19 浏览 0 评论

frp是一款十分厉害和方便的内网穿透软件,开源、高性能,支持 TCP、UDP、HTTP、HTTPS 协议代理,支持ssh穿透,http、https穿透、tcp、unix域套接字穿透等等。

典型的使用场景是:

服务端frps在公网服务器配置,客户端frpc在内网主机上配置。暴露任意frpc客户端上的端口,到服务器端frps,通过直接访问frps对应端口,转而实际访问内网主机的相关端口服务。

1、frp的配置方式网上见到的有2种,ini和toml文件。

ini格式的配置,应该是从0.52版以后就被弃用了。新功能也只在toml格式的配置文件支持。所以,最后推荐toml格式的配置文件。

服务端启动命令:frps.exe -c xxx.ini

客户端启动命令:frpc.exe -c xxx.ini

2、之前我一直在简单使用带端口的http代理穿透的场景:

frps配置(ini配置):

[common]
server_addr = x.x.x.x
server_port = 7000
vhost_http_port = 8080
# 身份验证方式,设置为token,默认是token,可以不配置此项
authentication_method = token 
# 自定义的token值,客户端需要配置相同的token才能连接
token = your_token_value 

frpc配置(ini配置)

[common]
admin_addr = x.x.x.x
admin_port = 7000  # 与frps的server_port保持一致
# 身份验证方式,设置为token,默认是token,可以不配置此项
authentication_method = token 
# 自定义的token值,客户端需要配置相同的token才能连接(与frps的配置保持一致)
token = your_token_value 

[web]
type = http
local_port = 1234  # 本地http服务的监听端口
custom_domains = test.yourdomain.com
http_user = abc  # 用于:HTTP Basec Auth访问验证,临时暴露此端口服务的,可以去掉
http_pwd = abc  # 用于:HTTP Basec Auth访问验证,临时暴露此端口服务的,可以去掉

最近,测试环境改变,需求场景也改变了,变成:

对于内网客户端的80、443端口,使用典型的http、https内网二级泛域名的穿透

我查了查资料,测试了一下,配置好自己可用的。

基本配置中,也从ini变成了toml,frp版本也使用了0.61+版本,对外反向代理使用的是nginx。具体操作如下:

1、配置frps和frpc,如下:

服务端frps(toml):

bindPort = 7000 # 防火墙开启此端口,frpc客户端连接使用

auth.method = "token"
auth.token = "xxxxxxx"

webServer.addr = "127.0.0.1"  # 限制frp自带的dash服务为本机访问
webServer.port = 7001   # frp自带的dash服务端口,防火墙不必开启此端口
webServer.user = "admin"
webServer.password = "xxxxx"

vhostHTTPPort = 7002  # frps的http监听端口,防火墙不必开启此端口,用于nginx反向代理使用

log.to = "console"  # 日志:显示到 console,方便查看状态,可以配置到文件
log.level = "info"
log.maxDays = 3
log.disablePrintColor = false

客户端frpc(toml)配置

	serverAddr="x.x.x.x"  # 服务端frps的ip地址
	serverPort=7000
	
	auth.method = "token"
	auth.token = "xxxxxxx"  # 与服务端frps配置的一致
	
	[[proxies]]
	name = "web2host"  # 随便起个标识
	type="http"
	localIp="0.0.0.0"  # 对外提供所有
	localPort=8080  #本地http服务的监听端口
  # *.go.yourdomain.com 下搞一个已解析或者hosts绑定的二级域名的子域名
	customDomains=["s2.go.yourdomain.com"]  

nginx的配置:

server {
	listen       80;
	listen 443 ssl http2;
	keepalive_timeout 70;
	server_name  *.go.yourdomain.com;
	
  # 日志配置
	access_log  "./access_go.yourdomain.com.log";
	# root 

  # 需要https的话,就配置一下证书
	ssl_certificate  ./fullchain.pem;
	ssl_certificate_key ./privkey.pem;
	ssl_session_cache shared:SSL:10m;
	ssl_session_timeout 5m;
	ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
	ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
	ssl_prefer_server_ciphers on;

	location / {
		proxy_pass http://127.0.0.1:7002;  # 与frps的vhostHTTPPort配置一致
		index index.html index.htm;
		
		proxy_set_header Host $host;
		proxy_set_header X-Real-IP $remote_addr;
		proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
		proxy_set_header X-Forwarded-Proto $scheme;
		
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        
		proxy_redirect http://$host/ http://$http_host/;
		
	}
}

当然一看就知道,proxy_redirect http://$host/ http://$http_host/;

这一句是一定要配置的,其他的都是常规配置。

之后就可以通过:
http://s2.go.yourdomain.com 和
https://s2.go.yourdomain.com 愉快的访问,在frpc客户端的8080端口服务了。

我选择二级泛域名,主要是考虑防止域名管理混乱,也可以直接搞一个主域名啥的,这就是nginx的常规设置了。

用于开发测试,产品展示还是又简单又实用。果然,frp确实好用啊。

相关推荐

office2010破解(office2010破解密钥)
  • office2010破解(office2010破解密钥)
  • office2010破解(office2010破解密钥)
  • office2010破解(office2010破解密钥)
  • office2010破解(office2010破解密钥)
迅雷种子搜索器(迅雷种子搜索器手机版下载)

    迅雷种子搜索方法:    1.在开始菜单栏或者到文件的安装路径文件夹中找到P2P种子搜索器。&nb...

手机怎么解压文件(苹果手机怎么解压文件)

手机解压文件方法:1、首先,在手机中找到文件管理,打开文件管理。2、打开文件管理之后找到压缩包,然后打开。3、打开安装包之后,选择需要的文件,。4、接下来找到“解压至”,点击“解压至”。5、点击之后,...

虚拟机安装centos7(虚拟机安装centos7图形界面)

安装CentOS7在虚拟机中,您可以按照以下步骤操作:1.下载CentOS7的ISO映像文件。2.打开虚拟机软件(如VMware、VirtualBox等)并创建一个新的虚拟机。3.在虚拟机创...

电脑老是重启(电脑老是重启什么原因造成的)

电脑由于工作环境积尘与空气湿度过大,经常使主板的接插件部分受潮产生氧化;特别是内存条插座、PCI扩展槽、键盘鼠标接口、LOT接口、CMOS电池压盒、ATX电源插座等。一旦它们出现接触不良现象,很容易出...

win8系统怎么重装系统(win8.1系统重装教程)

1、修改Cortana资源占用:按Windows按钮,输入regedit,打开注册表编辑器,找到以下路径:HKEY_LOCAL_MACHINE—SYSTEM—CurrentControlSet—Ser...

手机163邮箱app下载(163邮箱下载手机版官网 app)

163邮箱登录首页入口为http://mail.163.com/网易163免费邮箱--中文邮箱第一品牌.容量自动翻倍,支持50兆附件,免费开通手机号码邮箱赠送3G超大附件服务.支持各种客户端软件收发,...

win10此电脑怎么放在桌面上(wind10此电脑放桌面)
win10此电脑怎么放在桌面上(wind10此电脑放桌面)

步骤/方式1右键单击桌面空白处,点击个性化。步骤/方式2点击更改桌面图标。步骤/方式3把计算机勾选上。步骤/方式4即可把此电脑图标显示在桌面上。...

2025-11-08 14:03 off999

电脑配置怎么看在电脑上(电脑配置在电脑里怎么看)

查看电脑配置的方法有多种,以下是一些常见的方法:直接查看:在电脑桌面或操作系统中,找到“我的电脑”或“此电脑”,右键点击并选择“属性”,即可查看电脑的基本配置信息,包括CPU型号、内存大小、硬盘类型和...

电脑开机反复启动不起来(电脑开机反复重启开不了机怎么办)

1、先关闭主机总电源,电脑先关机吧,打开机箱,将内存条插槽两边的白色专卡口轻向下按,使内存条属弹出插槽。?2、取出内存条后,用干净的橡皮擦擦拭金手指或者用吹风机吹一吹。?3、然后将内存条对准插槽的卡口...

win10家庭版转专业版密钥(windows10家庭版升级到专业版密钥)

家庭版升级专业版密钥,需要付费购买获取不可以,家庭版密钥只是电脑还原时有效,重装系统就没有用了,可以看下面的方法。我是在淘宝买过几个不同系统的密钥都很好用,1-10元都买过,您进入搜索您需要系统的密钥...

安卓镜像下载(安卓镜像下载官网)

vmwareiso镜像文件可以从VMware官网下载。具体的下载步骤如下:1.打开VMware官网,进入产品下载页面。2.在产品下载页面,选择需要下载的VMware产品,比如VMwareWork...

哪个品牌u盘最可靠(哪个品牌的u盘好用)

十大耐用云U盘排行分别是:第一名闪迪第二名雷克沙第三名金士顿第四名三星第五名美商海盗船第六名东芝第七名惠普第八名威刚第九名台电第十名朗科。  质量最稳定u盘是金士顿:全球存储产品领导品牌,全球规模最大...

windows11系统怎么样(win11使用怎么样)

免激活的WindowS11系统很好用,所谓的免激活,并不是不激活,而是在安装的过程当中已经进行了激活,如果激活码是正规渠道获得的,那么就可以被微软所认可,这样的系统在今后的升级或者是打补丁的过程当中...

打印机如何网络共享打印(打印机网络共享打印怎么设置)

想要建立打印机共享使用的方法如下1右击【计算机】选择【管理】,在弹出的【计算机管理】窗口中:系统工具->本地用户和组->用户,在右边找到【Guest】双击进去,把账户已禁用的勾选去掉。2回...

取消回复欢迎 发表评论: