之前一直用apache来做weblogic的前端,由于nginx对静态内容的出色性能,不得不转投nginx。这里就不再写weblogic的安装了。
下面来配置nginx配置文件,在/opt/nginx/conf下的nginx.conf,为了省事,直接复制我的配置文件过来:#usernobody;worker_processes10;
#error_loglogs/error.log;#error_loglogs/error.lognotice;#error_loglogs/error.loginfo;
#pidlogs/nginx.pid;
events{useepoll;//nginx处理连接的方法,epoll-高效的方法,使用于Linux内核2.6版本及以后的系统。worker_connections51200;}
#access_loglogs/access.logmain;
sendfileon;#tcp_nopushon;
#keepalive_timeout0;keepalive_timeout75;
#gzipon;
upstream99ding{server124.42.*.***:7002weight=10;server124.42.*.***:7001weight=10;}//因为我的weblogic没有做集群,所以只能用nginx自带的负载均衡,不过推荐使用weblogic的集群
#charsetkoi8-r;
#access_loglogs/host.access.logmain;
location~^/(WEB-INF)/{denyall;}
location~\.(htm|html|gif|jpg|jpeg|png|bmp|ico|rar|css|js|zip|txt|flv|swf|mid|doc|ppt|xls|pdf|txt|mp3|wma)${root/opt/html/app;expires24h;}
proxy_set_headerHost$host;proxy_set_headerX-Forwarded-For$proxy_add_x_forwarded_for;proxy_buffer_size4k;proxy_buffers432k;proxy_busy_buffers_size64k;proxy_temp_file_write_size64k;proxy_max_temp_file_size512m;}//最关键的地方,将jsp和do文件转给weblogic处理,这里使用的是上面创建的test(负载均衡的名字),如果不用
#error_page404/404.html;
#redirectservererrorpagestothestaticpage/50x.html#error_page500502503504/50x.html;location=/50x.html{roothtml;}
}
接下来启动服务即可,首先检查配置文件是否有错误:/opt/nginx/sbin/nginx-t-c/opt/nginx/conf/nginx.conf启动服务:/opt/nginx/sbin/nginx-c/opt/nginx/conf/nginx.conf
------------------------
==============================================
=================================================
====================================
====================================================
问题解决了,似乎是因为我对动态页面也设置了缓存才导致的,后来我把
location/{...}中的以下三行注释掉后就没有出现注销失败的问题了
proxy_cache_key$host$uri$is_args$args;proxy_cachecache_one;expires1d;看来动态页面也做缓存的话问题还真多啊
--------------------------
=================================
现在网站发展的趋势对网络负载均衡的使用是随着网站规模的提升根据不同的阶段来使用不同的技术:
一种是通过硬件来进行,常见的硬件有比较昂贵的NetScaler、F5、Radware和Array等商用的负载均衡器,它的优点就是有专业的维护团队来对这些服务进行维护、缺点就是花销太大,所以对于规模较小的网络服务来说暂时还没有需要使用;另外一种就是类似于LVS/HAProxy、Nginx的基于Linux的开源免费的负载均衡软件策略,这些都是通过软件级别来实现,所以费用非常低廉,所以我个也比较推荐大家采用第二种方案来实施自己网站的负载均衡需求。
近期朋友刘鑫(紫雨荷雪)的项目成功上线了,PV达到了亿级/日的访问量,最前端用的是HAProxy+Keepalived双机作的负载均衡器/反向代理,整个网站非常稳定;这让我更坚定了以前跟老男孩前辈聊的关于网站架构比较合理设计的架构方案:即Nginx/HAProxy+Keepalived作Web最前端的负载均衡器,后端的MySQL数据库架构采用一主多从,读写分离的方式,采用LVS+Keepalived的方式。
在这里我也有一点要跟大家申明下:很多朋友担心软件级别的负载均衡在高并发流量冲击下的稳定情况,事实是我们通过成功上线的许多网站发现,它们的稳定性也是非常好的,宕机的可能性微乎其微,所以我现在做的项目,基本上没考虑服务级别的高可用了。相信大家对这些软件级别的负载均衡软件都已经有了很深的的认识,下面我就它们的特点和适用场合分别说明下。
LVS:使用集群技术和Linux操作系统实现一个高性能、高可用的服务器,它具有很好的可伸缩性(Scalability)、可靠性(Reliability)和可管理性(Manageability),感谢章文嵩博士为我们提供如此强大实用的开源软件。
LVS的特点是:
1、抗负载能力强、是工作在网络4层之上仅作分发之用,没有流量的产生,这个特点也决定了它在负载均衡软件里的性能最强的;
2、配置性比较低,这是一个缺点也是一个优点,因为没有可太多配置的东西,所以并不需要太多接触,大大减少了人为出错的几率;
3、工作稳定,自身有完整的双机热备方案,如LVS+Keepalived和LVS+Heartbeat,不过我们在项目实施中用得最多的还是LVS/DR+Keepalived;
4、无流量,保证了均衡器IO的性能不会收到大流量的影响;
5、应用范围比较广,可以对所有应用做负载均衡;
6、软件本身不支持正则处理,不能做动静分离,这个就比较遗憾了;其实现在许多网站在这方面都有较强的需求,这个是Nginx/HAProxy+Keepalived的优势所在。
7、如果是网站应用比较庞大的话,实施LVS/DR+Keepalived起来就比较复杂了,特别后面有WindowsServer应用的机器的话,如果实施及配置还有维护过程就比较复杂了,相对而言,Nginx/HAProxy+Keepalived就简单多了。
Nginx的特点是:
2、Nginx对网络的依赖非常小,理论上能ping通就就能进行负载功能,这个也是它的优势所在;
3、Nginx安装和配置比较简单,测试起来比较方便;
4、也可以承担高的负载压力且稳定,一般能支撑超过几万次的并发量;
5、Nginx可以通过端口检测到服务器内部的故障,比如根据服务器处理网页返回的状态码、超时等等,并且会把返回错误的请求重新提交到另一个节点,不过其中缺点就是不支持url来检测;
7、Nginx不仅仅是一款优秀的负载均衡器/反向代理软件,它同时也是功能强大的Web应用服务器。LNMP现在也是非常流行的web架构,大有和以前最流行的LAMP架构分庭抗争之势,在高流量的环境中也有很好的效果。
8、Nginx现在作为Web反向加速缓存越来越成熟了,很多朋友都已在生产环境下投入生产了,而且反映效果不错,速度比传统的Squid服务器更快,有兴趣的朋友可以考虑用其作为反向代理加速器。
HAProxy的特点是:
1、HAProxy是支持虚拟主机的,以前有朋友说这个不支持虚拟主机,我这里特此更正一下。
2、能够补充Nginx的一些缺点比如Session的保持,Cookie的引导等工作
3、支持url检测后端的服务器出问题的检测会有很好的帮助。
4、它跟LVS一样,本身仅仅就只是一款负载均衡软件;单纯从效率上来讲HAProxy更会比Nginx有更出色的负载均衡速度,在并发处理上也是优于Nginx的。
5、HAProxy可以对Mysql读进行负载均衡,对后端的MySQL节点进行检测和负载均衡,不过在后端的MySQLslaves数量超过10台时性能不如LVS,所以我向大家推荐LVS+Keepalived。
6、HAProxy的算法现在也越来越多了,具体有如下8种:
①roundrobin,表示简单的轮询,这个不多说,这个是负载均衡基本都具备的;
⑤ri,表示根据请求的URI;
⑥rl_param,表示根据请求的URl参数'balanceurl_param'requiresanURLparametername;
⑦hdr(name),表示根据HTTP请求头来锁定每一次HTTP请求;
⑧rdp-cookie(name),表示根据据cookie(name)来锁定并哈希每一次TCP请求
=======================
1、上传weblogic安装文件和nginx的源代码包(略)
2、安装weblogic8.16并破解
#groupaddbea
#useradd-d/bea-gbeaweblogic
#passwdweblogic
#chmod+xserver816_linux32.bin
#su–weblogic
$./server816_linux32.bin
(1)回车
(2)选择1,1-Yes,Iagreewiththetermsofthelicense
(3)选择1,1|CreateanewBEAHome
(4)输入/bea,"BEAHome"=[/bea](根据实际情况选择)
(5)选择1,1|Yes,UsethisBEAhomedirectory[/bea]
(6)选择1,->1|Complete
|InstallthecompleteBEAWebLogicPlatform.
(7)回车,"ProductInstallationDirectory"=[/bea/weblogic81]
(8)选择1,1|Yes,usethisproductdirectory[/bea/weblogic81]
$cp/opt/weblogic7_8_full_license/license.bea/bea/
$cp/opt/weblogic7_8_full_license/weblogic_sp.jar/bea/weblogic81/server/lib/
$chmod+x/bea/weblogic81/server/lib/weblogic_sp.jar
3、部署weblogic8.16的集群
$cd/bea/weblogic81/common/bin/
$./config.sh
(1)选择1,->1|CreateanewWebLogicconfiguration
(2)选择4,4|BasicWebLogicServerDomain8.1.6.0
(3)选择2,2|No
(4)配置管理平台信息
|Name|Value|
|__________________|_____________________|
1|*Name:|AdminServer|
2|Listenaddress:|AllLocalAddresses|
3|Listenport:|6666|
4|SSLlistenport:|N/A|
5|SSLenabled:|false|
(5)选择1,1|Yes
|Name*|Listenaddress|Listenport|SSLlistenport|SSLenabled|
|_________|_____________________|_____________|_________________|_____________|
1|lishi01|AllLocalAddresses|8001|N/A|false|
2|lishi02|AllLocalAddresses|8002|N/A|false|
(6)一路回车,直道出现以下界面
_|_________________________|_________________________________|
1|*Username:|weblogic|
2|*Userpassword:||
3|*Confirmuserpassword:||
4|Description:|Thedefaultadministrationuser|
(7)并且更改为以下
2|*Userpassword:|********|
3|*Confirmuserpassword:|********|
(8)模式的选择,这里我是测试,选择的是开发模式,根据需要自行选择
->1|DevelopmentMode
2|ProductionMode
(9)Jdk的选择,这里也是根据工程的开发使用得jdk来选择,这里我选择的sun的jdk
1|JRockitSDK1.4.2_10-8160@/bea/jrockit81sp6_142_10
2|SunSDK1.4.2_11@/bea/jdk142_11
3|OtherJavaSDK
(10)域名的安装位置,默认就好"TargetLocation"=[/bea/user_projects/domains]
(11)输入你的域名
(12)回车开始安装
4、配置集群
$cd/bea/user_projects/domains/lishi/
$viStartAdmin.sh
nohup./startWebLogic.sh>console.log&
$viStart_All_Server.sh
$chmod+xStartAdmin.sh
$./StartAdmin.sh
等待管理服务器启动后
$chmod+xStart_All_Server.sh
$./Start_All_Server.sh
(1)单击Cluster
(3)输入clustername,点击create
(4)配置组播ip以及端口
(5)添加服务器到Cluster中
(6)依次点击Machines,ConfigureanewMachine
(7)创建Machine
(8)配置ip以及端口
(9)添加服务器到Machine
5、nginx的负载均衡
#tarxzvfnginx-0.7.66.tar.gz
#cdnginx-0.7.66
#make
#makeinstall
#vi/opt/nginx/conf/nginx.conf
usernobodynobody;
worker_processes8;
error_loglogs/error.log;
#error_loglogs/error.lognotice;
#error_loglogs/error.loginfo;
pidlogs/nginx.pid;
events{
useepoll;
worker_connections51200;
includemime.types;
default_typeapplication/octet-stream;
#log_formatmain'$remote_addr-$remote_user[$time_local]"$request"'
sendfileon;
tcp_nopushon;
#keepalive_timeout0;
keepalive_timeout65;
gzipon;
gzip_min_length1k;
gzip_buffers416k;
gzip_comp_level2;
gzip_typestext/plainapplication/x-javascripttext/cssapplication/xml;
gzip_varyon;
upstreamlishi
{
server156.16.34.44:8001;
server156.16.34.44:8002;
server{
listen80;
server_name156.16.34.44;
#location/{
#roothtml;
#indexindex.htmlindex.htm;
#}
#redirectservererrorpagestothestaticpage/50x.html
#
error_page500502503504/50x.html;
location=/50x.html{
roothtml;
location/{
proxy_redirectoff;
proxy_set_headerHost$host;
proxy_set_headerX-Real-IP$remote_addr;
proxy_set_headerX-Forwarded-For$proxy_add_x_forwarded_for;
location/nginxstatus{
stub_statuson;
access_logon;
auth_basic"NginxStatus";}
#auth_basic_user_fileconf/htpassword;
======================================
Nginx是一个轻量级高性能的Web服务器,并发处理能力强,对资源消耗小,无论是静态服务器还是小网站,Nginx表现更加出色,作为Apache的补充和替代使用率越来越高.
绝大多数的Nginx运行在Linux机器上,虽然有Windows移植版,但我也没搭建过.所以本文将以Linux为例讲解,而MacOS或其他Unixlike机器上的操作应该是一样的.
1.进入/usr/local/nginx/conf/vhost目录,创建虚拟主机配置文件demo.neoease.com.conf({域名}.conf).
2.打开配置文件,添加服务如下:
includevhost/*.conf;
4.重启Nginx服务,执行以下语句.
servicenginxrestart
在前面第2步的虚拟主机服务对应的目录加入对PHP的支持,这里使用的是FastCGI,修改如下.
图片作为重要的耗流量大的静态资源,可能网站主并不希望其他网站直接引用,Nginx可以通过referer来防止外站盗链图片.
如果将WordPress的链接结构设定为/%postname%/,/%postname%.html等格式时,需要rewriteURL,WordPress提供Apache的.htaccess修改建议,但没告知Nginx该如何修改.我们可以将WordPress的虚拟主机配置修改如下:
LNMP套件在提供了WordPress为静态配置文件/usr/local/nginx/conf/wordpress.conf,在虚拟主机配置的server范围引用如下即可.
includewordpress.conf;
如果你使用LNMP套件,进入WordPress后台发现会出现404页面,wp-admin后面缺少了斜杆/,请在wordpress.conf最后添加以下语句:
rewrite/wp-admin$$scheme://$host$uri/permanent;
相对Apache,Nignx有更加强大的并发能力,而因为他对进程管理耗用资源也比较少.而Apache比Nginx有更多更成熟的可用模块,bug也比较少.卖主机的IDC选择Nignx,因为高并发允许他们创建更多虚拟主机空间更来钱;淘宝也因此改造Nignx(Tengine)作为CDN服务器,可承受更大压力.