【Nginx】静态资源部署、反向代理、负载均衡

个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~

个人主页:.29.的博客

学习社区:进去逛一逛~

nginx静态资源部署、反向代理、负载均衡

🚀Nginx配置文件结构(conf/nginx.conf)

  • nginx配置文件整体分为三部分:
    • 全局块 :Nginx运行相关的全局配置
    • events块 :网络连接相关的配置
    • http块 :代理、缓存、日志记录、虚拟主机配置
      • http全局块
      • Service块
        • Service全局块
        • location块

注:http块中可配置多个Service块,每个Service块可配置多个location块。


🚀Nginx部署静态资源

  • Nginx可以作为静态web服务器来部署静态资源。静态资源指在服务端真实存在并且能够直接展示的一些文件,比如常见的html页面、css文件、js文件、图片、视频等资源。

  • 相对于Tomcat,Nginx处理静态资源的能力更加高效,所以在生产环境下,一般都会将静态资源部署到Nginx中。将静态资源部署到Nginx非常简单,只需要将文件复制到Nginx安装目录下的html目录中即可。

server块

nginx 复制代码
    server {
        listen       80;        # 监听端口
        server_name  localhost; # 服务器名称(域名)

        location / {            # 匹配客户端请求url
            root   html;        # 指定静态资源的目录
            index  index.html index.htm;  # 指定默认首页
        }

        error_page   500 502 503 504  /50x.html;  # 指定报错页面

        location = /50x.html {
            root   html;
        }
    }

🚀Nginx反向代理

正向代理

是一个位于客户端和原始服务器(oricin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。

正向代理的典型用途是为在防火墙内的局域网客户端提供访问internet的途径。

正向代理一般是在客户端设置代理服务器,通过代理服务器转发请求,最终访问到目标服务器。

反向代理

反向代理服务器位于用户与目标服务器之间,但是对于用户而言,反向代理服务器就相当于目标服务器,即用户直接访问反向代理服务器就可以获得目标服务器的资源,反向代理服务器负责将请求转发给目标服务器。

用户不需要知道目标服务器的地址,也无须在用户端作任何设定。

⚪配置反向代理

配置方式

在某个server块的location块 中,添加proxy_pass属性,并配置反向代理需要请求转发到服务。

nginx 复制代码
    server {
        listen       82;        # 监听端口
        server_name  localhost; # 服务器名称

        location / {            # 匹配客户端请求url
            # 配置反向代理,将请求转发到指定服务
            proxy_pass http://192.168.88.161:8080; 
        }
    }

🚀Nginx负载均衡

介绍

早期的网站流量和业务功能都比较简单,单台服务器就可以满足基本需求,但是随着互联网的发展,业务流量越来越大并且业务逻辑也越来越复杂,单台服务器的性能及单点故障问题就凸显出来了,因此需要多台服务器组成应用集群进行性能的水平扩展以及避免单点故障出现。

  • **应用集群:**将同一应用部署到多台机器上,组成应用集群,接收负载均衡器分发的请求,进行业务处理并返回响应数据
  • **负载均衡器:**将用户请求根据对应的负载均衡算法分发到应用集群中的一台服务器进行处理

⚪负载均衡实现

配置方式

  • http块中使用upstream配置负载均衡的服务器组。
  • 将服务器组名称作为反向代理请求的服务域名。
  • 可使用weight设置权重,权重越大优先级越高。
nginx 复制代码
    upstream targetserver {     # ①upstream指令可以指定一组服务器,targetserver是服务器名,可自定义,可使用weight设置权重,权重越大优先级越高。
        server 192.168.88.129:8080 weight=10;
        server 192.168.88.162:8080;
    }

    server {
        listen       82;        # 监听端口
        server_name  localhost; # 服务器名称

        location / {            # 匹配客户端请求url
            # ②配置反向代理,将请求转发到指定服务
            proxy_pass targetserver ; 
        }
    }

负载均衡策略:


相关推荐
乘云数字DATABUFF8 小时前
5分钟部署开源APM Databuff:OpenTelemetry全链路追踪入门实战
运维·后端
荣--2 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森2 天前
动手实战学 Docker — 从零到集群编排完全指南
运维
Avan_菜菜3 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
SelectDB4 天前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
XIAOHEZIcode5 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户0328472220706 天前
如何搭建本地yum源(上)
运维
ping某7 天前
为什么 Nginx 明明监听了 80,转发后端时却用了 4xxxx 端口?
后端·nginx
大树889 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠9 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql