手记

linux服务器集群部署:之nginx配置

如果要配置几台linux集群~
肯定要配置一下负载均衡~~
这里我是用nginx做负载~~
其实还有其他一类的东西~~貌似很多公司采用nginx
反正我用这个~
我貌似记得好像在某本书上写的nginx的并发在5w左右~~
首先配置了一台接入服务器~~
整个服务器集群都采用的linux
但是为了安全只做了一台拥有外网环境的电脑
作为接入服务器我就把nginx装到上面了


先把nginx的最新源加载到系统里
nginx最新源
rpm -ivh http://nginx.org/packages/centos/6/noarch/RPMS/nginx-release-centos-6-0.el6.ngx.noarch.rpm
然后
yum install nginx 安装一下就好了
注意一下~~防火墙把80端口打开~~
然后开始简单的配置了

nginx简单的一些配置

首先是nginx配置的头部(这部分基本可以省略~~)

//运行用户为nginx,你也可以写root
user nginx;
//设置为“auto”自动检测它,通常设置为系统核心数量
worker_processes auto;
//错误日志位置
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;

其他配置
worker_connections设置可由一个worker进程同时打开的最大连接数。

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

配置你的负载均衡列表
weigth表示权重,权重越大分配比例越大

upstream www.me.com {
    server 192.168.1.3:8080 weight=1;
    server 192.168.2.3:8080  weight=1;
    server 192.168.3.3:8080  weight=2;
    }

http其他配置

#server_tokens 并不会让nginx执行的速度更快,但它可以关闭在错误页面中的nginx版本数字,这样对于安全性是有好处的。

#sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用,
    #必须设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.
    sendfile        on;
    #tcp_nopush     on;
#连接超时时间
    #keepalive_timeout  0;
    keepalive_timeout  65;
    tcp_nodelay        on;

    #开启gzip压缩
    gzip  on;
    gzip_disable "MSIE [1-6]\.(?!.*SV1)";//兼容IE6

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

重点设置如下
设置监听端口和访问的方式

server {
        listen       80;
        server_name  www.me.com;

设置访问的负载均衡处理

location / {

     root   html;
     index  index.html index.htm;
     proxy_pass   http://www.me.com;//这是个列表

还可以配置一下静态文件的处理,就可以不用tomcat处理静态文件了,这个地方是可以用正则表达式的~~

    location ^~ /resources/ {//静态文件请求目录
        root   /data/mm/;//静态文件存放目录
        expires 30d;//过期时间
    }

如果是如上配置的话,如果你想在你代码层面上要拿到用户访问的ip地址是拿不到的~~~~基本上都是本地回环地址
一些其他配置~~

#后端的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;
          client_max_body_size 10m;    #允许客户端请求的最大单文件字节数
          client_body_buffer_size 128k;  #缓冲区代理缓冲用户端请求的最大字节数,
          proxy_connect_timeout 90;  #nginx跟后端服务器连接超时时间(代理连接超时)
          proxy_send_timeout 90;        #后端服务器数据回传时间(代理发送超时)
          proxy_read_timeout 90;         #连接成功后,后端服务器响应时间(代理接收超时)
          proxy_buffer_size 4k;             #设置代理服务器(nginx)保存用户头信息的缓冲区大小
          proxy_buffers 4 32k;               #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
          proxy_busy_buffers_size 64k;    #高负荷下缓冲大小(proxy_buffers*2)
          proxy_temp_file_write_size 64k;  #设定缓存文件夹大小,大于这个值,将从upstream服务器传

然后执行
nginx -s reload
大功告成

30人推荐
随时随地看视频
慕课网APP