nginx 反向代理 负载均衡 动静分离

一样东西的诞生通常都是为了解决某些问题,对于 Nginx 而言,也是如此。

比如,你出于无聊写了一个小网站,部署到 tomcat 之后可以正常访问

但是后来,你的这个小网站因为内容很诱人逐步的火了,用户越来越多,并发量也慢慢增大,此时一台服务器已经满足不了网站的需求了。

你不能眼睁睁的看着你的"孩子"被压垮呀,于是乎,一咬牙又花钱加了几台服务器。

一、什么是Nginx

Nginx

Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,在微服务架构中,Nginx作为客户端请求的第一层中间件,通常将请求转发代理给网关。一般Nginx运用的主要场景有反向代理、负载均衡、动静分离等,在微服务架构如下:

其特点是占用内存少,并发能力强,运行还很文档,几乎可以做到7x24h不间断运行,即使运行数个月也不需要重启。而且,还能在服务不间断的情况下进行软件版本的升级。

Nginx代码完全用C语言编写,官方数据测试表明能够支持高达50000个并发连接数的响应。

反向代理

为了安全起见,一般我们不会将应用服务器内网地址暴露给外界,此时就让Nginx作为代理来访问内网地址。而Nginx的IP地址可以作为公网IP暴露给外界使用,这样就屏蔽了内网服务器信息。例如:

正向代理:访问www.google.com 需要正向代理,访问的目的地不发生变化

  • 首先在本机修改hosts文件
    路径为:C:\Windows\System32\drivers\etc\hosts
    添加以下内容:
php 复制代码
# 192.168.152.160是远程Nginx服务器地址
192.168.152.160    gulimall.com

当客户端输入 gulimall.com时,通过本地域名映射规则,解析出Nginx服务器地址

  • 设置Nginx反向代理
    修改nginx.conf的server段
perl 复制代码
 listen 80;
 server_name  gulimall.com;
 location / { 
  #代理给内网服务地址   
  proxy_pass http://172.20.10.3:8000; #商品服务的地址
 }

这样,我们就实现了Nginx的反向代理,是不是很简单呢?

三、负载均衡

现在有好几台服务器了,也有代理服务器了。但是因为你预算有限,后加的几台服务器配置有高有底,这时候如果能让配置高的服务器多承担点压力,让配置低的少承担点压力就好了。

Nginx的负载均衡就可以完成这样的需求。

在 conf.d 目录下创建 gulimall.conf --- 操作 cp defaut.conf gulimall.conf

gulimall.conf 配置文件如下

perl 复制代码
 listen 80;
 server_name  gulimall.com;
 location / { 
  #代理给内网服务地址   
  proxy_pass http://gulimall; #商品服务的地址
 }

nginx.conf 配置文件如下 选择的默认负载均衡:轮询

perl 复制代码
upstream gulimall{
    server 172.20.10.3:88;
    server 172.20.10.3:89;
}

网关的配置文件 application.yml文件如下

TypeScript 复制代码
spring:
  application:
    name: gulimall-gateway

  cloud:
    gateway:
      routes:
        - id: gulimall_host_route
          uri: lb://gulimall-product
          predicates:
            - Host=gulimall.com,item.gulimall.com

四、动静分离

你的小网站里有些请求是需要后台处理的,但是有些请求是不需要的,比如 css、html、jpg、js等文件,这些统称为静态文件

Nginx可以根据一定规则把不变的资源和经常变的资源区分开,做好了拆分之后,我们就可以根据静态资源的特点将其做缓存操作,从而提高资源响应的速度。

gulimall.conf 配置文件如下

TypeScript 复制代码
location /static/ {
    root /usr/share/nginx/html;
}

把对应的静态文件放在/usr/share/nginx/html/即可

OK,通过动静分离,你的小网站响应速度也上去了,用户体验更好了,你终于送了口气。

--不要用肉体的勤奋,去掩盖思考的懒惰--

相关推荐
运维李哥不背锅2 小时前
K8S集群节点负载无故飙升:CPU软死锁解决方案
linux·运维
Brandon汐6 小时前
Linux第四章练习
linux·运维·服务器
Ting-G6 小时前
配置GRE-tunnel隧道(思科&华为)
运维·网络·智能路由器
我是Superman丶7 小时前
【工具】Redis管理工具推荐
运维·数据库·redis
nzxzn7 小时前
linux第三次作业
linux·运维·服务器
chairon7 小时前
Ansible:playbook的高级用法
linux·运维·服务器·ansible·apache
上海云盾商务经理杨杨7 小时前
网络游戏服务器如何构建全方位防御体系?DDoS与CC攻击实战防护指南
运维·服务器·ddos
活跃家族8 小时前
UI自动化基础(1)
运维·自动化
字节源流8 小时前
【Spring Cloud Netflix】GateWay服务网关
java·运维·gateway
秦jh_8 小时前
【Linux网络】网络套接字socket
linux·运维·服务器·网络