采用软件nginx实现web服务器集群
nginx:软件负载均衡器 是高并发量http/反向代理服务器。实现windows下IIS的负载均衡
条件:2台服务器
1、cpu:Inter(R) 酷睿 i5 cpu 2.26GHz
内存:2G
系统:windows 7
IIS:IIS 7
nginx:nginx/windows-1.2.7
IP:192.168.2.123
环境:本地
2、cpu:Inter(R) 酷睿 i3 cpu 2.13GHz
内存:2G
系统:windows server 2003
IIS:IIS 6
nginx:nginx/windows-1.2.7
IP:192.168.2.124
环境:本地
注意:本次测试,软件nginx放在本地(192.168.2.123),也就是说放在域名绑定的那台服务器,这台服务器的IIS不能使用80端口,
因为等下nginx软件要使用80端口。
下载nginx的地址如下:
nginx下载:http://nginx.net/
本次测试使用的软件版本是:nginx/windows-1.2.7
下载解压到C:,把目录名改成nginx
时间步骤:
1、在本地192.168.2.123这台服务器IIS创建一个网站,使用端口号为8088。在远程192.168.2.124这台服务器IIS创建一个网站,使用端口号为8088。
两个网站都绑定相同的网站程序。
2、上面设置好两台web服务器的IIS后,下面配置nginx软件来做负载均衡集群。
打开C:\nginx\conf\nginx.conf
1.找到内容server{,在它的上面加入如下内容:
upstream ym.com{
server 192.168.2.123:8088;#真实服务器A(ym-PC)
server 192.168.2.124:8088;#真实服务器B(ym-PC)
}
(该内容是:负载切换使用的服务器网站IP)
2.找到 location / {
root html;
index index.html index.htm;
}
把内容替换成如下: location / {
proxy_pass http://ym.com;
proxy_redirect default;
}
3.找到server{
listen 80;
server_name localhost;
}
把内容替换成如下:
server{#Nginx代理服务器
listen 80;
server_name 192.168.2.26;
}
可参考下面的配置操作:
- worker_processes 1;
- events {
worker_connections 1024;
}- http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;- upstream wgf.com{
server 192.168.1.98; #真实服务器A(sxwgf-PC)
server 192.168.1.99; #真实服务器B(hzdk-vpc)
}- server { #Nginx代理服务器
listen 8088;- server_name localhost;
- location / {
root html;
index index.html index.htm;
proxy_pass http://wgf.com;
proxy_redirect default;
}- error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}- }
}
(这是监听访问域名所绑定的那台服务器的80端口的请求)
4.上述已经配置好了负载均衡。接下来就启动nginx软件,
进入命令提示符CMD,进入c:\nginx,输入nginx命令就可以运行。
停止nginx运行,输入nginx -s stop 即可
5.经过以上配置,现在就可以看下负载效果了。
在本地192.168.2.123这台服务器打开浏览器,输入http://192.168.2.123/,不断刷新,会不断把请求负载到两台服务器上。这样,网站的负载就成功了。
官方说nginx的并发数是50000,实际生产中是30000左右比较稳定。如果网站访问量非常大,可以专门用一台高配置的服务器跑nginx,其他web服务器跑
网站程序,如此负载,就没有太大问题,如果再不行,把网站的一些功能栏目做一个2级域名,2级域名同样做负载,这样就更强了。
nginx软件在linux上跑,性能比在windows上跑要好,所以做负载均衡的服务器,最好用linux跑nginx,而.net开发的网站放到windows服务器的IIS上。
注意:1、找到本地机器的\WINDOWS\system32\drivers\etc,修改hosts文件,添加192.168.2.123 www.ym123.com 注释掉#host
2、找到远程机器的\WINDOWS\system32\drivers\etc,修改hosts文件,添加192.168.2.124 www.ym123.com
3、
upstream ym.com{
server 192.168.2.123:8088;
server 192.168.2.124:8088;
}
server{#Nginx代理服务器
listen 80;
server_name http://www.ym123.com;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
proxy_pass http://ym.com/;
proxy_redirect default;
}
通过以上步骤,就可以使本地和远程机器通过域名访问做实验,皮面实际域名的绑定。
采用软件nginx实现web服务器集群的更多相关文章
- Web服务器集群搭建关键步骤纪要
前言:本文记述了搭建一个小型web服务器集群的过程,由于篇幅所限,系统.软件的安装和基本配置我这里就省略了,只记叙关键配置和脚本内容.假如各位朋友想了解各软件详细配置建议查阅官方文档. 一 需求分析: ...
- Nginx详解-服务器集群
Nginx是什么 代理服务器:一般是指局域网内部的机器通过代理服务器发送请求到互联网上的服务器,代理服务器一般作用在客户端.应用比如:GoAgent,FQ神器. 一个完整的代理请求过程为:客户端首先 ...
- Nginx+Tomcat+Terracotta的Web服务器集群实做
1.准备工作两个Linux服务器,可以用VMware装一个,然后配置好再克隆一个,修改IP即可.Host1:192.168.0.79Host2:192.168.0.80先配置好jdk1.6.0和tom ...
- 使用简单的 5 个步骤设置 Web 服务器集群
通过在多个处理器之间分担工作负载并采用多种软件恢复技术,能够提供高度可用的环境并提高环境的总体 RAS(可靠性.可用性和可服务性).可以得到的好处包括:更快地从意外中断中恢复运行,以及将意外中断对终端 ...
- web服务器集群(多台web服务器)后session如何同步和共享
在访问量上去以后,很多人会采用web集群的方式在满足逐渐增长的用户量.这时候就不得不面对一个问题,那就是在多个服务器下,每次请求都会因为负载均衡而分配到不同的服务器上.用户在登录服务器后,下一次请求被 ...
- web服务器集群
概述 集群和分布式都是从集中式进化而来的.分布式和集群会相互合作的,同时的集群和分布式.在这里重点说说集群 集群是什么? 集群能提高单位时间内处理的任务数量,提升服务器性能 有多台服务器去处理任务,但 ...
- web服务器集群session同步
在做了web集群后,你肯定会首先考虑session同步问题,因为通过负载均衡后,同一个IP访问同一个页面会被分配到不同的服务器上,如果session不同步的话,一个登录用户,一会是登录状态,一会又不是 ...
- nginx的配置服务器集群,负载均衡
在server{}前配置服务器ip和端口号 如: upstream local_tomcat { local_tomcat为访问路径,在下面配置服务器ip及端口号,也可以分配权重(weight==?) ...
- Linux服务器集群系统(四)--转
引用地址:http://www.linuxvirtualserver.org/zh/lvs4.html LVS集群的负载调度 章文嵩 (wensong@linux-vs.org) 2002 年 5 月 ...
随机推荐
- AbstractExecutorService (未完成)
AbstractExecutorService是一个实现了ExecutorService的抽象类.主要实现了ExecutorService的invoke方法.
- [可拖动DIV]刚开通博客顺便就写了点东西!
说说我自己的思路 首先需要一个初始div div { border: 1px #333 solid; width: 200px; height: 50px; } <div id="od ...
- Android开发系列之SQLite
上篇博客提到过SQLite,它是嵌入式数据库,由于其轻巧但功能强大,被广泛的用于嵌入式设备当中.后来在智能手机.平板流行之后,它作为文件型数据库,几乎成为了智能设备单机数据库的必选,可以随着安卓app ...
- MongoDB的timezone问题
MongoDB是以UTC格式来存储所有时间的,查询的时候也是返回UTC时间,不提供在数据库连接级别的timezone支持,这就带来一个问题:无法使用groupby对日期进行聚合,因为你所在的timez ...
- 纯原生js移动端图片压缩上传插件
前段时间,同事又来咨询一个问题了,说手机端动不动拍照就好几M高清大图,上传服务器太慢,问问我有没有可以压缩图片并上传的js插件,当然手头上没有,别慌,我去网上搜一搜. 结果呢,呵呵...诶~又全是基于 ...
- PHP程序员的技术成长规划(送给迷茫的你)
按照了解的很多PHP/LNMP程序员的发展轨迹,结合个人经验体会,抽象出很多程序员对未来的迷漫,特别对技术学习的盲目和慌乱,简单梳理了这个每个阶段PHP程序员的技术要求,来帮助很多PHP程序做对照设定 ...
- 大数据时代的技术hive:hive的数据类型和数据模型
在上篇文章里,我列举了一个简单的hive操作实例,创建了一张表test,并且向这张表加载了数据,这些操作和关系数据库操作类似,我们常把hive和关系数据库进行比较,也正是因为hive很多知识点和关系数 ...
- poj 2778 DNA Sequence ac自动机+矩阵快速幂
链接:http://poj.org/problem?id=2778 题意:给定不超过10串,每串长度不超过10的灾难基因:问在之后给定的长度不超过2e9的基因长度中不包含灾难基因的基因有多少中? DN ...
- ASP.Net 添加 Interop for Word, excel 插件
1:在服务器上安装office的Excel软件. 2:在"开始"->"运行"中输入dcomcnfg.exe启动"组件服务" 3:依次双 ...
- asp.net gridview 绑定图片字段,图片不显示
在浏览器中查看,图片属性. 右键查看,若后面出现若干%20 可使用以下办法解决. 备份表数据,然后删除表,把图片路径字符串在数据库中应使用varchar()类型. 原因可以查看vchar() var ...