如果要配置几台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
大功告成