`
flylynne
  • 浏览: 373763 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Linux ngix的安装及4种配置策略

 
阅读更多

 

nginx负载均衡的4中配置策略

nginx的upstream目前支持4种方式的分配:

1、轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。

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

例如:

    upstream tomcats {
         server 10.1.1.107:88 weight=10 ;
         server 10.1.1.132:80 weight=10 ;
    }
3、ip_hash
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。

例如:

    upstream tomcats {
         ip_hash;
         server 10.1.1.107:88;
         server 10.1.1.132:80;
    }


4、fair(第三方)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。

5、url_hash(第三方)
按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。

 

 

 

 

安装nginx版本为0.8.36

一。下载nginx

下载地址:http://www.nginx.org/

选择nginx-0.8.36

将该下载包拷贝到/usr/local/下(随意了,找个地方就好)

 

二。安装

cd /usr/local/

tar zxvf nginx-0.8.36.tar.gz

cd nginx-0.8.36

 

按照一些网络资料的介绍,执行如下命令即可完成安装

./configure

make

make install

 

但在实际安装过程中会,执行./configure时,根据系统的配置不同会有不同的错误提示,这里不罗嗦了,安装nginx需要安装openssl和 pcre,

openssl在linux下svn的安装中有过介绍,这里不再赘述,下面只介绍一下pcre的安装,如下:

下载pcre:http://sourceforge.net/projects/pcre/files/ ,选择pcre-8.02.tar.gz,拷贝到/usr/local/下

tar -zxvf pcre-8.02.tar.gz

cd pcre-8.02

./configure --prefix=/usr/local/pcre

make

make install

 

ok,pcre安装完成

 

接着我们安装nginx,

cd /usr/local/nginx-0.8.36

 

./configure --prefix=/usr/local/nginx --with-pcre=/usr/local/pcre-8.02 --with-http_ssl_module --with-openssl=/usr/local/openssl-0.9.8o

 

make

 

make install

 

ok,nginx安装完成。

 

三。配置

 修改 /usr/local/nginx/conf/nginx.conf 来满足自己的需求,下面给一个负载的小实例

Java代码 复制代码 收藏代码
  1. user  nginx;#确保存在这个用户  
  2. worker_processes  2;  
  3.   
  4. error_log  /var/log/nginx/error.log  info;#确保路径存在  
  5.   
  6. pid        logs/nginx.pid;  
  7.   
  8.   
  9. events {  
  10.     worker_connections  1024;  
  11.     multi_accept on;  
  12.     use epoll;  
  13. }  
  14.   
  15.   
  16. http {  
  17.     include       mime.types;  
  18.     default_type  application/octet-stream;  
  19.   
  20.     log_format  main  '$remote_addr - $remote_user [$time_local] $request '  
  21.                       '"$status" $body_bytes_sent "$http_referer" '  
  22.                       '"$http_user_agent" "$http_x_forwarded_for"';  
  23.   
  24.     access_log  /var/log/nginx/access.log  main;  
  25.   
  26.     sendfile        on;  
  27.     #tcp_nopush     on;  
  28.   
  29.     keepalive_timeout  30;  
  30.   
  31.     #gzip  on;  
  32.   
  33.     server_names_hash_bucket_size 128;  
  34.     upstream tomcats {  
  35.          server 192.168.0.104:8888 weight=3;  
  36.          server 192.168.2.94:8888 weight=2;   
  37.          ip_hash;  
  38.      
  39.     }  
  40.   
  41.     server {  
  42.         listen       80;  
  43.   
  44.         charset gb2312;  
  45.         add_header test private;  
  46.   
  47.         location / {  
  48.             root   /usr/local/test/boss/test;  
  49.             index  index.html index.htm index.jsp;  
  50.   
  51.             proxy_pass http://tomcats;  
  52.             proxy_redirect off;  
  53.             proxy_set_header Host $host;  
  54.             proxy_set_header X-Real-IP $remote_addr;  
  55.             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  
  56.             client_max_body_size 50m;  
  57.             client_body_buffer_size 256k;  
  58.             proxy_connect_timeout 10;  
  59.             proxy_send_timeout 15;  
  60.             proxy_read_timeout 15;  
  61.             proxy_buffer_size 4k;  
  62.             proxy_buffers 4 32k;  
  63.             proxy_busy_buffers_size 64k;  
  64.             proxy_temp_file_write_size 64k;  
  65.         }  
  66.   
  67.         error_page   500 502 503 504  /50x.html;  
  68.         location = /50x.html {  
  69.             root   html;  
  70.         }  
  71.   
  72.   }  
  73.   
  74. }  
user  nginx;#确保存在这个用户
worker_processes  2;

error_log  /var/log/nginx/error.log  info;#确保路径存在

pid        logs/nginx.pid;


events {
    worker_connections  1024;
    multi_accept on;
    use epoll;
}


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  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  30;

    #gzip  on;

    server_names_hash_bucket_size 128;
    upstream tomcats {
         server 192.168.0.104:8888 weight=3;
         server 192.168.2.94:8888 weight=2; 
         ip_hash;
   
    }

    server {
        listen       80;

        charset gb2312;
        add_header test private;

        location / {
            root   /usr/local/test/boss/test;
            index  index.html index.htm index.jsp;

            proxy_pass http://tomcats;
            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 50m;
            client_body_buffer_size 256k;
            proxy_connect_timeout 10;
            proxy_send_timeout 15;
            proxy_read_timeout 15;
            proxy_buffer_size 4k;
            proxy_buffers 4 32k;
            proxy_busy_buffers_size 64k;
            proxy_temp_file_write_size 64k;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

  }

}

 注意,这里nginx监听80端口,所以要在iptables里打开80端口。

启动nqinx:

/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf

 

接着访问这台机器的80的端口,如果请求成功,则说明配置成功。

 

为了操作方便,可以自己写一个nginx命令脚本,放到/etc/init.d下,并赋予其执行权限即可,详见附件,执行方法如下:

启动:service nginx start

停止:service nginx stop

重启:service nginx reconfigure

查看状态:service nginx status

 

nginx升级或重新编译时平滑启动的方法:

1.执行编译nginx,并覆盖原来的路径

2.kill -USR2 旧nginx主进程号:此时会在不关闭老进程的情况下启动一个新的nginx进程

3.kill -WINCH 旧nginx主进程号:查看老的工作进程是否还在使用,不使用时就关闭,如下

4.kill -QUIT 旧nginx主进程号:关闭旧nginx主进程

 

 

 

分享到:
评论

相关推荐

    nextcloud在linux和ngix环境下的配置文件

    很多nextcloud在linux和ngix环境下安装时,提供的单独nextcloud的linux配置文件因为存在空格,导致nextcloud启动失败,这个nextcloud是去空格的配置文件

    安装ngix步骤文档

    本文详细介绍了如何在Linux系统上安装Nginx的过程,并提供了具体的配置示例。Nginx因其高效、稳定的特点,在众多项目中被广泛采用。通过本文的指导,您可以顺利地安装和配置Nginx,为自己的项目提供更强大的Web服务...

    linux+nginx+php+mysql环境配置指南.pdf

    * Linux 安装和配置 * Nginx 安装和配置 * PHP 安装和配置 * MySQL 安装和配置 * 防火墙配置 相关资源 * Red Hat Linux 官方文档 * Nginx 官方文档 * PHP 官方文档 * MySQL 官方文档 * Linux 防火墙配置指南

    ngix服务器

    它以其稳定性高、内存占用少、配置简单和处理静态文件速度快等特点,在Web服务领域广受青睐。在移动端直播场景中,Nginx结合RTMP协议,能够有效地实现流媒体的接收和推送,构建起一个高效的直播后台系统。 **RTMP...

    在CentOS下安装Ngix服务及集群PHP、Tomcat

    一、Nginx安装与配置 1. 更新系统: ``` sudo yum update -y ``` 2. 安装EPEL仓库: ``` sudo yum install epel-release -y ``` 3. 安装Nginx: ``` sudo yum install nginx -y ``` 4. 启动Nginx服务: ``` sudo...

    nginx 的window 和linux版本

    本文将探讨Nginx在Windows和Linux平台上的安装与配置,以1.6.3版本为例进行说明。** ### 1. Nginx的Windows版本 在Windows环境下,Nginx可以通过.zip格式的文件进行安装。`nginx-1.6.3.zip`是适用于Windows系统的...

    ngix安装部署脚本,实现自动化安装nginx

    通过该脚本可以直接安装nginx

    ngix部署到linux

    nginx部署到linuix的详细配置,如果不对自己上百度吧

    实战ngix服务器

     本书主要分为4个部分,第1部分为基础篇,介绍了Nginx服务器的安装与配置方法;第2部分为进阶篇,重点介绍了Nginx的配置优化方法、Nginx与PHP/Ruby/Python/JSP/Perl/Memcached的结合配置方法、Nginx HTTP反向代理与...

    Windows下nginx的安装、配置和使用1

    在Windows环境下,安装和配置Nginx是一项基础且重要的任务,尤其对于开发和测试环境而言。Nginx是一款高性能的Web服务器和反向代理服务器,以其轻量级、高效的性能被广泛应用。本文将详细介绍在Windows上安装、配置...

    Nginx安装过程

    本文将详细介绍在CentOS 6环境下如何安装并配置Nginx,以及如何自定义日志格式。 #### 二、安装Nginx ##### 1. 准备工作 确保服务器能够连接到互联网,这是安装任何软件的基础条件。接着,下载Nginx的官方RPM包,...

    ngix + mysql + php 安装包

    这个"ngix + mysql + php 安装包"提供了便捷的一站式解决方案,尤其适合初学者,免去了繁琐的配置过程。 **Nginx** 是一个高性能的HTTP和反向代理服务器,以其轻量级、高并发处理能力而闻名。它的事件驱动模型和非...

    ngix_redis_tomcat集群

    redis,redis,tomcat集群实例,tomcat-session-jar文件夹下是需要的jar包,启动nginx,redis,tomcat后在浏览器中输入http://localhost/test/test2.jsp进行测试。

    ngix tomcat整合.zip

    ngix tomcat整合.zip

    nginx配置,超级详细,适合入门

    nginx配置,超级详细,适合入门,nginx配置,超级详细,适合入门,nginx配置,超级详细,适合入门

    ngix tomcat整合

    ngix tomcat整合

    云服务器环境安装,包括mysql,nginx,java,redis一站式安装

    在"服务器搭建.txt"文件中,应该包含了具体的命令行操作和配置文件的详细说明,遵循这些步骤,即使是对Linux不熟悉的用户也能顺利完成安装。不过,遇到问题时,查阅官方文档、社区论坛和Stack Overflow等资源也是...

Global site tag (gtag.js) - Google Analytics