官网使用Nginx实现动静分离

2024-05-29 06:08

本文主要是介绍官网使用Nginx实现动静分离,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Nginx 是俄罗斯人 伊戈尔·赛索耶夫( Igor Sysoev)开发的 一个 HTTP 和反向代理服务,邮件代理服务器,此外还可以作为 TCP/UDP 代理服务器。 仅 2021 年 7月里 Nginx 代理了市场 22.57% 的站点。这还不包括很多内网使用的站点,以及淘宝基于 Nginx 开发的 Tengine。再次致敬作者!

Nginx 作为 HTTP 反向代理服务器,主要用途之一就是实现网站的动静分离。

刚好公司上个月开发新版官网,和另一个同事一起完成,我主导开发,技术栈是 springboot + mybatisPlus +freemarker +  ElasticSearch +Nginx ,关于具体的实现思路,如果有人感兴趣的话,后续可以专门写一篇文章。

话不多说,直接先上图:

简单解释下:

1. 浏览器访问官网域名会跳转到 /usr/share/nginx/html下的index.html

2.  在html 文件会通过异步请求发送 /back/ 开头的url 请求后台接口

下面根据上图的需求,配置 nginx.conf, 注意在 http 模块中添加如下配置:

server {listen       80;# 配置你的域名server_name  www.xxx.com;# 默认路由到 /usr/share/nginx/html 下的 index.htmllocation / {root   /usr/share/nginx/html;index  index.html index.htm;  }# 请求 /back 开头的接口时会代理到后台服务location /back/ {# 后台服务器,一般配成内网域名,或者 ip:端口proxy_pass   http://backend.website.com;}
}

这里其实重点用的还是 location 指令, 可以参考之前的文章《Nginx 搭建文件服务器》。这里涉及到一个常用的指令proxy_pass,下面详细介绍下该指令:

# proxy_pass, 使用语法:proxy_pass URL;
# 如果proxy_pass加了 URI, location 中的URI,会被完全替代
# http://xxxxxx/name/hello =>  http://127.0.0.1/hello;
location /name/ {proxy_pass http://127.0.0.1:8080/;
}#  如果proxy_pass没有 URI, location 中的URI,会被追加
# http://xxxxxx/name/path/hello =>  http://127.0.0.1/name/path/hello
location /some/path/ {proxy_pass http://127.0.0.1:8080;
}#  如果proxy_pass 主机名后加了$request_uri, location 中的URI,会被追加
# http://xxxxxx/name/path1/hello1 =>  http://127.0.0.1/name/path1/hello1
location /name/ {proxy_pass http://127.0.0.1:8080$request_uri;
}# 使用 rewrite 指令时,proxy_pass 后的uri(如果有的话)会被 rewrite后的新uri 直接替换
# http://xxxxxx/name/path2/hello2 =>  http://127.0.0.1/name/path2/hello2
location /name/ {rewrite    /name/([^/]+)  /users?name=$1 break;proxy_pass http://127.0.0.1:8080;# 下面的写法,uri /会被替换,所以也能正常跳转# proxy_pass http://127.0.0.1/;
}

根据大家的反馈,后面会考虑分享Nginx的另个一重要功能:负载均衡。


 如果觉得还不错的话,关注、分享、在看(关注不会走丢~), 原创不易,且看且珍惜~

 

这篇关于官网使用Nginx实现动静分离的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

Qt spdlog日志模块的使用详解

《Qtspdlog日志模块的使用详解》在Qt应用程序开发中,良好的日志系统至关重要,本文将介绍如何使用spdlog1.5.0创建满足以下要求的日志系统,感兴趣的朋友一起看看吧... 目录版本摘要例子logmanager.cpp文件main.cpp文件版本spdlog版本:1.5.0采用1.5.0版本主要

Java中使用Hutool进行AES加密解密的方法举例

《Java中使用Hutool进行AES加密解密的方法举例》AES是一种对称加密,所谓对称加密就是加密与解密使用的秘钥是一个,下面:本文主要介绍Java中使用Hutool进行AES加密解密的相关资料... 目录前言一、Hutool简介与引入1.1 Hutool简介1.2 引入Hutool二、AES加密解密基础

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

SpringBoot实现微信小程序支付功能

《SpringBoot实现微信小程序支付功能》小程序支付功能已成为众多应用的核心需求之一,本文主要介绍了SpringBoot实现微信小程序支付功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录一、引言二、准备工作(一)微信支付商户平台配置(二)Spring Boot项目搭建(三)配置文件

鸿蒙中@State的原理使用详解(HarmonyOS 5)

《鸿蒙中@State的原理使用详解(HarmonyOS5)》@State是HarmonyOSArkTS框架中用于管理组件状态的核心装饰器,其核心作用是实现数据驱动UI的响应式编程模式,本文给大家介绍... 目录一、@State在鸿蒙中是做什么的?二、@Spythontate的基本原理1. 依赖关系的收集2.

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

基于Python实现高效PPT转图片工具

《基于Python实现高效PPT转图片工具》在日常工作中,PPT是我们常用的演示工具,但有时候我们需要将PPT的内容提取为图片格式以便于展示或保存,所以本文将用Python实现PPT转PNG工具,希望... 目录1. 概述2. 功能使用2.1 安装依赖2.2 使用步骤2.3 代码实现2.4 GUI界面3.效

MySQL更新某个字段拼接固定字符串的实现

《MySQL更新某个字段拼接固定字符串的实现》在MySQL中,我们经常需要对数据库中的某个字段进行更新操作,本文就来介绍一下MySQL更新某个字段拼接固定字符串的实现,感兴趣的可以了解一下... 目录1. 查看字段当前值2. 更新字段拼接固定字符串3. 验证更新结果mysql更新某个字段拼接固定字符串 -

java实现延迟/超时/定时问题

《java实现延迟/超时/定时问题》:本文主要介绍java实现延迟/超时/定时问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java实现延迟/超时/定时java 每间隔5秒执行一次,一共执行5次然后结束scheduleAtFixedRate 和 schedu

Java Optional避免空指针异常的实现

《JavaOptional避免空指针异常的实现》空指针异常一直是困扰开发者的常见问题之一,本文主要介绍了JavaOptional避免空指针异常的实现,帮助开发者编写更健壮、可读性更高的代码,减少因... 目录一、Optional 概述二、Optional 的创建三、Optional 的常用方法四、Optio