分布式电商项目(三)--Nginx

反向代理

反向代理服务器位于用户与目标服务器之间,但是对于用户而言,反向代理服务器就相当于目标服务器,即用户直接访问反向代理服务器就可以获得目标服务器的资源。同时,用户不需要知道目标服务器的地址,也无须在用户端作任何设定。反向代理服务器通常可用来作为Web加速,即使用反向代理作为Web服务器的前置机来降低网络和服务器的负载,提高访问效率。

特点:
1.反向代理服务器位于用户与目标服务器之间
2.对于用户而言,以为代理服务器就是真实的服务器.
3.反向代理机制保护了真实的服务器信息.
4. 反向代理一般称之为服务端代理.

在这里插入图片描述

步骤:
1.当用户发起请求时,该请求被代理服务器拦截.
2.代理服务器查询自己的配置文件,根据url地址获取真实的服务器信息.
3.由代理服务器根据真实的服务器信息,获取数据.
4.真实的服务器接收请求之后,将数据返回给代理服务器.
5.代理服务器接收到服务器数据之后,将数据回传给用户,本次代理结束.

正向代理

正向代理说明

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

特点:
1.代理服务器位于用户与真实服务器之间的
2.客户非常清楚自己访问的服务到底是谁?
3.服务器不清楚访问自己的服务器到底是谁,以为只是代理服务器访问.
4.正向代理称之为客户端代理.保护了客户的信息
在这里插入图片描述

Nginx

Nginx服务器介绍

Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004年10月4日。
其将源代码以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。2011年6月1日,nginx 1.0.4发布。

Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,在BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。

特点:
1.占用内存少 不超过2M
2.并发能力强 5万/秒 tomcat 150-220个/秒
3.开发语言 C语言

Nginx下载

分布式电商项目(三)--Nginx_第1张图片

nginx安装

启动: 首先右键以管理员身份运行,之后程序闪退表示服务器启动正常.
分布式电商项目(三)--Nginx_第2张图片

检查Nginx服务启动项

nginx启动时,会启动2个进程项,其中一个
1.主进程 主要为用户提供反向代理服务 占用内存大
2.守护进程 防止主进程意外关闭的. 占用内存小的
分布式电商项目(三)--Nginx_第3张图片

启动正常测试

分布式电商项目(三)--Nginx_第4张图片

NGINX入门案例说明

配置文件说明

http{
    #必须在http协议之内进行配置
    server{
        listen 80;
        server_name "监听域名地址";
        location / {
            root  "反向代理的是一个目录";
        }
        
    }
    server{.....}
}

NGINX实现图片回显

编辑Nginx.conf文件

#配置图片代理服务器  http://image.jt.com:80
    server {
        listen 80;
        server_name image.jt.com;

        location / {
            root  D:/JT-SOFT/images;
        }    
    }

nginx命令

目录: 在nginx的根目录中执行

分布式电商项目(三)--Nginx_第5张图片

命令:

1.启动命令 start nginx

2.重启命令 nginx -s reload

3.停止命令 nginx -s stop

编辑hosts文件(可以使用SwitchHosts)

介绍: HOSTS文件是操作系统为了方便开发,在本地形成的一个域名与IP的映射的文件. 但是该文件只对本机有效.
位置: C:WindowsSystem32driversetchosts
分布式电商项目(三)--Nginx_第6张图片

文件内容:

#IP 域名  映射关系

127.0.0.1  image.jt.com

127.0.0.1  manage.jt.com

127.0.0.1  www.jt.com

127.0.0.1  sso.jt.com

127.0.0.1  localhost

关于nginx回显图片报错问题说明

1.检查配置文件是否正确
分布式电商项目(三)--Nginx_第7张图片

5.检查hosts文件是否有效 如果不生效重启计算机
分布式电商项目(三)--Nginx_第8张图片

实现域名的代理

业务需求

需求: 需要通过http://manage.jt.com域名访问l...:8091的服务器.
操作:
1.修改hosts文件
2.修改nginx的配置文件

修改nginx.conf配置文件

修改nginx之后,重启即可.
分布式电商项目(三)--Nginx_第9张图片

nginx高级用法

nginx负载均衡机制

说明: 为了提升后台服务器的处理能力,可以增加服务器.实现负载均衡的策略.
分布式电商项目(三)--Nginx_第10张图片

动态获取服务器端口号.

请求路径: http://manage.jt.com/getPort 获取到当前的服务器端口号信息.

package com.jt.controller;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class PortController {

    @Value("${server.port}")
    private String port;
    /**
     * 获取端口号信息
     */
    @RequestMapping("/getPort")
    public String getPort(){

        return "当前访问的服务器的端口号为:"+port;
    }
}

项目打包

利用maven方式打包

说明:修改各自的端口号,之后将项目打包
分布式电商项目(三)--Nginx_第11张图片

利用压缩工具打包

将xxx.war改为xxx.zip 之后利用压缩工具修改配置文件,之后再次改为xxx.war即可
分布式电商项目(三)--Nginx_第12张图片

项目发布

命令: java -jar 8081.war 会占用一个终端窗口, 在运行时,终端不能关闭的.
分布式电商项目(三)--Nginx_第13张图片

分布式电商项目(三)--Nginx_第14张图片

释放资源的组合键

ctrl + c

nginx负载均衡测试

轮询策略

说明: 按照nginx.conf中配置文件的顺序依次访问.

#配置商品后台服务器
    server{
        listen  80;
        server_name manage.jt.com;

        location / {
            #代理真实服务器地址
            #proxy_pass http://localhost:8091;
            #映射到集群
            proxy_pass  http://jtWindows;
        }
    }

    #配置tomcat服务器集群  1.默认 轮询策略
    upstream jtWindows {
        server 127.0.0.1:8081;
        server 127.0.0.1:8082;
        server 127.0.0.1:8083;
    }

权重策略

说明: 由于公司的物理服务器可能性能有高有低,为了让高性能的服务器处理更多的数据.

#配置tomcat服务器集群  1.默认 轮询策略  2.权重策略
    upstream jtWindows {
        server 127.0.0.1:8081  weight=6;
        server 127.0.0.2:8082  weight=3;
        server 127.0.0.3:8083  weight=1;
    }

IPHASH策略

说明:如果需要将服务器与IP地址进行绑定时,使用该策略

    #配置tomcat服务器集群  1.默认 轮询策略  2.权重策略  3.ip_hash策略
    upstream jtWindows {
        ip_hash;
        server 127.0.0.1:8081  weight=6;
        server 127.0.0.2:8082  weight=3;
        server 127.0.0.3:8083  weight=1;
    }

原理:
分布式电商项目(三)--Nginx_第15张图片

Nginx属性说明

分布式电商项目(三)--Nginx_第16张图片

down属性

说明:如果服务器宕机,或者该服务器不想为用户继续提供服务,则可以采用shutdown属性进行标识.
nginx访问规则: 如果nginx访问的服务器不能正常的响应,则等待超时之后,访问新的服务器.

#配置tomcat服务器集群  1.默认 轮询策略  2.权重策略  3.ip_hash策略
    upstream jtWindows {
        #ip_hash;
        server 127.0.0.1:8081 down;
        server 127.0.0.1:8082;
        server 127.0.0.1:8083;
    }

backup属性

说明:backup表示备用机.正常情况下,该服务器不会为用户提供服务.但是当服务器宕机,或者服务器正忙时,才会访问该服务器.

#配置tomcat服务器集群  1.默认 轮询策略  2.权重策略  3.ip_hash策略
    upstream jtWindows {
        #ip_hash;
        server 127.0.0.1:8081 down;
        server 127.0.0.1:8082 down;
        server 127.0.0.1:8083 backup;
    }

tomcat服务器高可用机制

高可用: 当服务器发生故障时,通过某种机制可以自动的实现故障的迁移,从而使得用户不受任何的影响.

#配置tomcat服务器集群  1.默认 轮询策略  2.权重策略  3.ip_hash策略
    upstream jtWindows {
        #ip_hash;     down 标识宕机     backup 备用机
        #max_fails=1          表示最大的失败次数
        #fail_timeout=60s    如果访问不通,则在60秒内,不会再次访问故障机
        server 127.0.0.1:8081 max_fails=1 fail_timeout=60s;
        server 127.0.0.1:8082 max_fails=1 fail_timeout=60s;
        server 127.0.0.1:8083 max_fails=1 fail_timeout=60s;
    }

你可能感兴趣的:(nginx)