【新生指南-005】内网穿透2-使用云服务器+frp实现内网穿透(喂奶级)

发表于:2024-10-14 01:09:18 Docker 4692
本帖最后由 madrays 于 2024-12-8 21:26 编辑


🌎️前言
       前文介绍了lucky实现IPv6内网穿透的方法,但是受限于访问端IPv6无法保证的问题,例如公司网络未开启IPv6,那么lucky的IPv6穿透是无法访问的,这时候我们就需要使用 Frp 之类的内网穿透软件来实现在无IPv6的情况下实现外网访问,本次就介绍一下frp内网穿透的方法,注意此方法需要有一台有固定公网ip的云服务器,部署分为服务端frps和客户端frpc,我们需要在云服务器上部署frps,在飞牛上部署frpc


🏜️Frps部署
首先我们在云服务根目录下创建一个docker文件夹,其中创建一个frps文件夹,接着再在其中新建两个文件,分别命名为docker-compose.yml和frps.toml,有1panel之类的话直接创建,没有的话可以使用下面的命令。

  1. mkdir -p /docker/frps
  2. touch /docker/frps/docker-compose.yml
  3. touch /docker/frps/frps.toml
复制代码

🛑docker-compose.yml配置
修改docker-compose.yml中的内容如下:
  1. version: '3.3'
  2. services:
  3.     frps:
  4.         restart: always
  5.         network_mode: host
  6.         volumes:
  7.             - '/docker/frps/frps.toml:/etc/frp/frps.toml'
  8.         container_name: frps
  9.         image: snowdreamtech/frps:0.60
复制代码

🛑frps.toml配置
  1. bindAddr = "0.0.0.0"
  2. bindPort = 7000

  3. auth.method = "token"
  4. auth.token = "password"

  5. webServer.addr = "0.0.0.0"
  6. webServer.port = 7100
  7. webServer.user = "username"
  8. webServer.password = "password"
复制代码
上面的7000是服务端口,用于frps和frpc的通讯,7100是webui端口,token默认即可,password、username自行修改。
🛑启动frps
使用docker-compose up -d命令启动容器:
  1. cd /docker/frps
  2. docker-compose up -d
复制代码
尝试访问云服务器ip:7100访问frps的webui,登陆成功即可。

🏜️Frpc部署
文件管理器中找到你设置的docker所在存储空间中的appshare文件夹,这个就是应用文件,新建一个frpc文件夹,接着在frpc文件夹中新建两个文件,分别命名为docker-compose.yml和frpc.toml


🛑docker-compose.yml配置
修改docker-compose.yml中的内容如下:
  1. version: '3.3'
  2. services:
  3.     frpc:
  4.         restart: always
  5.         network_mode: host
  6.         volumes:
  7.             - '/vol1/@appshare/frpc/frpc.toml:/etc/frp/frpc.toml'
  8.         container_name: frpc
  9.         image: snowdreamtech/frpc:0.60
复制代码

🛑frpc.toml配置
  1. serverAddr = "云服务器ip"
  2. serverPort = 7000

  3. log.to = "console"
  4. log.level = "trace"
  5. log.maxDays = 3
  6. log.disablePrintColor = true

  7. auth.method = "token"
  8. auth.token = "password"

  9. [[proxies]]
  10. name = "sunpanel"
  11. type = "tcp"
  12. localIP = "127.0.0.1"
  13. localPort = 3002
  14. remotePort = 3003

  15. [[proxies]]
  16. name = "项目X"
  17. type = "tcp"
  18. localIP = "127.0.0.1"
  19. localPort = xxx
  20. remotePort = xxx
复制代码

上面的7000是服务端口,用于frps和frpc的通讯,7100是webui端口,token保持默认,password、username自行修改,注意auth.token变量需要和frps配置中的变量保持一致。
🛑启动frpc
使用docker-compose up -d命令启动容器:
  1. cd /vol1/@appshare/frpc
  2. docker-compose up -d
复制代码


🛩️如果部署成功,访问服务器ip:3002即可访问到飞牛中部署的sunpanel服务了。

🏜️题外话:反向代理实现域名+Https访问
这一步需要拥有域名,国内服务器需要备案,境外服务器暂无备案限制,这个我就不多说了,有兴趣的评论区讨论吧,云服务使用宝塔、1panel等可以很方便的实现,当然使用lucky也是可以的哈哈。
🏜️题外话2:没有云服务器怎么办
这种情况解决办法当然还是有的,比方说飞牛自带的穿透,或者樱花Frp(需要1块钱认证实名)这些公共Frp,效果肯定是没有自建frp服务器好的,但是应急用用还是可以的。
目前我采用的方案就是:
优先:lucky的ipv6穿透----适用于大部分场景,公司电脑有ipv6,手机4/5G有ipv6
备用:云服务器自建的frp穿透----适用于小部分没有ipv6的场景,例如我公司wifi没有ipv6
容灾:樱花frp穿透----适用于都崩了的场景,其实没咋用过,聊胜于无留着备用了


大家对什么项目感兴趣可以留言,写写喂奶级帮新同学们指路哈








收藏
送赞 3
分享

发表回复

评论列表(19)

第一行代码没显示正确,在云服务根目录下创建一个docker文件夹,其中创建一个frp文件夹,接着再在其中新建两个文件,分别命名为docker-compose.yml和frps.toml使用下面的代码:
   mkdir -p /docker/frp
   touch /docker/frp/docker-compose.yml
   touch /docker/frp/frps.toml
2024-10-14 16:53:37 回复
第一句应该是创建名称为frps的文件夹不是frp  详情 回复
2024-11-14 20:25
有需要的看看哈
2024-10-14 15:05:47 回复
用云服务器自建的话,看腾讯国内4M带宽的79一年,境外的30M一年99,有用过海外服务器的吗,怕墙的厉害
2024-10-14 16:47:21 回复
鱼找大学生卷,搞阿里hk
2024-10-14 16:50:50 回复
6 我找找去
2024-10-14 18:49:47 回复
昨天发帖问了一下,今天就找到了攻略,帮顶
2024-10-15 11:39:14 1 回复
路过,踩下。感谢分享
2024-10-16 08:35:34 回复

:time:

2024-10-18 16:39:00 回复
反向代理实现域名+Https访问
2024-10-23 08:50:42 回复
备用方案太合适了,同公司没有ipv6
2024-11-4 12:03:16 回复
第一句应该是创建名称为frps的文件夹不是frp
2024-11-14 20:25:00 回复
是的 搞错了哈哈  详情 回复
2024-11-14 23:56
是的  搞错了哈哈
2024-11-14 23:56:08 回复
frpc可以连接多个frps吗。做成类似容灾的方案自动切换,那个连接的上就连接那个
2024-11-15 09:11:25 回复
没有尝试过  感觉理论上可行  应该叫负载均衡
2024-11-15 15:32:18 回复
我在服务器多部署几个frpc.toml配置文件,连接不同的服务器,都可以正常使用。
2024-12-17 09:49:46 回复
FRS的解决方案,还需要一台公网IP云主机,成本太高。可使用goodlink,两台主机直连,无中转,跑满上下行带宽。操作最简单易用,无费用。https://gitee.com/konyshe/goodlink
2024-12-25 11:09:24 回复
ipv6需要穿透?不需要吧?直接就能连,买个域名,绑定ddns-go就行了
2024-12-25 13:42:00 回复
看起来也是个不错的工具,很适合没有ipv6的公司电脑
2025-1-14 10:25:54 回复
想问问怎么卸载
2025-1-16 21:10:16 回复