frp反向代理内网,使用内网的jupyterhub

2024-04-02 12:32

本文主要是介绍frp反向代理内网,使用内网的jupyterhub,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

其中jupyterhub 安装和使用可以参考这里

针对实际使用中,遇到如下场景,想让其他人测试在本地搭建的WEB服务,由于本地机器没有公网IP,无法域名解析到本地机器。可通过反向代理的方式,实现此功能。比如使用内网的jupyterhub.

FRP 是一个可用于内网穿透的高性能的反向代理应用,支持 TCP, UDP 协议,为 HTTP 和 HTTPS 应用协议提供了额外的能力,且尝试性支持了点对点穿透。
下载frp_0.27.0_linux_arm.tar.gz。

  • 将压缩包中的 frps 及 frps.ini 放到具有公网 IP 的机器上。

  • 将压缩包中的 frpc 及 frpc.ini 放到处于内网环境的机器上。

  • 修改配置文件

公网IP的机器上:

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

frps.ini

[common]
bind_port = 22222  # 中转的端口
vhost_http_port = 8888 # 公网ip 网页访问的端口

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

frpc.ini

[common]
server_addr = x.x.x.x   # 这个是公网的ip
server_port = 22222     # 公网中转的端口,和上面的frps.ini 一样[ssh]
type = tcp
local_ip = 127.0.0.1
local_port = 22
remote_port = 6001 # 公网对应的端口[jupyter]
type = http
local_port = 8888  # 本地jupyterhub 的服务端口
custom_domains = x.x.x.x   # 公网的ip地址
  • 启动 frps, frpc

公网机器:
启动 frps:
./frps -c ./frpc.ini

内网机器:
启动 frpc:
./frpc -c ./frpc.ini

网页访问内网的jupyterhub:

x.x.x.x:8888

systemctl frp自动启动脚本

1、脚本内容
放置在/lib/systemd/system目录下,由于我这里启动的是服务端,我将该脚本文件命名为:frps.service,完整路径为:
服务端:
/etc/systemd/system/frps.service

[Unit]
Description=frpc daemon
After=syslog.target network.target
Wants=network.target[Service]
Type=simple
ExecStart=/home/AtomEcho/frp_0.38.0_linux_386/frps -c /home/AtomEcho/frp_0.38.0_linux_386/frps.ini
Restart=always
RestartSec=1min[Install]
WantedBy=multi-user.target

client 端:/etc/systemd/system/frpc.service

[Unit]
Description=frpc daemon
After=syslog.target network.target
Wants=network.target[Service]
Type=simple
ExecStart=/data1/AtomEcho/frp_0.38.0_linux_386/frpc -c /data1/AtomEcho/frp_0.38.0_linux_386/frpc.ini
Restart=always
RestartSec=1min[Install]
WantedBy=multi-user.target
  • systemctl命令控制
systemctl enable frps #设置开机自动启动
systemctl enable frpc #设置开机自动启动systemctl disable frps #取消开机自动启动
systemctl start frps #开启frps服务
systemctl stop frps #关闭frps服务
systemctl restart frps #重启frps服务

如果对service 文件有修改,需要执行

systemctl daemon-reload

这篇关于frp反向代理内网,使用内网的jupyterhub的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/869983

相关文章

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

C#下Newtonsoft.Json的具体使用

《C#下Newtonsoft.Json的具体使用》Newtonsoft.Json是一个非常流行的C#JSON序列化和反序列化库,它可以方便地将C#对象转换为JSON格式,或者将JSON数据解析为C#对... 目录安装 Newtonsoft.json基本用法1. 序列化 C# 对象为 JSON2. 反序列化

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

Python ORM神器之SQLAlchemy基本使用完全指南

《PythonORM神器之SQLAlchemy基本使用完全指南》SQLAlchemy是Python主流ORM框架,通过对象化方式简化数据库操作,支持多数据库,提供引擎、会话、模型等核心组件,实现事务... 目录一、什么是SQLAlchemy?二、安装SQLAlchemy三、核心概念1. Engine(引擎)

Java Stream 并行流简介、使用与注意事项小结

《JavaStream并行流简介、使用与注意事项小结》Java8并行流基于StreamAPI,利用多核CPU提升计算密集型任务效率,但需注意线程安全、顺序不确定及线程池管理,可通过自定义线程池与C... 目录1. 并行流简介​特点:​2. 并行流的简单使用​示例:并行流的基本使用​3. 配合自定义线程池​示

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Java 正则表达式的使用实战案例

《Java正则表达式的使用实战案例》本文详细介绍了Java正则表达式的使用方法,涵盖语法细节、核心类方法、高级特性及实战案例,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、正则表达式语法详解1. 基础字符匹配2. 字符类([]定义)3. 量词(控制匹配次数)4. 边

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案