Nginx入门基础(一)

时间:2022-10-20 19:56:34

Nginx介绍

Nginx 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP服务器。

官方测试Nginx能够支撑5万并发链接,并且cpu、内存等资源消耗却非常低,运行非常稳定。

应用场景

HTTP 服务器,可以做网页静态服务器;

虚拟主机,可以实现在一台服务器虚拟出多个网站,例如个人网站使用的虚拟主机;

反向代理,负载均衡。

Windows环境下

官网下载解压版,双击nginx.exe启动,访问127.0.0.1展示欢迎页。

nginx.conf文件的结构

nginx的配置由特定的标识符(指令符)分为多个不同的模块。

指令符分为简单指令和块指令。

简单指令格式:[name parameters;]

块指令格式:和简单指令格式有一样的结构,但其结束标识符不是分号,而是大括号{},块指令内部可以包含simple directives 和block directives, 可以称块指令为上下文(e.g. events, http, server, location)

conf文件中,所有不属于块指令的简单指令都属于main上下文的,http块指令属于main上下文,server块指令http上下文。

配置静态访问

反向代理

反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。

配置C:\Windows\System32\drivers\etc\hosts文件,新增127.0.0.1 80.itman.com

nginx.conf配置如下:

    server {
        listen       80;
        server_name  80.itman.com;

        location / {
            proxy_pass  http://127.0.0.1:8080;
            index  index.html index.htm;
        }

    }

效果:启动一个Tomcat 127.0.0.1:8080,使用nginx反响代理80.itman.com直接跳转到127.0.0.1:8080

负载均衡(策略)

负载均衡建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性。

负载均衡(Load Balance)其意思就是分摊到多个操作单元上进行执行,例如Web服务器、FTP服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务。

1、轮询(默认)

每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器宕机,能自动剔除。

    upstream backserver {
        server 127.0.0.1:8081;
        server 127.0.0.1:8082;
    } 

    server {
        listen       80;
        server_name  80.itman.com;

        location / {
            proxy_pass  http://backserver;
            index  index.html index.htm;
        }

    }
2、指定权重

指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。

    upstream backserver {
        server 127.0.0.1:8081 weight=1;
        server 127.0.0.1:8082 weight=2;
    }
3、IP绑定

每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。

    upstream backserver {
        ip_hash;
        server 127.0.0.1:8081;
        server 127.0.0.1:8082;
    }
4、宕机轮询规则配置
    upstream backserver { #设定负载均衡的服务器列表
        server 127.0.0.1:8081;
        server 127.0.0.1:8082;
    } 

    server {
        listen       80;
        server_name  80.itman.com;

        location / {
            proxy_pass  http://backserver; #请求转向backserver定义的服务器列表
            index  index.html index.htm; #定义首页索引文件的名称
            proxy_connect_timeout 1; #nginx跟后端服务器连接超时时间(代理连接超时)
            proxy_send_timeout 1; #后端服务器数据回传时间(代理发送超时)
            proxy_read_timeout 1; #连接成功后,后端服务器响应时间(代理接收超时)
        }

    }

Nginx解决网站跨域问题

若http://127.0.0.1:8080工程A中页面直接访问http://127.0.0.1:8081/index8081接口,会产生跨域问题。

A页面代码:

  $(function () {
      $.get("http://127.0.0.1:8081/index8081", {}, function (result) {
         $("#show").html(result);
      })
    })

nginx.conf:

    server {
        listen       80;
        server_name  localhost;
        location /api {
            rewrite  ^/api/(.*)$ /$1 break;
            proxy_pass  http://127.0.0.1:8081;
            index  index.html index.htm;
        }
        location / {
            proxy_pass  http://127.0.0.1:8080;
            index  index.html index.htm;
        }
    }
    server {
        listen       80;
        server_name  www.itman.com;
        location /A {
            proxy_pass  http://a.a.com:81/A;
            index  index.html index.htm;
        }
        location /B {
            proxy_pass  http://b.b.com:81/B;
            index  index.html index.htm;
        }
    }

示例代码

A页面调整:

    $(function () {
        $.get("/api/index8081", {}, function (result) {
            $("#show").html(result);
        })
    })

浏览器跨域的解决方式有很多种:
1.jsonp 需要目标服务器配合一个callback函数。
2.window.name+iframe 需要目标服务器响应window.name。
3.window.location.hash+iframe 同样需要目标服务器作处理。
4.html5的postMessage+ifrme这个也是需要目标服务器或者说是目标页面写一个postMessage,主要侧重于前端通讯。
5.CORS需要服务器设置header:Access-Control-Allow-Origin。
6.nginx反向代理 这个方法一般很少有人提及,但是他可以不用目标服务器配合,不过需要你搭建一个中转nginx服务器,用于转发请求。

Nginx配置防盗链

Nginx配置DDOS

限制请求速度

    limit_req_zone $binary_remote_addr zone=one:10m rate=30r/m; #每分钟30请求

    server {
        limit_req zone=one;
        listen       8080;
        server_name  8080.itman.com;
        location / {
            root   data/www;
            index  index.html index.htm;
        }
    }

`limit_req_zone`命令设置了一个叫one的共享内存区来存储请求状态的特定键值,在上面的例子中是客户端IP($binary_remote_addr)。location块中的`limit_req`通过引用one共享内存区来实现限制访问/login.html的目的。

限制链接数

设置Nginx、Nginx Plus的连接数在一个真实用户请求的合理范围内。比如,你可以设置每个客户端IP连接/store不可以超过10个。