当前位置: 首页 > article >正文

[Linux]从零开始的Nginx反向代理配置及运用教程

一、前言

        最近在自己的服务器上部署了SillyTavern服务,这让我随时随地都可以访问SillyTavern进行愉快的角色扮演。随着使用,一些问题也体现了出来。首先就是,每次我访问SillyTavern的面板时都需要输入ip地址加端口号,这也非常的不方便。其次,IP地址加端口号的形式也不方便我自己记忆。后来我发现一些提供SillyTavern服务的服务商,他们为SillyTavern的面板加上域名并且可以使用https协议访问,在此基础上,并不需要额外的端口号之类的就可以直接访问SillyTavern的页面。如果按照比较常规的做法来说,就是将SillyTavern的服务端口改为80再将域名解析到服务器的IP就可以实现使用域名来访问SillyTavern服务了。当然,这种方式确实可以,但是同时也引发了一些新的问题,如果我们80端口运行的服务不止这一个呢?那岂不是冲突了。后面通过群友那里我了解到,对于我这种情况,可以使用Nginx的反向代理功能来实现。那么本次教程,我们就来看看如何进行Nginx的反向代理以及运用到我们的页面访问中。如果你准备好了,那就让我们开始吧!

二、什么是Nginx反向代理

        要清楚这个问题,我们首先就要清楚什么是反向代理,之前在讲网络的那篇文章中已经为大家讲解了什么是反向代理以及基本的实现原理,如果想要更加详细的讲解,请查看下面的文章:

网络基础:[网络]从零开始的计算机网络基础知识讲解_网络请求 从0开始教程-CSDN博客

简单来讲,反向代理决定了我们的流量被路由到哪一台服务器。最常见的反向代理的运用就是为了让不具备公网IP的设备被外部访问。

Nginx的反向代理也是同理,它能决定我们的流量被路由到指定的内网服务器。注意,这里是内网,在日常使用的环境中,我们经常将Nginx服务器作为一个内网外层网关,通过Nginx反向代理使得外部的流量被路由到内部网络中。当用户通过域名访问的服务时,Nginx反向代理服务器首先收到请求,随后由Nginx反向代理服务器决定将我们的访问流量路由到哪一台内网服务器上,内网服务器收到请求以后,会响应Nginx反向代理服务器,随后Nginx反向代理服务器响应用户,这样就完成了一次完整的请求。

看了上面的描述,相信大家已经对Nginx反向代理有一定的了解了,下面就让我们来实践一下吧。

三、Nginx反向代理配置

        现在我们就使用一个实际的案例来演示Nginx反向代理。假如我的服务器的8000端口上运行了SillyTavern服务,如图:

这里可以看到,我的服务器ip地址为39.101.179.176,并且我部署的服务的端口号为8000,下面我们就使用Nginx为这个服务套上域名。

这里为了配置方便,我们仍然使用宝塔面板。如果你还不会安装宝塔面板,可以参考之前的网站搭建教程:

网站搭建教程:[Linux]从零开始的网站搭建教程_linux服务器怎么搭建网站-CSDN博客

这里我就默认大家已经安装好了宝塔面板,并且已经学习了基本的网站搭建。这些东西也是下一步的前提。

我们打开宝塔面板:

这里我们首先新建一个网站,这里我们使用Nginx进行反向代理,本质上是在使用Nginx的http或者https反向代理。我们首先需要搭建一个对外的网站,然后再将访问网站的流量反向代理到别的地方。我们首先点击“添加站点”:

点击了以后就能看到站点创建页面了:

我们这里首先要使用一个域名,等会儿可能会涉及域名解析,如果你还不知道什么是域名以及如何解析请参考上面的网络基础教程和下面的内网穿透教程:

网站内网穿透教程:[Linux]从零开始的网站内网穿透教程_linux内网穿透-CSDN博客

这里因为我想反向代理我的SillyTavern服务,所以我的域名就是“SillyTavern.clxm.xyz”这里我选择在我原本域名的基础上解析一个二级域名,大家也可以直接使用一级域名,但是在解析时一定要解析对:

这里不用填写服务的端口号,Nginx反向代理会帮我们解决端口的问题。填写完域名以后,我们直接点击“确定”即可:

这里可以看到,我们的网站已经创建好了:

这里再为我们的二级域名添加解析,这里的域名注册以及解析教程在内网穿透:

随后我们直接访问我们的网站,可以看到网站已经可以正常访问了:

大家一定要完成这一步以后再进行下一步,我们必须要保证我们原本的网站是能够正常访问的再进行重定向。

同时我们还需要保证我们被重定向到的网站能够正常访问:

下面我们就可以开始进行重定向了,我们点击网站后面的“设置”:

随后点击“设置”界面的“反向代理”:

随后我们再点击“添加反向代理”:

这里的“代理名称”大家根据代理的用途自行定义,目标URL就是我们的服务的地址,我们这里直接填写我们服务器的地址再加上端口号:

随后点击“确定”即可:

这里可以看到,我们的Nginx反向代理已经添加完成了:

随后我们再次访问我们网站的域名,可以看到我们使用域名也能正常的访问到我们部署到8000端口的服务了:

至此,Nginx反向代理的部署就完成了。

四、结语

        最近的比赛确实比较忙,也没时间写长篇的帖子了。这篇帖子可能不能算作教程,更倾向于是个人笔记。如果大家看了还有不理解的地方可以随时在私信或者在评论区向我提问。最后,感谢大家的观看!


http://www.kler.cn/a/459405.html

相关文章:

  • 【机器学习:二、线性回归模型】
  • c-动态内存管理 (动态内存管理比较深入的分析和理解博客总结)
  • C#调用Lua
  • 2025.01.02(数据库)
  • websocket-sharp:.NET平台上的WebSocket客户端与服务器开源库
  • 拟声 0.60.0 | 拟态风格音乐播放器,支持B站音乐免费播放
  • python3中条件判断语句:match...case语句
  • 后端Java开发如何向LLM方向转型
  • Python爬虫:亚马逊评论数据在市场分析中的应用
  • 【实验记录】动手实现一个简单的神经网络实验(一)
  • Nginx 配置前端后端服务
  • 【Python实现连续学习算法】Python实现连续学习Baseline 及经典算法EWC
  • Spring Cloud Alibaba2022之Sentinel总结
  • 【GraphRAG】LEGO-GraphRAG框架解读
  • 商米电子秤服务插件
  • 华为ensp-BGP联盟
  • vue 修改vant样式NoticeBar中的图标,不用插槽可以直接用图片
  • AI与药学:ChatGPT与临床培训——药学博士(Pharm-D)学生的看法、担忧和实践
  • 《机器学习》——数据标准化(0~1标准化,z标准化)
  • 【杂谈】-艺术中的AI:作用及未来
  • C语言内存管理函数
  • [python SQLAlchemy数据库操作入门]-14.实时数据采集 记录股市动态
  • No.2十六届蓝桥杯备战|练习题4道|数据类型|字符型|整型|浮点型|布尔型|signed|unsigned(C++)
  • 下载并使用CICFlowMeter提取网络流特征(Windows版本)
  • Mac 环境 VVenC 编译与编码命令行工具使用教程
  • 英创主板ESM8400支持Debian 12桌面系统