使用frp端口映射实现内网穿透(SSH、HTTP服务)

article/2025/9/29 20:02:18

使用frp端口映射实现内网穿透(SSH、HTTP服务)

一、下载

通过内网穿透的原理和实现方式的学习我们已经明白了内网穿透的原理,想要实现内网穿透就需要让内网实现与具有公网IP的设备进行绑定。

我们这里使用frp(一个专注于内网穿透的高性能的反向代理应用,支持 TCP、UDP、HTTP、HTTPS 等多种协议。可以将内网服务以安全、便捷的方式通过具有公网 IP 节点的中转暴露到公网)进行内网穿透。下载地址:https://github.com/fatedier/frp/releases

我们需要在内网设备和公网设备上都进行frp的下载。

  • fprc:客户端程序;(内网程序)
  • frpc.ini:客户端程序配置文件;
  • frps:服务网器端程序;(公网程序,进行端口映射服务)
  • frps.ini:服务器端程序配置文件;

二、基础配置配置

1)对于公网设备,我们需要配置frps.ini文件

[common]
bind_port = 7000
token = 129496dashboard_addr = 0.0.0.0
dashboard_port = 7500
dashboard_user = root
dashboard_pwd = xxxx
  1. bind_port:用户客户端与服务端连接的端口(让外网设备可以将请求信息转发给内网让内网主动与发起请求设备进行连接)
  2. token:认证密码
  3. dashboard:仪表盘
    • addr:服务器本机
    • port:仪表盘网页绑定在服务器的端口
    • user:访问仪表盘网页的用户名
    • pwd:密码

2)对于内网设备,我们需要配置frpc.ini文件

[common]
server_addr = ip
server_port = 7000
authentication_method = token 
token = xxxxx
  1. server_addr:服务器(公网设备)IP
  2. server_port:服务器端口(有了IP和端口后内网即可进行NAT穿透,让公网设备可以将请求转发给自己),需与服务器bind_port的设置保持一致
  3. authentication_method:采用token的认证方式
  4. token:认证密码,需与服务器的设置保持一致

3)服务器端开放7000端口和7500端口

三、实现SSH服务

1)在原本客户端的frpc.ini配置基础上增加

# 配置ssh服务
[ssh]
type = tcp
local_ip = 127.0.0.1 
local_port = 22 # ssh服务端口
remote_port = 6000  # 这个自定义,之后再ssh连接的时候要用

注释记得去除

  1. [ssh]:[服务名]
  2. type:表示想要实现的服务对应的协议
  3. local_ip:表示本地需要暴露到公网的服务地址,即内网对应的地址
  4. local_port:表示本地需要暴露到公网的端口,即内网监听的端口,由于是ssh服务故监听22端口
  5. remote_port:表示在 frp 服务端监听的端口,访问外网设备此端口的流量将会被转发到内网设备的对应端口(local_port)

2)服务器端开放6000端口

3)运行程序

  • 服务器端:./frps -c ./frps.ini
  • 客户端:./frpc -c ./frpc.ini

4)使用ssh连接工具,通过外网ip加6000端口号即可以与内网建立ssh连接

四、实现HTTP、HTTPS服务

1)在原本客户端的frpc.ini配置基础上增加

[http]
type = http
local_ip = 127.0.0.1
local_port = 8800
custom_domains = xxx

此处与SSH服务配置相似,只是将type更改为http并多设置一个custom_domains

custom_domains = 这里填写你已经解析到frps服务端IP上的域名,自己每个穿透对应服务,都可以绑定一个专属域名用于访问,包括使用tcp和udp协议,然后就可以通过这个已经自定义域域名访问到自己的对应HTTP服务

如果没有域名则先写外网ip即可

注意这里没有设置remote_port,http服务和http服务的访问端口在服务器端设置

2)在原本服务端的frps.ini配置基础上增加

vhost_http_port = 7600
vhost_https_port = 7601

vhost_http_port = 7600 和 vhost_https_port = 7601 表示将服务器的7600端口做为http服务的访问入口,7601端口做为https服务的访问入口

3)服务器端开放7600端口、如果配置了https服务则开放7601端口

4)运行程序

5)通过域名/ip+端口访问内网的http/https服务

五、frp服务自启动

  1. 进入frp目录,复制文件

    • cp frps /usr/local/bin/frps
    • mkdir /etc/frp
    • cp frps.ini /etc/frp/frps.ini
  2. 创建frps.service服务:vim /lib/systemd/system/frps.service

    • [Unit]
      Description=frpc daemon
      After=syslog.target  network.target
      Wants=network.target[Service]
      Type=simple
      ExecStart=/usr/local/bin/frps -c /etc/frp/frps.ini
      Restart=always
      RestartSec=1min
      ExecStop=/usr/bin/killall frps[Install]
      WantedBy=multi-user.target
      
  3. 设置开机自启动:systemctl enable frps

  4. 开启服务:systemctl start frps

  5. 查看状态:systemctl status frps

image-20220716191807877active(running)则表示启动成功


http://chatgpt.dhexx.cn/article/wqZQs7dl.shtml

相关文章

rinetd端口转发工具

前言 环境:Centos7.9 rinetd.tar.gz 在生产环境中,为了网络安全,我们需要进行端口转发,而rinetd是一款很好用的端口转发工具,下面我们就来讲解一下如何使用rinetd来实现端口转发。rinetd的下载地址:http:…

电脑端口详解

计算机端口号总数:65535,一般用到的是1~65535,0一般不使用 0-1023: 系统端口,也叫公认端口,这些端口只有系统特许的进程才能使用;1024~65535为用户端口: 1024-5000: 临时…

HTTP服务占用80端口的解决办法,找出占用80的元凶。

电脑没有运行web服务,但是80端口被占用,导致运行使用80端口的软件的时候提示80端口监听失败。 网络上搜索一般给的办法是 net stop HTTP,把windows的http API禁用,这样确实80端口没有占用了,但是所有依赖http的服务就…

python端口扫描

文章目录 python网络编程socket函数服务器端套接字函数客户端套接字函数公共用途套接字 C/S架构实践 编写端口扫描器多线程端口扫描2.0 python网络编程 socket又称“套接字”,应用程序通常通过“套接字”向网络发出请求或者应答请求。使主机间或者一台计算机上的进…

https默认端口443_为什么选择80作为默认HTTP端口,选择443作为默认HTTPS端口?

https默认端口443 While many of us are familiar with various ports being assigned for specific purposes or uses, we may not know the particular reason why they were chosen. Today’s SuperUser Q&A post has the answers to a curious reader’s questions. 尽…

HTTP协议

目录 前置 1.网络划分 1)局域网 2)广域网 2.IP地址和端口号 1)IP地址 2)端口号 3.网络通信 一,概念 1.HTTP 2.二进制数据和文本 二,抓包 1.网络抓包 2.URL(统一资源定位器&#…

C语言字符串数组赋值错误

直接上代码&#xff1a; #include"stdio.h"int main(){char a[10];for(int i 0; i<10;i){printf("第%d个&#xff1a;",i);scanf("%c",&a[i]);}return 0; }经典的错误&#xff0c;标准的零分&#xff01; 这样的赋值手法&#xff0c;是…

c 语言定义2维字符串数组赋值,二维数组赋值字符串 c 语言 二维字符串数组赋值问题...

C语言中二维字符数组应该怎样赋值&#xff1f; c语言二维数组如何定义字符串&#xff1f;&#xff1f;&#xff1f;&#xff1f;急。。。 二维字符数组的定义格式为&#xff1a;char 数组名[第一维大小][第二维大小]; 例如&#xff1a;char c[3][10]; //定义了一个3行10列的二维…

关于中字符串常量给字符数组赋值

结论 在定义字符数组时&#xff0c;可以同时初始化字符数组&#xff0c;即用字符串常量给字符数组赋值在定义完之后&#xff0c;则不允许用字符串常量给字符数组赋值。如需赋值&#xff0c;则使用strcpy()函数&#xff08;需包含头文件string.h&#xff09; #include <std…

C语言:字符数组赋值

字符数组&#xff1a;C语言学习中较麻烦的部分&#xff0c;C语言中没有字符串这种类型的数组&#xff0c;字符串只能存储在字符型数组中。 1、定义时直接赋值 char a[10]{"I LOVE C"};//可以直接省去花括号直接写成char a[10]I LOVE C"; 注意&#xff1a;此处的…

【C#】 Convert.ToInt16 、Convert.ToInt32、Convert.ToInt64 区别

一般写程序是用的都是Convert.ToInt32&#xff0c;为什么呢&#xff1f; 1.Convert.ToInt是数据类型转换成int类型 2. 有三种方法toint16,toint32,toint64 int16-数值范围&#xff1a;-32768 到 32767 int32-数值范围&#xff1a;-2,147,483,648 到 2,147,483,647 …

C# 中int short Int16 Int32 Int64详解

Java中没有Int32,Int64,,只有int,short,long Java中int就代表Int32 ,short就代表Int16&#xff0c;long就代表Int64 首先&#xff0c;几个基本的关键字&#xff1a; Int16 short, 占2个字节. -32768 ~ 32767 Int32 int, 占4个字节. -2147483648 ~ 2147483647 Int64 lon…

【C++】INT32_MAX

INT32_MAX INT32_MAX可以把它认为在limits.h下面的一个宏。关于宏&#xff0c;可以参考这篇文章&#xff0c;直接点击&#xff01;其实就是一个别称&#xff01;

python中int的取值范围_int32的取值范围是多少?

int32的数值取值范围为“-2147483648”到“2147483647”;而int64的数值取值范围为“-9223372036854775808”到“9223372036854775808”。 int32的取值范围 计算机中32位int类型变量的范围,其中int类型是带符号整数。 正数在计算机中表示为原码,最高位为符号位: 1的原码为000…

c语言unsigned int 范围,unsigned int 32比特数据范围为-2147

提到unsigned,大家应该都了解,有朋友问c语言中unsigned什么意思,还有人想问c语言中的unsigned是什么意思,这到底是咋回事?事实上unsigned呢,下面是小编推荐给大家的unsigned int,下面我们一起来看看吧! unsigned int 一、指代不同 1、int:定义整数类型变量的标识符。 …

C#中ToInt32以及类似函数用法介绍

C#中ToInt32以及类似函数用法介绍 作用程序举例程序逻辑程序代码 程序 作用 将指定的值转换为 32 位有符号整数。对应的还有ToInt16&#xff0c;ToInt64 指定的值可以是字符串、时间、位等数据类型。 程序举例 程序逻辑 当输入值整数时&#xff0c;当输入值大于0&#xff0…

C语言 —— int32_t uint32_t 及size_t

文章目录 int32_t和int区别使用原因stdint.h源码 int32_t和uint32_t的区别size_t在不同机器中定义不同&#xff1a;stdint.h源码 参考文档 int32_t和int区别 我们都知道&#xff0c;C语言的基本类型就char, short, int 等。但是我们在看其他源码时经常碰到int32_t, int8_t这种…

linux futex 进程同步,Linux的新式线程同步原语——Futex

在我的上一篇文章《本地POSIX线程库》http://www.linuxidc.com/Linux/2013-10/91409.htm 中&#xff0c;提到了Futex一词&#xff0c;发现好多读者误以为这是我的笔误&#xff0c;将Mutex错写为Futex了。其实Futex是Linux的一种全新的线程同步原语。本文将为您解读高效的Futex。…

futex同步机制分析之三内核实现

一、源码引入 前两篇从应用分析到了库&#xff0c;本篇到内核中看看&#xff0c;futex到底何方神圣&#xff1f;&#xff08;Linux3.1.1&#xff09; 先看一下futex.c和futex.h&#xff08;kennel/futex.c linux/futex.h&#xff09;: /*** struct futex_q - The hashed futex…

futex同步机制分析之一应用

futex同步机制分析之一应用 一、多线程&#xff08;进程&#xff09;的同步机制 c编程中最难的部分有哪些&#xff0c;估计绝大多数人都会首先提出来是多线程&#xff08;进程&#xff09;编程。为什么多线程编程难呢&#xff1f;一个主要的原因就是多线程的同步。在多线程同步…