J2EE集群开发部署实战<o:p></o:p>
概述
一个集群系统是一群松散结合的服务器组,形成一个虚拟的服务器,为客户端用户提供统一的服务。对于这个客户端来说,通常在访问集群系统时不会意识到它的服务是由具体的哪一台服务器提供。集群系统一般应具高可用性、可伸缩性、负载均衡、故障恢复和可维护性等特殊性能。越来越多的关键任务和大型应用正运行在J2EE平台上,象银行之类的应用要求很高的可用性(HA),大型系统比如大型网站则要求更好的伸缩性。J2EE集群是最常用的技术,用来提供高可用性和伸缩性的容错服务,单机部署和多机集群化部署差别很大,网上的资料大多语焉不详,即使文档图文并茂,也是到了关键处就部署成功,其实后面还要做些工作才行,且多以单机部署多个server来模拟集群化部署,其实和真正多机部署还是有比较大的差别。本文仅以weblogic应用服务器为例说明集群化部署。
集群层次说明
Web级集群,是J2EE集群中最重要和基础的功能。web层集群技术包括:Web负载均衡和HTTPSession失效转移。web负载均衡,基本的是在浏览器和web服务器之间放置负载均衡器。<o:p></o:p>
应用级集群,是ejb集群,EJB是J2EE应用平台的核心,EJB是用于开发和部署具多层结构的、分布式的、面向对象的Java应用系统跨平台的构件体系结构。主要是业务应用,部署在EJB容器上。<o:p></o:p>
数据库级集群,是oracle数据库设置多个数据库实例,全部映射到数据库。
Weblogic集群概念
Ø Domain:由配置为Administrator Server的WebLogic Server实例管理的逻辑单元,这个单元是有所有相关资源的集合。
Ø Server: 一个相对独立的,为实现某些特定功能而结合在一起的单元。按功能可分为domain server 和managed server。一个Domain 可以包含一个或多个WebLogic Server实例,甚至是Server集群。一个Domain中有一个且只能有一个Server 担任管理Server的功能,其它的Server具体实现一个特定的逻辑功能。
Ø Domain Server:在一个集群中,有且仅有一个domain server,即管理server,该server只负责管理多个Managed server(被管理server),即domain server仅仅是行政领导,考勤之类的活动,如某个managed Sever的状态,是未知(unKnown),还是运行(run),还是停止(shutdown),远程启动等等,不负责具体业务。因此部署时domain server上不要部署具体任务,毕竟人家是当官的吗。
Ø Managed Server:真正的实干家,部署具体的应用。应用及业务逻辑组件被分发在多个受管服务器(Managed Server)。<o:p></o:p>
Weblogic集群要求
Ø 集群中的所有Server必须位于同一网段,并且必须是IP广播(UDP)可到达的
Ø 集群中的所有Server必须使用相同的版本,包括Service Pack
Ø 集群中的Server必须使用永久的静态IP地址。动态IP地址分配不能用于集群环境。如果服务器位于防火墙后面,而客户机位于防火墙外面,那么服务器必须有公共的静态IP地址,只有这样,客户端才能访问服务器 <o:p></o:p>
Ø 使用weblogic的支持集群的licence<o:p></o:p>
项目实战
项目概况
我们的项目是struts—ejb—hibernate—spring,因为hibernate和spring都必须进行初始化且初始化都依赖于servlet,在系统启动时就初始化数据,并且我们在web层和ejb层分别部署为web集群和ejb集群,而hibernate和spring都部署在应用服务器上。为此,我们打了两个部署包,一个是cnlife.war, cnlife_app.ear,其中cnlife.war包部署在web集群上,cnlife
_app.ear部署在ejb集群上,cnlife_app.ear包括两个包,其中一个是cnlifeejb.jar(ejb包),
另外一个是backgroudinit.war,backgroudinit.war用来初始化spring,hibernate的初始化数据。
<o:p> </o:p>
cnlife.war (部署在Web Server)
_backgroudinit.war
|
cnlife_app.ear-| (部署在 Application Server)
|_cnlifeejb.jar
<o:p> </o:p>
Ejb是stateless Session bean,使用ejb的目的就是应用服务器集群,部署示意图如下:
<v:shapetype o:spt="75" coordsize="21600,21600" filled="f" stroked="f" id="_x0000_t75" path="m@4@5l@4@11@9@11@9@5xe" o:preferrelative="t"><v:stroke joinstyle="miter"></v:stroke><v:formulas><v:f eqn="if lineDrawn pixelLineWidth 0"></v:f><v:f eqn="sum @0 1 0"></v:f><v:f eqn="sum 0 0 @1"></v:f><v:f eqn="prod @2 1 2"></v:f><v:f eqn="prod @3 21600 pixelWidth"></v:f><v:f eqn="prod @3 21600 pixelHeight"></v:f><v:f eqn="sum @0 0 1"></v:f><v:f eqn="prod @6 1 2"></v:f><v:f eqn="prod @7 21600 pixelWidth"></v:f><v:f eqn="sum @8 21600 0"></v:f><v:f eqn="prod @7 21600 pixelHeight"></v:f><v:f eqn="sum @10 21600 0"></v:f></v:formulas><v:path o:extrusionok="f" o:connecttype="rect" gradientshapeok="t"></v:path><o:lock v:ext="edit" aspectratio="t"></o:lock></v:shapetype><v:shape id="_x0000_i1025" type="#_x0000_t75" o:ole="" style="WIDTH: 414.75pt; HEIGHT: 109.5pt"><v:imagedata src="file:///C:\DOCUME~1\ADMINI~1\LOCALS~1\Temp\msohtml1\01\clip_image001.emz" o:title=""></v:imagedata></v:shape>
Web级集群
Web集群中使用内存复制策略<o:p></o:p>
weblogic.xml 如下
<!DOCTYPE weblogic-web-app PUBLIC "-//BEA Systems, Inc.//DTD Web Application <o:p></o:p>
8.1//EN" "http://www.bea.com/servers/wls810/dtd/weblogic810-web-jar.dtd"><o:p></o:p>
<o:p> </o:p>
<weblogic-web-app><o:p></o:p>
<session-descriptor><o:p></o:p>
<session-param> <param-name>PersistentStoreType</param-name> <param-value>replicated</param-value> </session-param> <o:p></o:p>
</session-descriptor><o:p></o:p>
</weblogic-web-app><o:p></o:p>
使用JNDI连接EJB集群<o:p></o:p>
Web集群使用JNDI连接EJB集群时,首先在初始化context时,使用如下方式<o:p></o:p>
public static final String PROVIDER_URL = "t3://<st1:chsdate isrocdate="False" month="12" day="30" islunardate="False" w:st="on" year="1899">10.10.21</st1:chsdate>.13,10.10.21.14:8001";<o:p></o:p>
其中<st1:chsdate isrocdate="False" month="12" day="30" islunardate="False" w:st="on" year="1899">10.10.21</st1:chsdate>.13,10.10.21.14是集群中EJB集群中的Management Server地址。<o:p></o:p>
书写规则是:
Managed server使用相同端口号,“t3://acme1,acme2,acme3:<st1:chmetcnv tcsc="0" hasspace="False" sourcevalue="7001" negative="False" numbertype="1" unitname="”" w:st="on">7001”</st1:chmetcnv>
Managed server使用不同端口号,“t3://node1:7001,node2:7002,node3:<st1:chmetcnv tcsc="0" hasspace="False" sourcevalue="7003" negative="False" numbertype="1" unitname="”" w:st="on">7003”</st1:chmetcnv>
Weblogic Proxy<o:p></o:p>
Web级集群负载均衡器,可以使用硬件(如交换机),专门的负载均衡器(如aparche的负载均衡器),我们使用weblogic的软件均衡器,该均衡器除了负载均衡外,还有失效处理机制。<o:p></o:p>
Weblogic.xml<o:p></o:p>
<!DOCTYPE weblogic-web-app PUBLIC "-//BEA Systems, Inc.//DTD Web Application 8.1//EN" "http://www.bea.com/servers/wls810/dtd/weblogic810-web-jar.dtd"><o:p></o:p>
<o:p> </o:p>
<weblogic-web-app> <o:p></o:p>
<context-root>/</context-root><o:p></o:p>
</weblogic-web-app><o:p></o:p>
<o:p> </o:p>
Web.xml<o:p></o:p>
!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd"> <o:p></o:p>
<web-app><o:p></o:p>
<servlet><o:p></o:p>
<servlet-name>HttpClusterServlet</servlet-name><o:p></o:p>
<servlet-class><o:p></o:p>
weblogic.servlet.proxy.HttpClusterServlet<o:p></o:p>
</servlet-class><o:p></o:p>
<init-param><o:p></o:p>
<param-name>WebLogicCluster</param-name><o:p></o:p>
<param-value><o:p></o:p>
<st1:chsdate isrocdate="False" month="12" day="30" islunardate="False" w:st="on" year="1899">10.10.21</st1:chsdate>.13:8001|10.10.21.14:8001<o:p></o:p>
</param-value><o:p></o:p>
</init-param><o:p></o:p>
<init-param><o:p></o:p>
<param-name>DebugConfigInfo</param-name><o:p></o:p>
<param-value>ON</param-value><o:p></o:p>
</init-param><o:p></o:p>
<init-param><o:p></o:p>
<param-name>verbose</param-name> <o:p></o:p>
<param-value>true</param-value> <o:p></o:p>
</init-param><o:p></o:p>
</servlet><o:p></o:p>
<o:p> </o:p>
<servlet-mapping><o:p></o:p>
<servlet-name>HttpClusterServlet</servlet-name><o:p></o:p>
<url-pattern>/</url-pattern><o:p></o:p>
</servlet-mapping><o:p></o:p>
<o:p> </o:p>
<servlet-mapping><o:p></o:p>
<servlet-name>HttpClusterServlet</servlet-name><o:p></o:p>
<url-pattern>*.jsp</url-pattern><o:p></o:p>
</servlet-mapping><o:p></o:p>
<o:p> </o:p>
<servlet-mapping><o:p></o:p>
<servlet-name>HttpClusterServlet</servlet-name><o:p></o:p>
<url-pattern>*.htm</url-pattern><o:p></o:p>
</servlet-mapping><o:p></o:p>
<o:p> </o:p>
<servlet-mapping><o:p></o:p>
<servlet-name>HttpClusterServlet</servlet-name><o:p></o:p>
<url-pattern>*.html</url-pattern><o:p></o:p>
</servlet-mapping><o:p></o:p>
</web-app><o:p></o:p>
其中“<st1:chsdate isrocdate="False" month="12" day="30" islunardate="False" w:st="on" year="1899">10.10.21</st1:chsdate>.13:8001|10.10.21.14:<st1:chmetcnv tcsc="0" hasspace="False" sourcevalue="8001" negative="False" numbertype="1" unitname="”" w:st="on">8001”</st1:chmetcnv>表示用作web集群中的机器地址及端口,用竖线分开。<o:p></o:p>
EJB级集群
设置集群地址<o:p></o:p>
设置集群地址,其中的ip地址为managed server的地址和端口号,多个managed server使用“,”隔开。
Hibernate配置文件设置数据源<o:p></o:p>
使用weblogic连接池配置hibernate配置文件:(片断),其中mypool是数据源的JNDI
<property name="dialect">org.hibernate.dialect.Oracle9Dialect</property>
<property name="hibernate.connection.datasource">mypool</property>
<property name="hibernate.connection.provider_class">org.hibernate.connection.DatasourceConnectionProvider</property>
<property name="hibernate.session_factory_name">hibernate.session_factory</property>
<property name="hibernate.jndi.class">weblogic.jndi.WLInitialContextFactory</property>
<property name="hibernate.jndi.url">t3://localhost:7001/</property>
<property name="hibernate.jdbc.fetch_size">50</property>
<property name="hibernate.jdbc.batch_size">25</property>
<property name="show_sql">true</property>
WebLogic EJB JNDI注意事项<o:p></o:p>
JNDI 表示必须使用“.”隔开,在单机上使用“/”也可以,但在集群中不要使用“/”<o:p></o:p>
<weblogic-enterprise-bean><o:p></o:p>
<ejb-name>DestroyAccountEJB</ejb-name><o:p></o:p>
&
分享到:
相关推荐
J2EE集群设计开发部署(基于IBM+WAS) J2EE集群设计开发部署(基于IBM+WAS)
3.什么是J2EE集群? 4.WEB层集群实现8 4.1.WEB层负载均衡 4.2.HTTP会话的失败转移 4.2.1.数据库持久方案 4.2.2.内存复制方案 4.2.3.Tomcat的方案:多服务器复制 4.2.4.WebLogic, WebSphere, JBoss的方案:结对...
J2EE集群J2EE集群J2EE集群J2EE集群J2EE集群J2EE集群J2EE集群J2EE集群J2EE集群J2EE集群
jsp 真实项目实例 j2ee实战开发项目 java实战开发项目源程序,仅供研究
J2EE集群技术揭秘J2EE集群技术揭秘
J2EE集群 pdf
j2ee开发经验分享j2ee开发经验分享j2ee开发经验分享j2ee开发经验分享j2ee开发经验分享j2ee开发经验分享j2ee开发经验分享j2ee开发经验分享j2ee开发经验分享j2ee开发经验分享j2ee开发经验分享j2ee开发经验分享j2ee开发...
但由于缺乏J2EE规范的支持,J2EE提供厂商实现的集群尽不相同,引起许多J2EE架构师和开发者的麻烦,比如下面: 1. 为什么附带集群能力的商业J2EE服务器如此昂贵?(比不带集群能力的贵10倍) 2. 为什么我在单机上...
中文版的J2EE集群技术讲解。揭开J2EE集群的面纱
主要讲J2EE集群原理 ,很不错。 可以供学习
整个Struts2.2+Spring3.0+hiberate3.6进行的JavaEE开发,主要包括三部分,第一部分JavaEE基础开发知识,第二部分三个框架的用法,第三部分实际应用
润乾报表在J2EE下的部署,与j2ee进行集成时候的一些说明
J2EE集群.学习资料非常丰富。非常有用。可以好好学习。
韩顺平 J2EE视频实战教程JSP详细目录: 韩顺平.j2ee视频实战教程jsp第1讲(上集) 韩顺平.j2ee视频实战教程jsp第1讲(下集) 韩顺平.j2ee视频实战教程jsp第2讲(上集) 韩顺平.j2ee视频实战教程jsp第2讲(中集) 韩顺平.j2ee...
J2EE项目开发与设计随书源码免费分享,喜欢的朋友欢迎自行下载
快逸报表在J2EE下的部署 快逸报表在J2EE下的部署 快逸报表在J2EE下的部署 快逸报表在J2EE下的部署
揭开j2ee集群的神秘面纱,浅显易懂的PDF,值得花两个小时来看
dubbo-app 是J2EE集群分布式基础开发平台,技术栈包括:spring-cloud-alibaba,dubbo、nacos,sentinel,gateway、redis、SpringBoot,MyBatis、Spring-Security业务模块包括:用户管理,角色管理、权限管理,字典管理...