如果要配置几台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 {
# }
# }
}