澳门新浦京娱乐场网站-www.146.net-新浦京娱乐场官网
做最好的网站

澳门新浦京娱乐场网站:Windows负载均衡布局方式

一、Nginx简介

一、下载Nginx
解压到C:nginx目录下
二、在两台服务器上分别建一个网站:
S1:192.168.16.35:8054
S2:192.168.16.16:8089
二、找到目录
C:nginxconfnginx.conf
打开nginx.conf
配置如下:

Nginx的Web缓存服务与新浪网的开源NCACHE模块

什么是web缓存
Web缓存位于内容源web服务器和客户端之间,当用户访问一个 URL时,web缓存服务器回去后端web源服务器取回要输出的内容,然后,当下一个请求到来时,如果访问的是相同的URL,web缓存服务器直接输出内容给客户端,而不是像源服务器再次发送请求。web缓存降低了内容源web服务器、数据库的负载,减轻了网络延迟,提高了用户的响应速度,增强了用户体验。
最著名的还要数Squid Cache,其主要在Unix一类系统运行。

Nginx的Web缓存服务
Nginx从0.7.48后支持类似于Squid的缓存模块。这个缓存是把URL及相关组合当做key,用md5算法对key进行希哈,得到硬盘上对应的希哈路径,从而将缓存内容保存在该目录内。支持任意URL链接。同时也支持404/301/302这样的非200状态码。
Nginx的Web缓存服务主要用于proxy_cache相关指令集和fastcgi相关指令集构成,前者用于反向代理时,对后端内容源进行缓存,后者主要用于对FastCDI的动态程序进行缓存。两者功能基本一样。

proxy_cache相关指令集
1、proxy_cache指令
语法:proxy_cache zone_name;
默认值:none
使用环境:http,server,location
该指令用于设置那个缓存区将被应用,zone_name的值为proxy_cache_path指令创建的缓存区明称。
2、proxy_cache_path指令
语法:proxy_cache_path path[levels=number] keys_zone=zone_name:zone_size[incative=time] [max_size=size];
默认值:none
使用环境:HTTP
eg:
proxy_cache_path /data0/proxy_cache_dir levels=1:2 keys_zone=cache_one: 500m inactive=1d max_size=30g;
注意该指令只能在http标签内配置,levels指定该缓存有两层hash目录,第一层为1个字母,第二层为2个字母,保存文件名类似于/data0/proxy_cache_dir/c/29/fdg35415fg35f4gsdf2g1535gh465h;key_zone参数用来为缓存区起名,500m指定内存空间大小为500MB;inactive的1d是如果缓存数据在1天之内没有被访问,将被删除;max_size的30g是指硬盘的缓存空间为30GB。
3proxy_cache_methods指令
语法:proxy_cache_methods [GET HEAD POST];
默认值:proxy_cache_methods GET HEAD;
使用环境:http,server,location
该指令用于设置用于缓存那些HTTP方法,默认缓存 HTTP GET/HEAD 方法,不缓存HTTP POST方法。
4proxy_cache_min_uses指令
语法:proxy_cache_min_uses the_number;
默认值:proxy_cache_min_uses 1;
使用环境:http,server,location
该指令设置缓存最小的使用次数,默认值是1.
5、proxy_cache_valid指令
语法:proxy_cache_valid reply_code [reply_code…]time;
默认值:none
使用环境:http,server,location
该指令用于对不同的返回状态码的URL设置不同的缓存时间,例如:
proxy_cache_valid 200 302 10m;
proxy_cache_valid 404 1m;
如果不指定状态吗,直接指定时间,则只有200、301、302状态的URL缓存5分钟。
6、proxy_cache_key指令
语法:proxy_cache_key line;
默认值:none
使用环境:http,server,location
该指令用来设置web缓存的key值,Nginx根据key值md5希哈存储缓存。一般根据‘$host(域名)、$request_uri(请求路径)’等组合变量合成proxy_cache_key.例如:proxy_cache_key "$host:$server_port$uri$is_args$args";

proxy_cache完整示例
su
yum -y install pcre//安装pcre
wget
tar zxvf ngx_cache_purge-2.3.tar.gz//获取nginx_cache_purge
cd nginx-1.6.3//进入你的nginx文件目录(nginx安装请参考前面的博客)
 ./configure --user=www --group=www --addmodule=../ngx_cache_purge-2.3 --prefix=/usr/local/webserver/nginx --with-http_stub_status_module --with-http_ssl_module
配置nginx.conf
cd /usr/local/webserver/nginx/conf

#user  www www;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;

events {
    use epoll;
    worker_connections  1024;
}

http {
    include      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  logs/access.log  main;

    #charset utf-8;

    server_name_hash_bucket_size 128;
    client_header_buffer_size 32k;
    large_client_header_buffers 4 32k;

    sendfile        on;
    #tcp_nopush    on;

    keepalive_timeout  30;

    tcp_nodely  on;

    proxy_temp_path /data0/proxy_temp_path;

    proxy_temp_path /data0/proxy_temp_path levels=1:2 key_zone=cache_one:200m inactive=1d max_size=30g;
    upstream my_sever_pool{
        server 192.168.1.2:80 weight=1 max_fails=2 fail_timeout=30s;
        server 192.168.1.3:80 weight=1 max_fails=2 fail_timeout=30s;
        server 192.168.1.4:80 weight=1 max_fails=2 fail_timeout=30s;

    }

 

    #gzip  on;

    server {
        listen      80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            proxy_set_header Host $host;
        proxy_set_header X-Forward-For $remote_addr;
        proxy_pass ;
      # root  html;
            #index  index.html index.htm;
        }
    location ~ .*.(gif|jpg|jpeg|png|bmp|swf|js|css)$
    {
        #使用web缓存区cache_one
        proxy_cache cache_one;

        #对不同状态码设置不同缓存时间
        proxy_cache_valid 200 304 12h;
        proxy_cache_valid 301 302 1m;
        proxy_cache_valid any im;
        #设置web缓存的key值,nginx根据key值md5希哈存储缓存,这里根据“域名/URL 参数”组合成key。
        proxy_cache_key $host$uri$is_args$args;
        #反向代理,访问后端内容源服务器
        proxy_set_header Host $host;
        proxy_set_header X-Forwarded-For $remote_addr;
        proxy_pass http:my_server_pool;
    }
    #用于清除缓存,假设一个URL为
    location ~ /purge(/.*)
    {
        #设定只允许指定的IP或IP段才可以清除URL缓存。
        allow      127.0.0.1
        allow      192.168.0.0/16;
        deny        all;
        proxy_cache_purge cache_one $shot$1$is-args$args;
    }
    access_log 0ff

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page  500 502 503 504  /50x.html;
        location = /50x.html {
            root  html;
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ .php$ {
        #    proxy_pass  ;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ .php$ {
        #    root          html;
        #    fastcgi_pass  127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /.ht {
        #    deny  all;
        #}
    }

    # another virtual host using mix of IP-, name-, and port-based configuration
    #
    #server {
    #    listen      8000;
    #    listen      somename:8080;
    #    server_name  somename  alias  another.alias;

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

    # HTTPS server
    #
    #server {
    #    listen      443 ssl;
    #    server_name  localhost;

    #    ssl_certificate      cert.pem;
    #    ssl_certificate_key  cert.key;

    #    ssl_session_cache    shared:SSL:1m;
    #    ssl_session_timeout  5m;

    #    ssl_ciphers  HIGH:!aNULL:!MD5;
    #    ssl_prefer_server_ciphers  on;

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

}

更多Nginx相关教程见以下内容:

CentOS 6.2实战部署Nginx MySQL PHP

使用Nginx搭建WEB服务器

搭建基于Linux6.3 Nginx1.2 PHP5 MySQL5.5的Web服务器全过程

CentOS 6.3下Nginx性能调优

CentOS 6.3下配置Nginx加载ngx_pagespeed模块

CentOS 6.4安装配置Nginx Pcre php-fpm

Nginx安装配置使用详细笔记

Nginx日志过滤 使用ngx_log_if不记录特定日志

Nginx 的详细介绍:请点这里
Nginx 的下载地址:请点这里

本文永久更新链接地址:

什么是web缓存 Web缓存位于内容源web服务器和客户端之间,当用户访问一个 URL时,web缓存服务器...

1. nginx是什么

Nginx是HTTP服务器和反向代理,同时也是一个IMAP/POP3代理服务器。

Nginx特点:高性能,高稳定性,丰富的功能,简单的配置,低的资源消耗。

Nginx 负载均衡在金山逍遥网中的实际应用

在金山逍遥网中,前端负载均衡服务器采用的是Nginx,两台Nginx服务器为一组,承担多种类型的负载均衡服务,两台负载均衡服务器均处于活动状态,各自绑定一个公网虚拟IP,作为负载均衡服务器,当其中一个发生故障时,另一台接管发生故障服务器的虚拟IP。配置nginx.conf代码如下

代码:

user www www;
work_processes 8;
error_log /data1/logs/nginx_error.log crit;
pid /usr/local/webserver/nginx/nginx.pid;

#specifies the value for maximum file descriptors that can be opened by this process worker_rlimit_nofile 51200

events
{
    use epoll;
    worker_connections 51200;
}

http
{
    include    mine.types;
    default_type  application/octet-strem;

    #charset utf-8

    server_names_hash_bucket_size 128k;
    client_header_buffer_size  32k;
    large_client_header_buffers 4 32k;

    sendfile on;
    #tcp_nopush on;

    keepalive_timeout 30;
    tcp_nodelay on;

    fastcgi_connect_timeout  300;
    fastcgi_send_timeout 300;
    fastcgi_read_timeout 300;
    fastcgi_buffer_size 64k;
    fastcgi_buffers 4 64k;
    fastcgi_busy_buffers_size  128k;
    fastcgi_temp_file_write_size  128k;

    gzip on;
    gzip_min_length 1k;
    gzip_buffers  4 16k;
    gzip_http_version 1.1
    gzip_comp_level 2;
    gzip_types  text/plain  application/x-javascript  text/css  application/xml;
    gzip_vary on;

    limit_zone anti_attack $binary_remote_addr 10m;

    #允许客户端请求的最大单文件字节数
    client_max_body_size 300m;

    #缓冲区代理缓冲用户端的最大字节数 可以理解为现存到本地再传给用户
    client_body_size 128k;

    #跟后端服务器连接的超时时间_发起握手等候响应超时时间
    proxy_connect_time 600;

    #连接成功后_等待后端服务器响应时间_其实已经进入后端的派对等候处理
    proxy_read_timeout  600;

    #后端回传时间_规定时间内传完所有数据
    proxy_send_timeout  600;

    #代理请求缓存区,保存用户的头信息以供Nginx进行规则处理
    proxy_buffer_size  16k;
    proxy_buffers  4  32k;
    proxy_busy_buffers_size  64k;
    proxy_temp_file_write_size 64k;

    #缓存
    proxy_temp_path /data2/proxy_temp_path;
    proxy_cache_path  /data2/proxy_cache_path levels=1:2 keys_zone=cache_one:200m inactive=1d max_size=5;

    upstream myserver_pool{
        server xx.xx.xx.1:80 weight=1 max_fails=2 fail_timeout=30s;
        server xx.xx.xx.2:80 weight=1 max_fails=2 fail_timeout=30s;
        server xx.xx.xx.3:80 weight=1 max_fails=2 fail_timeout=30s;
    }

    upstream php_server_pool{
        server xx.xx.xx.4:80 weight=1 max_fails=2 fail_timeout=30s;
        server xx.xx.xx.5:80 weight=1 max_fails=2 fail_timeout=30s;
        server xx.xx.xx.6:80 weight=1 max_fails=2 fail_timeout=30s;
        server xx.xx.xx.7:80 weight=1 max_fails=2 fail_timeout=30s;
        server xx.xx.xx.8:80 weight=1 max_fails=2 fail_timeout=30s;
    }

    upstream bbs_server_pool{
        ip=hash;
        server xx.xx.xx.9:80 max_fails=2 fail_timeout=30s;
        server xx.xx.xx.10:80 max_fails=2 fail_timeout=30s;
        server xx.xx.xx.11:80 max_fails=2 fail_timeout=30s;
        server xx.xx.xx.12:80 max_fails=2 fail_timeout=30s;
    }

    upstream cms_server_pool{
        server xx.xx.xx.13:80 weight=1 max_fails=2 fail_timeout=30s;
        server xx.xx.xx.14:80 weight=1 max_fails=2 fail_timeout=30s;
    }

    upstream pic_server_pool{
        server xx.xx.xx.15:80 weight=1 max_fails=2 fail_timeout=30s;
        server xx.xx.xx.16:80 weight=1 max_fails=2 fail_timeout=30s;
    }

    upstream xoyohimsg_server_pool{
        server xx.xx.xx.17:3245;
        server xx.xx.xx.18:3245 down;
    }

    #xoyo.com域名调转到www.xoyo.com

    server
    {
        listen 80;
        server_name xiyo.com;

        rewrite ^/(.*) http:xoyo.com/ permanent;

        acces_log /data1/logs/xoyo.com_access.log;
    }

    #用户中心HTTP/SSL加密浏览
    server
    {
        listen 443;
        server_name my.xoyo.com

        ssl on;
        ssl_cretificate  my.xoyo.com.crt;
        ssl_cretificate_key my.xoyo.com.key;

    location /
    {
        proxy_pass ;
        proxy_set_header Host my.xoyo.com;
        proxy_set_header X-Forward-For $remote_addr;
    }
    access_log /data1/logs/my.xoyo.com_access.log;

    }

    #图片服务器,不同的路径访问后端不同的服务器
    server
    {
        listen 80;
        server_name pic.xoyo.com;

        location /cms/
        {
        proxy_pass ;
        proxy_set_header Host pic.xoyo.com;
        proxy_set_header X-Forward-For $remote_addr;
        }
        access_log /data1/logs/pic.xoyo.com_access.log;
    }

    #音频电台文件下载,进行简单防盗链
    #limit_zone media %binary_remote_addr 10m;
    server
    {
        listen 80;
        server_name media.xoyo.com;

        location /
        {
        proxy_pass ;
        proxy_set_header Host $host;
        proxy_set_header X-Forward-For $remote_addr;

        valid_reference nine blocked www.xoyo.com *.xoyo.com  www.kingsoft.com  *.kingsoft.com  www.kingsoft.cn  *.kingsoft.cn;
        if ($invalid_referers){
            rewrite ^/ ;
        }
        }
        access_log /data1/logs/media.xoyo.com_access.log;
    }
    #“逍遥有聊”WebIM产品的负载均衡,反向代理两种HTTP服务器
    server
    {
        listen  80;
        server_name hi.xoyo.com;
    #反向代理一款定制开发的高性能消息队列HTTP服务器
    location /recmessage.xoyo
    {
        proxy_pass ;
        proxy_set_header Host $host;
    }

    location /
    {
        proxy_pass ;
        proxy_set_header Host $host;
        proxy_set_header X-Forward-For $remote_addr;

    }

    access_log /data1/logs/hi.xoyo.com_access.log;

    #论坛负载均衡并对图片、Flash、JavaScript、CSS、静态HTML进行Web缓存
    server {
    listen  80;
    server_name bbs.xoyo.com *.bbs.xoyo.com bbs.xoyo.kingsoft.com;

    location /
    {
        proxy_pass ;
        proxy_set_header Host $host;
        proxy_set_header X-Forward-For $remote_addr;

    }

    location ~ .*.(gif|jpg|jpeg|png|bmp|swf|js|css|html|shtml)$
    {
        proxy_cache  cache_one;
        proxy_cache_valid  200 10m;
        proxy_cache_valid  304 1m;
        proxy_cache_valid  301 302 ih;
        proxy_cache_valid  any 1m;
        proxy_cache_key $host$uri$is_args$args;
        proxy_set_header  Host  $host;
        proxy_set_header X-Forward-For $remote_addr;
        proxy_pass ;

    }
    log_format bbs '$remote_addr $host  $remote_user [$time_local] "$request"'
    '"$status" $body_bytes_sent "$http_referer"'
    '"$http_user_agent"  "$http_x_forwarded_for"';
access_log /data1/logs/bbs.xoyo.com_access.log bbs;

}
    #论坛附件反向代理,限制下载速度为256k/秒
    server{
        listen 80;
        server_name  att03.bbs.xoyo.com  att02.bbs.xoyo.com  att01.bbs.xoyo.com;

    location /{
        #限制下载速度为256k/s
        limit_rate 256k;
        proxy_pass ;
        proxy_set_header Host $host;
        proxy_set_header X-Forward-For $remote_addr;
    }
    access_log off;
}

#逍遥江湖SNS社区,管理后台定位到一台服务器上,并对图片,flash,javascript,CSS进行web缓存

    server
    {
        listen  80;
        server_name  hu.xoyo.com  *.hu.xoyo.com;

        location /
        {

        proxy_pass ;
        proxy_set_header Host $host;
        proxy_set_header X-Forward-For $remote_addr;
        }
    location ~ .*.(gif|jpg|jpeg|png|bmp|swf|js|css)$
    {
        proxy_cache  cache_one;
        proxy_cache_valid  200 10m;
        proxy_cache_valid  304 1m;
        proxy_cache_valid  301 302 ih;
        proxy_cache_valid  any 1m;
        proxy_cache_key $host$uri$is_args$args;
        proxy_set_header  Host  $host;
        proxy_set_header X-Forward-For $remote_addr;
        proxy_pass ;
    }

    location ~ ^/admincp.php
    {
        proxy_set_header  Host  $host;
        proxy_set_header X-Forward-For $remote_addr;
        proxy_pass ;

    }
    access_log /data1/logs/hu.xoyo.com_accsee.log;
    }
}

更多Nginx相关教程见以下内容:

CentOS 6.2实战部署Nginx MySQL PHP

使用Nginx搭建WEB服务器

搭建基于Linux6.3 Nginx1.2 PHP5 MySQL5.5的Web服务器全过程

CentOS 6.3下Nginx性能调优

CentOS 6.3下配置Nginx加载ngx_pagespeed模块

CentOS 6.4安装配置Nginx Pcre php-fpm

Nginx安装配置使用详细笔记

Nginx日志过滤 使用ngx_log_if不记录特定日志

Nginx 的详细介绍:请点这里
Nginx 的下载地址:请点这里

本文永久更新链接地址:

负载均衡在金山逍遥网中的实际应用 在金山逍遥网中,前端负载均衡服务器采用的是Nginx,两台Nginx服务器为一组,承担多种类型的负...

   Nginx是一款开源代码的高性能HTTP服务器和反向代理服务器,同时支持IMAP/POP3/SMTP代理服务

复制代码 代码如下:

Nginx的基本HTTP功能:

  1. 提供静态文件和index文件,生成自动索引,打开文件描述符缓存。

  2. 使用缓存加速反向代理,简单的负载平衡和容错。

  3. 使用缓存机制加速远程FastCGI服务器的访问,简单的负载均衡和容错。

4. 模块化的结构,过滤器包括gzip、字节range、chunk响应、XLST、SSI和图像大小调整过滤、被传递到后台服务器多个SSI指令在单个页面的并行处理。

  1. 支持SSL和TLS SNI。

1.Nginx工作原理

#使用的用户和组,window下不指定
#user nobody;
#指定工作衍生进程数(一般等于CPU总和数或总和数的两倍,例如两个四核CPU,则总和数为8)
worker_processes 1;
#指定错误日志文件存放路径,错误日志级别可选项为【debug|info|notice|warn|error|crit】
#error_log logs/error.log;
#error_log logs/error.log notice;
error_log logs/error.log info;
#指定pid存放路径
#pid logs/nginx.pid;

其他HTTP功能:

  1. 基于名称和基于IP的虚拟服务器。

  2. 支持Keep-alive和管道连接

  3. 灵活的配置。

  4. 重新配置和在线升级而不用中断对客户访问的处理。

  5. 访问日志的格式,缓存日志写入和快速日志轮询。

  6. 3xx-5xx错误代码重定向。

  7. 重写模块。

  8. 基于客户端IP地址和HTTP基本认证的访问控制。

  9. 基于HTTP协议的PUT,DELETE,MKCOL,COPY和MOVE方法。

  10. FLV流文件。

  11. 速度限制。

  12. 限制同时连接数或者是来自同一IP地址的请求。

  13. 嵌入式语言PERL解析。

       Nginx由内核和模块组成,完成工作是通过查找配置文件将客户端请求映射到一个location block(location是用于URL匹配的命令),location配置的命令会启动不同模块完成工作。

#工作模式及连接数上限
events {
#使用网络I/O模型,Linux系统推荐使用epoll模型,FreeBSD系统推荐使用kqueue;window下不指定
#use epoll;
#允许的连接数
worker_connections 1024;
}

邮件代理服务器功能。

       Nginx模块分为核心模块,基础模块和第三方模块。

#设定http服务器,利用他的反向代理功能提供负载均衡支持
http {
#设定mime类型
include 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"';

架构和可扩展性

  1. 非阻塞。

  2. 事件驱动。

  3. 单线程。

  4. 一个master和几个worker。

  5. 高效的资源使用。

  6. 高度的模块化。

服务器的类型:一下所有角色,nginx都可以胜任。

  1. Web服务器,主要用于提供HTTP的访问,例如Nginx, Apache, IIS等。

2. 应用程序服务器。用于应用程序的运行,包括的工作有:客户会话管理、业务逻辑管理、数据操作等。

3. 代理服务器。通常代理服务器都设置一个较大的缓冲区,当有外界的信息通过时,同时也将其保存到缓冲区中,当其他用户再访问相同的信息时, 则直接由缓冲区中取出信息,传给用户,以提高访问速度。

4. 反向代理服务器。反向代理服务器上缓存的页面,不是由于某些用户访问某个页面后留下的缓存,而是根据网站运维的策略定期、定时地生成一些后台服务器的页面缓存。

5. 后台服务器。一种说法,如果使用Nginx作为反向代理,那么Apache就是后台服务器。

6. CDN缓存服务器。就是缓存服务器,而且是反响代理的应用,在网站部署中,算是一种策略。对于远距离访问,选择距离和时间更短的服务器,是反向代理的另一种应用。

           核心模块:HTTP模块、EVENT模块(事件)、MAIL模块。

#access_log logs/access.log main;
log_format main '$remote_addr - $remote_user [$time_local]'
'"$request" $status $bytes_sent'
'"$http_referer" "$http_user_agent" "$http_x_forwarded_for"'
'"$gzip_ratio"';
log_format download '$remote_addr - $remote_user [$time_local]'
'"$request" $status $bytes_sent'
'"$http_referer" "$http_user_agent"'
'"$http_range" "$sent_http_content_range"';

2. 使用Nginx

           基础模块:HTTP Access模块、HTTP FastCGI模块、HTTP Proxy模块、HTTP Rewrite模块。

#设定请求缓冲
client_header_buffer_size 1k;
large_client_header_buffers 4 4k;

安装Nginx

linux下进入root用户。安装所有库的过程中碰到的缺少C编译器、缺少C 编译器等一系列问题,把错误提示google一下即可。

1.安装PCRE库

$ cd /usr/local

$ wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.40.tar.gz

$ tar -zxvf pcre-8.40.tar.gz

$ cd pcre-8.40

$ ./configure

$ make

$ make install

2.安装zlib库

$ cd /usr/local

$ wget

$ tar -zxvf zlib-1.2.11.tar.gz

$ cd zlib-1.2.11

$ ./configure

$ make

$ make install

3.安装openssl

$ wget

$ tar -zxvf openssl-1.0.1j.tar.gz

$ cd openssl-1.0.1j

$ ./config

$ make

$ make install

  1. 安装nginx

$ wget

$ tar -zxvf nginx-1.8.0.tar.gz

$ cd nginx-1.8.0 

$ ./configure --prefix=/usr/local/nginx --with-pcre=/usr/local/pcre-8.40 --with-zlib=/usr/local/zlib-1.2.11

$ make

$ make install 

configure命令参数,根据前面库的路径来定。

           第三方模块:HTTP Upstream Request Hash模块、Notice模块、HTTP Access Key模块。

#设定access log
access_log logs/access.log main;
client_header_timeout 3m;
client_body_timeout 3m;
send_timeout 3m;

基本命令

所有命令在nginx安装目录下进行。

可以使用ps 来grep nginx的安装目录。

  1. 启动

$./nginx

  1. 停止

$ ./nginx -s stop

  1. 检查配置文件

$ ./nginx -t

  1. 查看版本

$ ./nginx -v 

2.性能优势

sendfile on;
tcp_nopush on;
tcp_nodelay on;
#keepalive_timeout 0;
keepalive_timeout 65;

配置文件

nginx配置文件在$NGINX_PATH/conf/nginx.conf.

下面对Q9的配置环境nginx配置文件做详细解释。

user  apache; #用户是apache,用户后面也可以接用户组名。

worker_processes  1;#

error_log logs/errors.log info; #错误日志配置,第一个参数是日志路径,第二个参数是日志级别,高于参数的级别都会打印。

pid        logs/nginx.pid;# 用来存储nginx进程的pid

events {

    use epoll;#指定使用的事件驱动模型。epoll是一种基于Linux 2.6 操作系统下有效的模型。

    worker_connections  300;#设置每个worker线程所能处理的连接数。

}

http {

    include    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  logs/access.log  main;#访问日志,

    #access_log off;

    sendfile        on;#是否使用sendfile,该方法在内核中操作,更高效

    tcp_nopush    on;#套接字选项TCP_NOPUSH,设置为on,Nginx会尝试在单个TCP包中发送整个HTTP响应头。

    fastcgi_connect_timeout 75;#定义和fastCGI服务器建立连接的超时时长

    fastcgi_send_timeout 600;#和fastCGI服务器传输一个请求的超时时长

    fastcgi_read_timeout 600;#从fastCGI服务器读取一个响应的超时时长

    fastcgi_buffers 1024 8k;#从fastCGI服务器读取响应使用缓存的数量和大小

    fastcgi_buffer_size 8k;#读取FastCGI服务器读取响应的第一片段的缓存大小

    client_body_buffer_size 2m;#指定了客户端请求体缓存的大小

    client_max_body_size 500m;#请求体的最大大小

    proxy_ignore_client_abort on;#客户端关闭连接时,是否关闭和代理服务器的连接

    proxy_connect_timeout 75;#和代理服务器建立连接的超时时长

    proxy_send_timeout 600;#和代理服务器传输请求的超时时长

    proxy_read_timeout 600;#和代理服务器读取响应的超时时长

    proxy_buffers 1024 16k;#从代理服务器读取响应的缓存数量和大小。

    proxy_buffer_size 16k;##读取代理服务器读取响应的第一片段的缓存大小

    send_timeout 600;#设置响应超时,不是整个传输响应的时间,而是两个读操作之间的时间

    keepalive_timeout  65;#服务器端保持连接的时间

    gzip on;#是否压缩响应包

    gzip_vary on;#是否在响应头插入Vary: Accept-Encoding,如果gzip等命令生效的话

    gzip_comp_level 3;#压缩级别,1-9

    gzip_types *;支持任何MIME类型

    #gzip_types multipart/related application/xop xml application/octet-stream application/soap xml mtom/xop;

    server {

        listen      80;#监听端口

        listen      443 ssl;

        server_name  localhost;#虚拟服务器名称

        ssl_certificate      /etc/httpd/conf/server.crt;#证书文件

        ssl_certificate_key  /etc/httpd/conf/server.key;#密钥文件

        ssl_session_cache    shared:SSL:10m;#存储session参数的方式和大小。shared是所有worker线程共享,1MB可以存储4000session,每个cache都有专名。不同虚拟服务器可以共享cache。

        ssl_session_timeout  300;#会话超时时间,该时间内,client可以重用session参数

        autoindex on;#允许以HTML格式浏览nginx的目录

        autoindex_exact_size off;#显示出文件的确切大小,单位是bytes。

        autoindex_localtime on;#显示的文件时间为文件的服务器时间

        rewrite_by_lua_file /usr/local/openresty/nginx/inflate.lua;#rewrite阶段处理,可以实现复杂的转发/重定向逻辑;

        location /emsdownload/ {

            alias /home/express/upload_file/;

        }

        location /emsreport/ {

            alias /home/express/upload_file/report/;

        }

        location /express-ear-1.0-express-ejb3-1.0/ {

            proxy_pass ;

            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; #为了获取真实的客户端IP

        }

        location /express-war/ {

            proxy_pass ;

        }

        location /njs/ {

            proxy_pass ;

        }

        error_page  500 502 503 504  /50x.html;#5XX错误会显示该网页

        location = /50x.html {

            root  html;

        }

    }

    server {

        listen      80;

        listen      8000;

        server_name  q9app-uat1.800best.com;

        root /var/www/html/a;

        #access_log  logs/vhost_access.log  main;

        error_log  logs/vhost_error.log  warn;

    }

}

       web服务器,处理静态文件、索引文件以及自动索引效率高。

#开启gzip模块
gzip on;
gzip_min_length 1100;
gzip_buffers 4 8k;
gzip_types text/plain application/x-javascript text/css application/xml;

       代理服务器,快速高效反向代理,提升网站性能。

output_buffers 1 32k;
postpone_output 1460;

       负载均衡器,内部支持Rails和PHP,也可支持HTTP代理服务器,对外进行服务。同时支持简单容错和利用算法进行负载均衡。

server_names_hash_bucket_size 128;
client_max_body_size 8m;

       性能方面,Nginx专门为性能设计,实现注重效率。采用Poll模型,可以支持更多的并发连接,并在大并发时占用很低内存。

fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
fastcgi_buffer_size 64k;
fastcgi_buffers 4 64k;
fastcgi_busy_buffers_size 128k;
fastcgi_temp_file_write_size 128k;
gzip_http_version 1.1;
gzip_comp_level 2;
gzip_vary on;

       稳定性方面,采用分阶段资源分配技术,使CPU资源占用率低。

#设定负载均衡的服务器列表
upstream localhost {
#根据ip计算将请求分配各那个后端tomcat,可以解决session问题
ip_hash;
#同一机器在多网情况下,路由切换,ip可能不同
#weigth参数表示权值,权值越高被分配到的几率越大
#server localhost:8080 weight=1;
#server localhost:9080 weight=1;
server 192.168.16.35:8054 max_fails=2 fail_timeout=600s;
server 192.168.16.16:8089 max_fails=2 fail_timeout=600s;
}

       高可用性方面,支持热备,启动迅速。

#设定虚拟主机
server {
listen 80;
server_name 192.168.16.16;

二、配置文件详解

#charset koi8-r;
charset UTF-8;
#设定本虚拟主机的访问日志
access_log logs/host.access.log main;
#假如访问 /img/*, /js/*, /css/* 资源,则直接取本地文档,不通过squid
#假如这些文档较多,不推荐这种方式,因为通过squid的缓存效果更好
#location ~ ^/(img|js|css)/ {
# root /data3/Html;
# expires 24h;
# }
#对 "/" 启用负载均衡
location / {
root html;
index index.html index.htm index.aspx;

Nginx配置文件(/usr/local/nginx/conf/nginx.conf)

proxy_redirect off;
#保留用户真实信息
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
#允许客户端请求的最大单个文件字节数
client_max_body_size 10m;
#缓冲区代理缓冲用户端请求的最大字节数,可以理解为先保存到本地再传给用户
client_body_buffer_size 128k;
#跟后端服务器连接超时时间 发起握手等候响应超时时间
proxy_connect_timeout 12;
#连接成功后 等待后端服务器响应时间 其实已进入后端的排队之中等候处理
proxy_read_timeout 90;
#后端服务器数据回传时间 就是在规定时间内后端服务器必须传完所有数据
proxy_send_timeout 90;
#代理请求缓存区 这个缓存区间会保存用户的头信息一共Nginx进行规则处理 一般只要能保存下头信息即可
proxy_buffer_size 4k;
#同上 告诉Nginx保存单个用的几个Buffer最大用多大空间
proxy_buffers 4 32k;
#如果系统很忙的时候可以申请国内各大的proxy_buffers 官方推荐 *2
proxy_busy_buffers_size 64k;
#proxy 缓存临时文件的大小
proxy_temp_file_write_size 64k;
proxy_next_upstream error timeout invalid_header http_500 http_503 http_404;
proxy_max_temp_file_size 128m;

配置文件主要包括全局配置,I/O事件配置和HTTP配置这三大块内容,配置语句的格式“关键字      值;”(末尾以分号表示结束),以“#”开始的部分表示注释。

proxy_pass ;
}

1)全局配置

#error_page 404 /404.html;

#Nginx的worker进程运行用户以及用户组

# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}

#user  nobody nobody;

# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ .php$ {
# proxy_pass ;
#}

#Nginx开启的进程数

# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
#location ~ .php$ {
# root html;
# fastcgi_pass 127.0.0.1:9000;
# fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
# include fastcgi_params;
#}

worker_processes  1;

# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#location ~ /.ht {
# deny all;
#}
}

#worker_processes auto;

# another virtual host using mix of IP-, name-, and port-based configuration
#
#server {
# listen 8000;
# listen somename:8080;
# server_name somename alias another.alias;

#以下参数指定了哪个cpu分配给哪个进程,一般来说不用特殊指定。如果一定要设的话,用0和1指定分配方式.

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

#这样设就是给1-4个进程分配单独的核来运行,出现第5个进程是就是随机分配了。eg:

# HTTPS server
#
#server {
# listen 443;
# server_name localhost;

#worker_processes 4     #4核CPU

# ssl on;
# ssl_certificate cert.pem;
# ssl_certificate_key cert.key;

#worker_cpu_affinity 0001 0010 0100 1000

# ssl_session_timeout 5m;

       

# ssl_protocols SSLv2 SSLv3 TLSv1;
# ssl_ciphers HIGH:!aNULL:!MD5;
#澳门新浦京娱乐场网站:Windows负载均衡布局方式,Nginx的Web缓存服务与乐乎网的开源NCACHE模块。 ssl_prefer_server_ciphers on;

#定义全局错误日志定义类型,[debug|info|notice|warn|crit]

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

#error_log  logs/error.log  info;

}

#指定进程ID存储文件位置

四、双击C:nginxnginx.exe文件,启动nginx。
五、打开浏览器:
输入 进行访问
测试:关掉S1上的网站,再刷新浏览器访问;关掉S2上的网站,打开S1的网站,刷新浏览器访问。

#pid        logs/nginx.pid;

核心代码1:在http{}里面加入

#一个nginx进程打开的最多文件描述符数目,理论值应该是最多打开文件数(ulimit -n)与nginx进程数相除,但是nginx分配请求并不是那么均匀,所以最好与ulimit -n的值保持一致。

复制代码 代码如下:

#vim /etc/security/limits.conf

#设定负载均衡的服务器列表
upstream localhost {
#根据ip计算将请求分配各那个后端tomcat,可以解决session问题
澳门新浦京娱乐场网站:Windows负载均衡布局方式,Nginx的Web缓存服务与乐乎网的开源NCACHE模块。ip_hash;
#同一机器在多网情况下,路由切换,ip可能不同
#weigth参数表示权值,权值越高被分配到的几率越大
#server localhost:8080 weight=1;
#server localhost:9080 weight=1;
server 192.168.1.98:8081 max_fails=2 fail_timeout=600s;
server 192.168.1.98:8082 max_fails=2 fail_timeout=600s;

#  *                soft    nproc          65535

核心代码2:在server {}添加

#  *                hard    nproc          65535

复制代码 代码如下:

#  *                soft    nofile         65535

#对 "/" 启用负载均衡
location / {
root html;
index index.html index.htm index.aspx;

#  *                hard    nofile         65535

proxy_redirect off;
#保留用户真实信息
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
#允许客户端请求的最大单个文件字节数
client_max_body_size 10m;
#缓冲区代理缓冲用户端请求的最大字节数,可以理解为先保存到本地再传给用户
client_body_buffer_size 128k;
#跟后端服务器连接超时时间 发起握手等候响应超时时间
proxy_connect_timeout 12;
#连接成功后 等待后端服务器响应时间 其实已进入后端的排队之中等候处理
proxy_read_timeout 90;
#后端服务器数据回传时间 就是在规定时间内后端服务器必须传完所有数据
proxy_send_timeout 90;
#代理请求缓存区 这个缓存区间会保存用户的头信息一共Nginx进行规则处理 一般只要能保存下头信息即可
proxy_buffer_size 4k;
#同上 告诉Nginx保存单个用的几个Buffer最大用多大空间
proxy_buffers 4 32k;
#如果系统很忙的时候可以申请国内各大的proxy_buffers 官方推荐 *2
proxy_busy_buffers_size 64k;
#proxy 缓存临时文件的大小
proxy_temp_file_write_size 64k;
proxy_next_upstream error timeout invalid_header http_500 http_503 http_404;
proxy_max_temp_file_size 128m;
proxy_pass ;
}

worker_rlimit_nofile 65535;

以下是一些补充工具:
Nginx负载均衡是一个很神奇的技术,很多人都不能很好的掌握这个技术,今天在这里我们向大家详细的介绍下有关Nginx负载均衡的问题。今天小试了一下Nginx负载均衡,真是爽啊!Nginx是什么?

2)事件配置

Nginx (”engine x”) 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器。 Nginx 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,它已经在该站点运行超过两年半了。Igor 将源代码以类BSD许可证的形式发布。尽管还是测试版,但是,Nginx 已经因为它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名了。

1. events {

首先是配置十分的简单,而且功能非常强大。真是相见恨晚。先来看看配置文件怎么写吧

#use [ kqueue | rtsig | epoll | /dev/poll | select | poll ]; epoll模型是Linux 2.6以上版本内核中的高性能网络I/O模型,如果跑在FreeBSD上面,就用kqueue模型。

复制代码 代码如下:

use epoll;

worker_processes 1;
events {
worker_connections 1024;
}
http{
upstream myproject {
#这里指定多个源服务器,ip:端口,80端口的话可写可不写
server 192.168.43.158:80;
server 192.168.41.167;
}
server {
listen 8080;
location / {
proxy_pass ;
}
}
}

#每个进程可以处理的最大连接数,理论上每台nginx服务器的最大连接数为worker_processes*worker_connections。理论值:worker_rlimit_nofile/worker_processes

Nginx负载均衡有哪些功能呢?

#注意:最大客户数也由系统的可用socket连接数限制(~ 64K),所以设置不切实际的高没什么好处

如果后面的服务器其中一台坏了,它能自动识别,更牛的是它好了之后Nginx可以马上识别服务器A和B,如果A的响应时间为3,B的响应时间为1,那么Nginx会自动调整访问B的概率是A的3倍,真正做到Nginx负载均衡好的,安装完成了。我在make的时候报了个错,说HTTP Rewrite 模块 有问题,我就

worker_connections  65535;   

./configure –without-http_rewrite_module
然后再make,make install就可以了。

#worker工作方式:串行(一定程度降低负载,但服务器吞吐量大时,关闭使用并行方式)

安装好了之后新建一个配置文件,把上面的配置文件内容拷进去,当然要修改你的IP,保存为比如 load_balance.conf然后启动:

#multi_accept on;

/usr/local/Nginx/sbin/Nginx -c load_balence.conf

  }

由于Nginx的作者是俄国人,所以英文的文档也不是那么完善,对于我来说Nginx的最大优点还是配置简单,功能强大。我曾经配过 apache-jk,那真的不是一般人能配的。太复杂了,而且只能用来做tomcat的Nginx负载均衡。

3)http参数

Nginx就没有这个限制,对它来说后面是什么服务器是完全透名的。Nginx就一点不爽,它本身目前还不能在windows下面跑。写了一大堆,哈哈。~~说的不对的大家指出哈

#文件扩展名与文件类型映射表

您可能感兴趣的文章:

  • nginx 作为反向代理实现负载均衡的例子
  • Nginx负载均衡的4种方案配置实例
  • windows安装nginx部署步骤图解(反向代理与负载均衡)
  • windows使用nginx实现网站负载均衡测试实例
  • Nginx 安装笔记(含PHP支持、虚拟主机、反向代理负载均衡)
  • Nginx做NodeJS应用负载均衡配置实例
  • linux服务器之LVS、Nginx和HAProxy负载均衡器对比总结
  • Nginx geoip模块实现地区性负载均衡
  • 使用nginx来负载均衡 本文在window与linux下配置nginx实现负载
  • nginx实现负载均衡和动静分离

include 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"';

#定义日志的格式。后面定义要输出的内容。

#1.$remote_addr 与$http_x_forwarded_for 用以记录客户端的ip地址;

#2.$remote_user :用来记录客户端用户名称;

#3.$time_local :用来记录访问时间与时区;

#4.$request  :用来记录请求的url与http协议;

#5.$status :用来记录请求状态;

#6.$body_bytes_sent :记录发送给客户端文件主体内容大小;

#7.$http_referer :用来记录从那个页面链接访问过来的;

#8.$http_user_agent :记录客户端浏览器的相关信息

#连接日志的路径,指定的日志格式放在最后。

#access_log  logs/access.log  main;

#只记录更为严重的错误日志,减少IO压力

 error_log logs/error.log crit;

#关闭日志

#access_log  off;

#默认编码

#charset utf-8;

#服务器名字的hash表大小

 server_names_hash_bucket_size 128;

#客户端请求单个文件的最大字节数

 client_max_body_size 8m;

#指定来自客户端请求头的hearerbuffer大小

 client_header_buffer_size 32k;

#指定客户端请求中较大的消息头的缓存最大数量和大小。

large_client_header_buffers 464k;

#开启高效传输模式。

sendfile        on;

#防止网络阻塞

tcp_nopush on;

tcp_nodelay on;    

#客户端连接超时时间,单位是秒

keepalive_timeout 60;

#客户端请求头读取超时时间

client_header_timeout 10;

#设置客户端请求主体读取超时时间

client_body_timeout 10;

#响应客户端超时时间

send_timeout 10;

#FastCGI相关参数是为了改善网站的性能:减少资源占用,提高访问速度。

fastcgi_connect_timeout 300;

fastcgi_send_timeout 300;

fastcgi_read_timeout 300;

fastcgi_buffer_size 64k;

fastcgi_buffers 464k;

fastcgi_busy_buffers_size 128k;

fastcgi_temp_file_write_size 128k;

 

gzip模块设置

#开启gzip压缩输出

gzip on;

#最小压缩文件大小

gzip_min_length 1k;

#压缩缓冲区

gzip_buffers 416k;

#压缩版本(默认1.1,前端如果是squid2.5请使用1.0)

gzip_http_version 1.0;

#压缩等级 1-9 等级越高,压缩效果越好,节约宽带,但CPU消耗大

gzip_comp_level 2;

#压缩类型,默认就已经包含text/html,所以下面就不用再写了,写上去也不会有问题,但是会有一个warn。

gzip_types text/plain application/x-javascript text/css application/xml;

#前端缓存服务器缓存经过压缩的页面

gzip_vary on;

4)虚拟主机基本设置

#虚拟主机定义

server {

#监听端口

listen       80;

#访问域名

server_name  localhost;

#编码格式,若网页格式与此不同,将被自动转码

#charset  utf-8;

#虚拟主机访问日志定义

#access_log  logs/host.access.log  main;

#对URL进行匹配

location /{

#访问路径,可相对也可绝对路径

root   html;

#首页文件。以下按顺序匹配

index  index.html index.htm;

 } 

#错误信息返回页面

#error_page  404              /404.html;

# redirect server error pages to the static page /50x.html

#error_page   500 502 503 504  /50x.html;

location = /50x.html {       //错误页面配置

root   html;

  }

#访问URL以.php结尾则自动转交给127.0.0.1

# proxy the PHP scripts to Apache listening on 127.0.0.1:80

#

#location ~ .php$ {

#    proxy_pass   ;

#    }

#php脚本请求全部转发给FastCGI处理

# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000

#

#location ~ .php$ {

#    root           html;

#    fastcgi_pass   127.0.0.1:9000;

#    fastcgi_index  index.php;

#    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;

#    include        fastcgi_params;

#    }

#禁止访问.ht页面 (需ngx_http_access_module模块)

# deny access to .htaccess files, if Apache's document root

# concurs with nginx's one

#

#location ~ /.ht {

#    deny  all;

#    }

    }

#HTTPS虚拟主机定义

# HTTPS server

#

#server {

#    listen       443 ssl;

#    server_name  localhost;

#    ssl_certificate      cert.pem;

#    ssl_certificate_key  cert.key;

#    ssl_session_cache    shared:SSL:1m;

#    ssl_session_timeout  5m;

#    ssl_ciphers  HIGH:!aNULL:!MD5;

#    ssl_prefer_server_ciphers  on;

#    location / {

#        root   html;

#        index  index.html index.htm;

#    }

#    }

5)Nignx状态监控

#Nginx运行状态,StubStatus模块获取Nginx自启动的工作状态(编译时要开启对应功能)

#location /NginxStatus {

#    #启用StubStatus的工作访问状态    

#    stub_status    on;

#    #指定StubStaus模块的访问日志文件

#    access_log    logs/Nginxstatus.log;

#    #Nginx认证机制(需Apache的htpasswd命令生成)

#    #auth_basic    "NginxStatus";

#    #用来认证的密码文件

#    #auth_basic_user_file    ../htpasswd;    

#    }

访问:http://IP/NginxStatus(测试就不加密码验证相关)

6)反向代理

#以下配置追加在HTTP的全局变量中

 

#nginx跟后端服务器连接超时时间(代理连接超时)

proxy_connect_timeout      5;

#后端服务器数据回传时间(代理发送超时)

proxy_send_timeout         5;

#连接成功后,后端服务器响应时间(代理接收超时)

proxy_read_timeout         60;

#设置代理服务器(nginx)保存用户头信息的缓冲区大小

proxy_buffer_size          16k;

#proxy_buffers缓冲区,网页平均在32k以下的话,这样设置

proxy_buffers              432k;

#高负荷下缓冲大小(proxy_buffers*2)

proxy_busy_buffers_size    64k;

#设定缓存文件夹大小,大于这个值,将从upstream服务器传

proxy_temp_file_write_size 64k;

#反向代理缓存目录

proxy_cache_path /data/proxy/cache levels=1:2 keys_zone=cache_one:500m inactive=1d max_size=1g;

#levels=1:2 设置目录深度,第一层目录是1个字符,第2层是2个字符

#keys_zone:设置web缓存名称和内存缓存空间大小

#inactive:自动清除缓存文件时间。

#max_size:硬盘空间最大可使用值。

#指定临时缓存文件的存储路径(路径需和上面路径在同一分区)

proxy_temp_path /data/proxy/temp

    

#服务配置

server {

#侦听的80端口

listen       80;

server_name  localhost;

location /{

#反向代理缓存设置命令(proxy_cache zone|off,默认关闭所以要设置)

proxy_cache cache_one;

#对不同的状态码缓存不同时间

proxy_cache_valid 200 304 12h;

#设置以什么样参数获取缓存文件名

proxy_cache_key $host$uri$is_args$args;

#后7端的Web服务器可以通过X-Forwarded-For获取用户真实IP

proxy_set_header Host $host;

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  

#代理设置

proxy_pass   ;

#文件过期时间控制

expires    1d;

   }

#配置手动清楚缓存(实现此功能需第三方模块 ngx_cache_purge)

location ~ /purge(/.*) {

allow    127.0.0.1;

deny    all;

proxy_cache_purge    cache_one    $host$1$is_args$args;

 }

#设置扩展名以.jsp、.php、.jspx结尾的动态应用程序不做缓存

location ~.*.(jsp|php|jspx)?$ {

proxy_set_header Host $host;

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  

proxy_pass ; }

7)负载均衡

#负载均衡服务器池

upstream my_server_pool {  

#调度算法 

#1.轮循(默认)(weight轮循权值) 

#2.ip_hash:根据每个请求访问IP的hash结果分配。(会话保持)   

#3.fair:根据后端服务器响应时间最短请求。(upstream_fair模块)

#4.url_hash:根据访问的url的hash结果分配。(需hash软件包)

#参数:

#down:表示不参与负载均衡

#backup:备份服务器

#max_fails:允许最大请求错误次数

#fail_timeout:请求失败后暂停服务时间。

 server   IP:80 weight=1 max_fails=2 fail_timeout=30;

 server   IP:80 weight=2 max_fails=2 fail_timeout=30;

  }

#负载均衡调用

server {

    ...

 location / {

  proxy_pass ;

 }

 }

8)URL重写

#根据不同的浏览器URL重写

if($http_user_agent ~Firefox){

rewrite ^(.*)$  /firefox/$1 break;

}

if($http_user_agent ~ MSIE){

rewrite ^(.*)$  /msie/$1 break;

}

#实现域名跳转 

 location /{

 rewrite ^/(.*)$ permanent;   

}

9)IP限制

#限制IP访问

location /{

deny   IP;

allow   IP/24; 

allow   IP;

deny   all;

}

10)Nginx相关命令

#启动nginx

nginx

##检查配置

nginx –t 

#关闭nginx

nginx -s stop

#平滑重启

kill -HUP `cat /usr/local/nginx/logs/ginx.pid`

本文由澳门新浦京娱乐场网站发布于澳门新浦京娱乐场网站,转载请注明出处:澳门新浦京娱乐场网站:Windows负载均衡布局方式