0


docker搭建frp内网穿透

华子目录

实验前的准备工作

1.

  1. frp

介绍

  • frp是一款高性能的内网穿透工具,它采用客户端-服务端的模式,通过中转服务器外部网络的请求转发到内部网络中的指定计算机

1.1

  1. frp

的工作原理

  • 客户端frp服务器发送请求,请求服务器分配一个唯一的客户端ID
  • frp服务器分配一个唯一的客户端ID,并将其返回给客户端
  • 客户端使用分配的客户端ID连接到frp服务器,以便服务器可以知道客户端连接的计算机和端口
  • 外部网络发出请求时,frp服务器将请求转发客户端

2.

  1. docker

简介

这里我们需要弄清楚

  1. 4

点:

  • docker镜像:一个特殊文件系统
  • docker容器:docker镜像运行时的实体
  • docker仓库:存放docker镜像文件的地方
  • docker数据卷: - 数据持久性:即使容器删除Volume中的数据也不会丢失,因为它们存储在宿主机上。- 数据共享:多个容器可以共享同一个Volume,使得数据共享变得简单方便。

3.下载

  1. frp

在这里插入图片描述

4.配置docker镜像加速

  • 由于目前国内的docker镜像站被全面封杀,这里博主找到了一个为数不多的docker镜像加速站,亲测可用
  1. {"registry-mirrors":["https://dockerhub.icu"]}

5.准备

  1. frp

服务端和

  1. frp

客户端
IP说明172.25.254.99frp服务端172.25.254.66frp客户端,web服务器

6.

  1. frp

客户端与

  1. frp

服务端关闭

  1. firewalld

  1. selinux

实验步骤

1.docker下运行nginx服务

  • 查看docker运行状态
  1. [root@frp-client ~]# systemctl is-active docker
  2. active
  • 做docker数据卷
  1. [root@frp-client ~]# docker volume create myVolume
  2. myVolume
  3. [root@frp-client ~]# docker volume ls
  4. DRIVER VOLUME NAME
  5. local 7a2f4cc60c2a165c35b65678e090966a35169b41a6a924dbffde63a3fa5c1f61
  6. local 9c2ddeac03bf2ca05d624d9bcc15f43be690c30770206e27e149ab34e5d4208b
  7. local 33eb668b5b2b00e576cc7b1516fedd39b00d5e4d2b785721bc4d4db57f710e65
  8. local 35ce78b1622154a1d2200be9436b177f05b763632985969aed3050fdefcd230b
  9. local 866d9b3799c81138487c29c9b506a81d12b4bf607073d97aaac1e41a52655575
  10. local 5653f75b05220d4a2acb5b01d6d812c6e6fb1e8b6605da946b7ff89f9b7aa83b
  11. local 2656990227a34c0f5e8022aa8a05a7be0c91554a28b2d71e8f4a51d73a5e36f4
  12. local my-web
  13. local myVolume
  14. [root@frp-client ~]# docker volume inspect myVolume[{"CreatedAt":"2024-08-06T23:51:22+08:00",
  15. "Driver":"local",
  16. "Labels": null,
  17. "Mountpoint":"/var/lib/docker/volumes/myVolume/_data",
  18. "Name":"myVolume",
  19. "Options": null,
  20. "Scope":"local"}][root@frp-client ~]# cd /var/lib/docker/volumes/myVolume/_data[root@frp-client _data]# ls[root@frp-client _data]#
  • 运行nginx容器
  1. [root@frp-client ~]# docker run -itd -v myVolume:/usr/share/nginx/html -p 8080:80 --name web nginx
  2. 571ece7fe9981eb9b1ced8c6e6503b4aea68e3b8feac81a6d9750c50e804fa6e
  1. [root@frp-client ~]# docker ps
  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  3. 571ece7fe998 nginx "/docker-entrypoint.…" About an hour ago Up About an hour 0.0.0.0:8080->80/tcp, :::8080->80/tcp web
  • 上传网页文件到数据卷
  1. [root@frp-client ~]# cd /var/lib/docker/volumes/myVolume/_data[root@frp-client _data]# ls
  2. 50x.html CSS img index.html js
  • 简单测试

在这里插入图片描述

2.上传

  1. frp
  • 将下好的frp包使用mobaxterm上传到frp-server端和frp-client端的/root
  1. [root@frp-server ~]# ls
  2. 公共 模板 视频 图片 文档 下载 音乐 桌面 anaconda-ks.cfg frp_0.56.0_linux_amd64.tar.gz
  1. [root@frp-client ~]# ls
  2. 公共 模板 视频 图片 文档 下载 音乐 桌面 anaconda-ks.cfg frp_0.56.0_linux_amd64.tar.gz

3.解压

  1. frp
  1. [root@frp-server ~]# tar -zxvf frp_0.56.0_linux_amd64.tar.gz
  2. frp_0.56.0_linux_amd64/
  3. frp_0.56.0_linux_amd64/frpc.toml
  4. frp_0.56.0_linux_amd64/frpc
  5. frp_0.56.0_linux_amd64/frps
  6. frp_0.56.0_linux_amd64/LICENSE
  7. frp_0.56.0_linux_amd64/frps.toml
  1. [root@frp-client ~]# tar -zxvf frp_0.56.0_linux_amd64.tar.gz
  2. frp_0.56.0_linux_amd64/
  3. frp_0.56.0_linux_amd64/frpc.toml
  4. frp_0.56.0_linux_amd64/frpc
  5. frp_0.56.0_linux_amd64/frps
  6. frp_0.56.0_linux_amd64/LICENSE
  7. frp_0.56.0_linux_amd64/frps.toml
  • frpc是客户端启动脚本frpc.toml是客户端配置文件
  • frps是服务端启动脚本frps.toml是服务端配置文件

4.配置frp-server端配置文件

  1. [root@frp-server frp_0.56.0_linux_amd64]# vim frps.toml[root@frp-server frp_0.56.0_linux_amd64]# cat frps.toml
  2. bindPort =7000#frp监听端口
  3. vhostHTTPPort =8888#当访问8888时

5.配置frp-client端配置文件

  1. [root@frp-client frp_0.56.0_linux_amd64]# vim frpc.toml[root@frp-client frp_0.56.0_linux_amd64]# cat frpc.toml
  2. serverAddr ="172.25.254.99"#服务端IP地址
  3. serverPort =7000#frp监听端口[[proxies]]
  4. name ="web-http"type="http"
  5. localIP ="127.0.0.1"
  6. localPort =8080#frp客户端的端口
  7. customDomains =["172.25.254.99"]

6.执行frp脚本启动

  • 先启动服务端,-c用来告诉frps服务端去加载哪个配置文件
  1. [root@frp-server frp_0.59.0_linux_amd64]# ./frps -c frps.toml
  • 再启动客户端,-c用来告诉frps服务端去加载哪个配置文件
  1. [root@frp-client frp_0.59.0_linux_amd64]# ./frpc -c frpc.toml

测试

在这里插入图片描述

标签: docker 容器 运维

本文转载自: https://blog.csdn.net/huaz_md/article/details/140964616
版权归原作者 ^~^前行者~~~ 所有, 如有侵权,请联系我们删除。

“docker搭建frp内网穿透”的评论:

还没有评论