Linux下的服务器集群

来源:互联网 发布:淘宝换货小二介入 编辑:程序博客网 时间:2024/05/17 02:10

如果要用几台服务器配置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,你也可以写rootuser nginx;//设置为“auto”自动检测它,通常设置为系统核心数量worker_processes auto;//错误日志位置error_log /var/log/nginx/error.log;pid /run/nginx.pid;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

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

events {worker_connections 2048;multi_accept on;use epoll;}
  • 1
  • 2
  • 3
  • 4
  • 5

配置你的负载均衡列表 
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;    }
  • 1
  • 2
  • 3
  • 4
  • 5

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;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

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

server {        listen       80;        server_name  www.me.com;
  • 1
  • 2
  • 3

设置访问的负载均衡处理

location / {     root   html;     index  index.html index.htm;     proxy_pass   http://www.me.com;//这是个列表
  • 1
  • 2
  • 3
  • 4
  • 5

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

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

如果是如上配置的话,如果你想在你代码层面上要拿到用户访问的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服务器传
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

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

阅读全文
0 0