Nginx初级

1.下载和安装
下载地址http://nginx.org/en/download.html
下载后解压即可
2.基本操作
在nginx.exe所在目录,打开命令行工具
start nginx : 启动nginx
nginx -s reload  :修改配置后重新加载生效
nginx -s stop  :快速停止nginx
nginx -s quit  :完整有序的停止nginx
※nginx开启时logs中会创建pid文件
3.conf/nginx.conf文件
#运行用户
#user somebody;
#启动进程,通常设置成和cpu的数量相等
worker_processes  1;
#全局错误日志
error_log  D:/Tools/nginx-1.10.1/logs/error.log;
error_log  D:/Tools/nginx-1.10.1/logs/notice.log  notice;
error_log  D:/Tools/nginx-1.10.1/logs/info.log  info;
#PID文件,记录当前启动的nginx的进程ID
pid        D:/Tools/nginx-1.10.1/logs/nginx.pid;
#工作模式及连接数上限
events {
    worker_connections 1024;    #单个后台worker process进程的最大并发链接数
}
#设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
    #设定mime类型(邮件支持类型),类型由mime.types文件定义
    include       D:/Tools/nginx-1.10.1/conf/mime.types;
    default_type  application/octet-stream;
   
    #设定日志
    log_format  main  '[$remote_addr] - [$remote_user] [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
                     
    access_log    D:/Tools/nginx-1.10.1/logs/access.log main;
    rewrite_log     on;
   
    #sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用,
    #必须设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.
    sendfile        on;
    #tcp_nopush     on;
    #连接超时时间
    keepalive_timeout  120;
    tcp_nodelay        on;
   
    #gzip压缩开关
    #gzip  on;
 
    #设定实际的服务器列表
    upstream zp_server1{
        server 127.0.0.1:8089;
    }
    #HTTP服务器
    server {
        #监听80端口,80端口是知名端口号,用于HTTP协议
        listen       80;
       
        #定义使用www.xx.com访问
        server_name  www.helloworld.com;
       
        #首页
        index index.html
       
        #指向webapp的目录
        root D:\01_Workspace\Project\github\zp\SpringNotes\spring-security\spring-shiro\src\main\webapp;
       
        #编码格式
        charset utf-8;
       
        #代理配置参数
        proxy_connect_timeout 180;
        proxy_send_timeout 180;
        proxy_read_timeout 180;
        proxy_set_header Host $host;
        proxy_set_header X-Forwarder-For $remote_addr;
        #反向代理的路径(和upstream绑定),location 后面设置映射的路径
        location / {
            proxy_pass http://zp_server1;
        }
        #静态文件,nginx自己处理
        location ~ ^/(images|javascript|js|css|flash|media|static)/ {
            root D:\01_Workspace\Project\github\zp\SpringNotes\spring-security\spring-shiro\src\main\webapp\views;
            #过期30天,静态文件不怎么更新,过期可以设大一点,如果频繁更新,则可以设置得小一点。
            expires 30d;
        }
   
        #设定查看Nginx状态的地址
        location /NginxStatus {
            stub_status           on;
            access_log            on;
            auth_basic            "NginxStatus";
            auth_basic_user_file  conf/htpasswd;
        }
   
        #禁止访问 .htxxx 文件
        location ~ /\.ht {
            deny all;
        }
       
        #错误处理页面(可选择性配置)
        #error_page   404              /404.html;
        #error_page   500 502 503 504  /50x.html;
        #location = /50x.html {
        #    root   html;
        #}
    }
}

4.配置反向代理:
在nginx.conf文件中添加include XXX.conf
 
在conf文件夹中创建XXX.conf,编辑内容
 
Nginx在接收到www.test.com访问时,转至10.48.193.2:8089
(www.test.com返回本地)
※在logs中的errors.log可以查看报错
5.负载均衡配置:
   在server之前添加upstream,表示服务器列表
 upstream example {
        #weigth参数表示权值,权值越高被分配到的几率越大
        server 192.168.1.11:80   weight=5;
        server 192.168.1.12:80   weight=1;
        server 192.168.1.13:80   weight=6;
}
添加完成后需修改server中的proxy_pass,如proxy_pass http://example;
在server中还可以增加关于缓存的设置:
 
6.静态站点配置
Nginx本身也是一个静态资源的服务器,当只有静态资源的时候,就可以使用Nginx来做服务器,同时现在也很流行动静分离,就可以通过Nginx来实现,首先看看Nginx做静态资源服务器。
server {
        listen 80;
        server_name  www.test2.com;
        root  /home/liujiepeng/workspace/html/etc/resource/html/;  #指定页面根目录
        index  Home.html;               #指定首页
}
这样如果访问http://localhost 就会默认访问到/home/liujiepeng/workspace/html/etc/resource/html目录下面的index.html,如果一个网站只是静态页面的话,那么就可以通过这种方式来实现部署。
动静分离动静分离是让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开来,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作,这就是网站静态化处理的核心思路。
upstream test{        server localhost:8080;        server localhost:8081;    }
server {        listen      80;       
server_name  localhost;
location / {  root  e:\wwwroot;           
index  index.html; }
 # 所有静态请求都由nginx处理,存放目录为html      
location~\.(gif|jpg|jpeg|png|bmp|swf|css|js)${root    e:\wwwroot;        }
# 所有动态请求都转发给tomcat处理       
location ~ \.(jsp|do)$ { proxy_pass  http://test;       }
error_page  500 502 503 504  /50x.html;        location = /50x.html {     root  e:\wwwroot;        }    } 
这样我们就可以把HTML以及图片和css以及js放到wwwroot目录下,而tomcat只负责处理jsp和请求,例如当我们后缀为gif的时候,Nginx默认会从wwwroot获取到当前请求的动态图文件返回,当然这里的静态文件跟Nginx是同一台服务器,我们也可以在另外一台服务器,然后通过反向代理和负载均衡配置过去就好了,只要搞清楚了最基本的流程,很多配置就很简单了,另外localtion后面其实是一个正则表达式,所以非常灵活。
 
1.反向代理
反向代理应该是 Nginx 做的最多的一件事了,什么是反向代理呢,以下是百度百科的说法:反向代理(Reverse Proxy)方式是指以代理服务器来接受 internet上 的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给 internet 上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。简单来说就是真实的服务器不能直接被外部网络访问,所以需要一台代理服务器,而代理服务器能被外部网络访问的同时又跟真实服务器在同一个网络环境,当然也可能是同一台服务器,端口不同而已。
2.负载均衡
负载均衡也是 Nginx 常用的一个功能,负载均衡其意思就是分摊到多个操作单元上进行执行,例如:Web服务器、FTP服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务。简单而言就是当有2台或以上服务器时,根据规则随机的将请求分发到指定的服务器上处理,负载均衡配置一般都需要同时配置反向代理,通过反向代理跳转到负载均衡。而Nginx目前支持自带3种负载均衡策略,还有2种常用的第三方策略。
1、RR(默认)每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。简单配置  upstream test {      server localhost:8080;      server localhost:8081;  }  server {      listen      81;                                                              server_name  localhost;                                                    client_max_body_size 1024M;
    location / {          proxy_pass http://test;          proxy_set_header Host $host:$server_port;      }  } 这里配置了2台服务器,当然实际上是一台,只是端口不一样而已,而8081的服务器是不存在的,也就是说访问不到,但是我们访问 http://localhost 的时候,也不会有问题,会默认跳转到http://localhost:8080 具体是因为Nginx会自动判断服务器的状态,如果服务器处于不能访问(服务器挂了),就不会跳转到这台服务器,所以也避免了一台服务器挂了影响使用的情况,由于 Nginx 默认是RR策略,所以我们不需要其他更多的设置。
2、权重指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。 例如  upstream test {      server localhost:8080 weight=9;      server localhost:8081 weight=1;  } 那么10次一般只会有1次会访问到8081,而有9次会访问到8080。
3、ip_hash上面的2种方式都有一个问题,那就是下一个请求来的时候请求可能分发到另外一个服务器,当我们的程序不是无状态的时候(采用了session保存数据),这时候就有一个很大的很问题了,比如把登录信息保存到了session中,那么跳转到另外一台服务器的时候就需要重新登录了,所以很多时候我们需要一个客户只访问一个服务器,那么就需要用iphash了,iphash的每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。  upstream test {      ip_hash;      server localhost:8080;      server localhost:8081;  }
4、fair(第三方)按后端服务器的响应时间来分配请求,响应时间短的优先分配。  upstream backend {       fair;       server localhost:8080;      server localhost:8081;  }
5、url_hash(第三方)按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。 在upstream中加入hash语句,server语句中不能写入weight等其他的参数,hash_method是使用的hash算法。  upstream backend {       hash $request_uri;       hash_method crc32;       server localhost:8080;      server localhost:8081;  }
以上5种负载均衡各自适用不同情况下使用,所以可以根据实际情况选择使用哪种策略模式,不过fair和url_hash需要安装第三方模块才能使用,由于本文主要介绍Nginx能做的事情,所以Nginx安装第三方模块不会再本文介绍。
4.正向代理
正向代理,意思是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。客户端才能使用正向代理。当你需要把你的服务器作为代理服务器的时候,可以用Nginx来实现正向代理,但是目前Nginx有一个问题,那么就是不支持HTTPS
发布了11 篇原创文章 · 获赞 0 · 访问量 2021

猜你喜欢

转载自blog.csdn.net/wzyfhyh/article/details/79592181