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
大功告成

我服务器上的多服务器多站点配置:

# For more information on configuration, see:
#   * Official English Documentation: http://nginx.org/en/docs/
#   * Official Russian Documentation: http://nginx.org/ru/docs/

user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;

# Load dynamic modules. See /usr/share/nginx/README.dynamic.
include /usr/share/nginx/modules/*.conf;

events {
    worker_connections 1024;
}

http {
    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;
    tcp_nodelay         on;
    keepalive_timeout   65;
    types_hash_max_size 2048;

    include             /etc/nginx/mime.types;
    default_type        application/octet-stream;

    # Load modular configuration files from the /etc/nginx/conf.d directory.
    # See http://nginx.org/en/docs/ngx_core_module.html#include
    # for more information.
    include /etc/nginx/conf.d/*.conf;

    server {
        listen       80 default_server;
        listen       [::]:80 default_server;
        server_name  *.dreamsoso.com;
        #root         /usr/share/nginx/html;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        location / {
	    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 http://47.92.68.170:8083;
	    if ($host ~ ^(dileber)\.dreamsoso\.com$){
              proxy_pass http://localhost:8082;
            }
	    if ($host ~ ^(shop)\.dreamsoso\.com$){
              proxy_pass http://localhost:8083;
            }
	    if ($host ~ ^(www)\.dreamsoso\.com$){
              proxy_pass http://localhost:8083;
            }
	    if ($host ~ ^(gold)\.dreamsoso\.com$){
	      proxy_pass http://localhost:8087;
	    }
	    if ($host ~ ^(me)\.dreamsoso\.com$){
	      proxy_pass http://localhost:8091;
	    }
	    if ($host ~ ^(chain)\.dreamsoso\.com$){
	      proxy_pass http://localhost:8093;
	    }
	    if ($host ~ ^(hunli)\.dreamsoso\.com$){
	      proxy_pass http://localhost:8094;
	    }
        }

 	

        error_page 404 /404.html;
            location = /40x.html {
        }

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

    server {
    	listen 8087;             
    	server_name _;           # 域名:www.example.com 这里 "_" 代表获取匹配所有
    	root /opt/aligold/; # 站点根目录
    	index index.html;
    }


    server {
    	listen 8091;             
    	server_name _;           # 域名:www.example.com 这里 "_" 代表获取匹配所有
    	root /opt/me/; # 站点根目录
    	index index.html;
    }

    server {
    	listen 8093;             
    	server_name _;           # 域名:www.example.com 这里 "_" 代表获取匹配所有
    	root /opt/chain/; # 站点根目录
    	index index.html;
    }

    server {
    	listen 8094;             
    	server_name _;           # 域名:www.example.com 这里 "_" 代表获取匹配所有
    	root /opt/hunli/; # 站点根目录
    	index HMDGO1ND.html;
    }

# Settings for a TLS enabled server.
#
#    server {
#        listen       443 ssl http2 default_server;
#        listen       [::]:443 ssl http2 default_server;
#        server_name  _;
#        root         /usr/share/nginx/html;
#
#        ssl_certificate "/etc/pki/nginx/server.crt";
#        ssl_certificate_key "/etc/pki/nginx/private/server.key";
#        ssl_session_cache shared:SSL:1m;
#        ssl_session_timeout  10m;
#        ssl_ciphers HIGH:!aNULL:!MD5;
#        ssl_prefer_server_ciphers on;
#
#        # Load configuration files for the default server block.
#        include /etc/nginx/default.d/*.conf;
#
#        location / {
#        }
#
#        error_page 404 /404.html;
#            location = /40x.html {
#        }
#
#        error_page 500 502 503 504 /50x.html;
#            location = /50x.html {
#        }
#    }

}


你可能感兴趣的:(服务器集群,nginx,集群,linux,负载均衡,服务器)