Nginx高端成长之路Java

Nginx基础知识

2019-06-04  本文已影响7人  doMyselfzy

本文主要介绍Nginx相关的基础技术,并做一些配置说明,具体实践,需要靠各位自己在实际中进行践行。

Nginx是什么?

Nginx是一个web服务器,主要处理客户端和服务器的请求分发。

特点和优势

  1. 高并发
  2. 热部署
  3. 低功耗

使用和扩展

阿里技术团队在Nginx的基础上,继承全部特性,并做了更多高级封装,延伸出一个开源框架Tengine

概念

正向代理

正向代理

预先知道需要访问的服务器地址,最直接的案例就是VPN代理,明确知道国外机房服务器位置,但是访问的客户机不明。

反向代理

反向代理

预先不知道需要访问的服务器地址,因为当高并发的访问时,会对服务器进行分布式处理,不同业务进行不同的服务器部署,这个时候访问地址不明,但是客户端访问是明确的,此称为反向代理。

反向代理,主要用于服务器集群分布式部署的情况下,反向代理隐藏了服务器的信息

优秀的代理模式

优秀的代理模式

负载均衡

Nginx负载均衡算法有好几种,这里只介绍最常用的一种:轮询

Weight轮询(默认):接收到的请求按照顺序逐一分配到不同的后端服务器,即使在使用过程中,某一台后端服务器宕机,nginx会自动将该服务器剔除出队列,请求受理情况不会受到任何影响。 这种方式下,可以给不同的后端服务器设置一个权重值(weight),用于调整不同的服务器上请求的分配率;权重数据越大,被分配到请求的几率越大;该权重值,主要是针对实际工作环境中不同的后端服务器硬件配置进行调整的。

Nginx命令

  1. 启动方式
    windows下:nginx.exe
    Linux: sudo nginx
  2. 关闭命令
    nginx -s stop(强制停止nginx服务器,如果有未处理的数据,丢弃)
    nginx -s quit(停止nginx服务器,如果有未处理的数据,等待处理完成之后停止)
  3. 重启命令
    nginx -s reload

Nginx最常用的功能

  1. 反向代理
  2. 负载均衡
  3. 静态资源服务器

Nginx配置

nginx.config:最核心的配置文件

基础配置

main                                # 全局配置

events {                            # nginx工作模式配置
}

http {                                # http设置
    ....

    server {                        # 服务器主机配置
        ....
        location {                    # 路由配置
            ....
        }

        location path {
            ....
        }

        location otherpath {
            ....
        }
    }

    server {
        ....

        location {
            ....
        }
    }

    upstream name {                    # 负载均衡配置
        ....
    }
}

Main模块配置说明

Event模块

Http模块

日志配置

Server模块

sever模块配置是http模块中的一个子模块,用来定义一个虚拟访问主机,也就是一个虚拟服务器的配置信息

location模块

location模块是nginx配置中出现最多的一个配置,主要用于配置路由访问信息

在路由访问信息配置中关联到反向代理、负载均衡等等各项功能,所以location模块也是一个非常重要的配置模块

基本配置:

location / {
            root   html;
            index  index.html index.htm;
        }

location /:表示匹配访问根目录
root:用于指定访问根目录时,访问虚拟主机的web目录
index:在不指定访问具体资源时,默认展示的资源文件列表

反向代理配置方式:

location /ole-platform {
            proxy_pass   http://ole-platform_sim/ole-platform;
            proxy_set_header host $host;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            client_max_body_size 2000m;
        }

upstream模块:

upstream ueditor_sim {
      server   192.168.1.178:8312;
    }

upstream模块主要负责负载均衡的配置,通过默认的轮询调度方式来分发请求到后端服务器

ip_hash:指定请求调度算法,默认是weight权重轮询调度,可以指定
server host:port:分发服务器的列表配置

带权重的配置:

upstream test {
    server 192.168.0.1 weight=5;
    ip_hash;
    server 192.168.0.2 weight=7;
}

本次Nginx基础知识分享暂时就介绍到这,如果有其他想学习的,请查阅我的Wiki或者关注我的公众号。

Wiki:https://domyselfzy.github.io/
公众号:

错过时光
上一篇 下一篇

猜你喜欢

热点阅读