• Nginx基础


    Nginx基础

    一、Nginx基本概念
    1.1 什么是Nginx
    Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,其特点是占有内存少,并发能力强,事实上Nginx的并发能力在同类型的网页服务器中表现较好。Nginx可以作为静态页面的web服务器,同时还支持CGI协议的动态语言。如perl、php等,但是不支持java。java程序只能通过与tomcat配合完成。Nginx专为性能优化而开发,性能是其最重要的考量,非常注重效率,能经受住高负载的考验,支持高达50000个并发连接数。

    1.2 代理
    1.2.1 正向代理
    在客户端(浏览器)配置代理服务器,通过代理服务器进行互联网访问。适用于客户端知道目标服务器地址,但由于网络限制等原因无法直接目标服务器,通过代理服务器去访问目标服务器获取服务。

    1.2.2 反向代理
    用户将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器数据后,再返回给客户端。此时的反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器IP,具体是哪个台服务器在提供服务,用于对于客户端用户是无感知的。比如现实中我们通过访问百度的代理服务器对外提供的域名后,代理服务器把我们的请求到他们N多的服务器节点中的一个,节点服务器我们的请求进行搜索后将结果返回。

    1.3 负载均衡
    客户端发送多个请求到服务器,服务器随后分发处理请求到不同的服务器。服务器处理完毕后,再将结果返回给客户端。上述架构模式对于早期的系统相对单一,并发请求相对较少的情况下比较合适。但随着信息数量的不断增长,访问量和数据量的飞速增长,以及系统业务的复杂度增加,这种架构会造成相应客户端的请求日益缓慢,并发量特别大的时候,还容易造成服务器直接崩溃。负载均衡:基于集群的概念,增加服务器的数量,将请求分发到各个服务器上,将原先请求集中到单个服务器上的情况,改为请求分发到多个服务器上,将负载分发到不同的服务器。

    1.4 动静分离
    为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器来解析,加快解析的速度,降低原来单个服务器的压力。

    二、Nginx的配置文件介绍

    2.1 Nginx配置文件位置
    配置文件位置:/usr/local/nginx/conf/nginx.conf

    2.2 Nginx配置文件组成
    配置文件由三部分组成

    2.2.1 全局块
    从配置文件开始到events块之间的内容,主要是设置一些影响Nginx服务器整体运行的配置指令。主要包括:配置运行Nginx服务器的用户(组)、允许生成的work process数、进程PID存放路径、日志存放路径和类型

    配置文件的引入

    work_process值越大,可以支持的并发处理量也越多,但是会受到硬件、软件等设备的制约。

    2.2.2 events块
    events块的指令主要影响Nginx服务器与用户的网络连接,常用的设置包括:是否开启对多work_process下的网络连接进行序列化、是否允许同时接收多个网络连接、选取哪种时间驱动模型来处理连接请求、每个work_process可以同时支持的最大连接数。

    每个work_process支持的最大连接数为1024,这部分配置对Nginx的性能影响较大,在实际中应该灵活配置

    2.2.3 http块

    http块是Nginx服务器配置中最频繁的部分,代理、缓存、日指定以等绝大多数功能和第三方模块的配置都在这里。包括:http全局块、server块

    2.2.3.1 http全局块

    http全局块配置的指令包括:文件引入、MIME-TYPE定义、日志自定义、连接超时时间、单链接请求数上限

    2.2.3.2 server块

    server块与虚拟主机有密切关系,虚拟主机从用户角度看,和一台独立的硬件主机完成一样,该技术的产生是为了节省互联网服务器硬件成本。每个http块可以包括多个server块,而每个server块相当于一个虚拟主机。每个server块也分为全局server块,以及可以同时包含多个的location块。

    全局server块 ,最常见的配置时本虚拟机主机的监听配置和本虚拟机主机的名称或IP配置

    location块
    一个server块可以配置多个location块,location块的作用时基于nginx服务器接收到的请求字符串(如 server_name/uri-string),对虚拟主机名称(IP别名也可)之外的字符串(如 前面的/uri-string)进行匹配,对特定的请求进行处理。地址定向、数据缓存、应答控制等功能,还有许多第三方模块的配置也在这里进行。

  • 相关阅读:
    colormap
    tensorflow4
    tensorflow3
    attention 机制
    tensorflow2
    Android 再谈handler
    Android表格布局之设置边框
    Android AsyncTask异步加载WebAPI
    Android JPush极光推送应用
    Android规划周期任务
  • 原文地址:https://www.cnblogs.com/clar/p/13475551.html
Copyright © 2020-2023  润新知