﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>BlogJava-&lt;strong&gt;&lt;font style="font-size:25px;"&gt;vista&lt;/font&gt;&lt;/strong&gt;-随笔分类-开源※类库</title><link>http://www.blogjava.net/vista/category/15809.html</link><description>&lt;font style="font-size:18px;"&gt;回顾※展望&lt;font&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;潜心技术&amp;&amp;不再搁浅
&lt;a onClick="谢谢点击" href="http://blog.csdn.net/images/blog_csdn_net/Diego1983/hehe.jpg" target="_blank"&gt;&lt;img src="http://blog.csdn.net/images/blog_csdn_net/Diego1983/hehe.jpg"  height="40" border="0" /&gt;&lt;/a&gt;</description><language>zh-cn</language><lastBuildDate>Sat, 03 Mar 2007 04:09:20 GMT</lastBuildDate><pubDate>Sat, 03 Mar 2007 04:09:20 GMT</pubDate><ttl>60</ttl><item><title>转贴－－JBOSS集群</title><link>http://www.blogjava.net/vista/archive/2006/12/05/85483.html</link><dc:creator>Vista</dc:creator><author>Vista</author><pubDate>Tue, 05 Dec 2006 01:30:00 GMT</pubDate><guid>http://www.blogjava.net/vista/archive/2006/12/05/85483.html</guid><wfw:comment>http://www.blogjava.net/vista/comments/85483.html</wfw:comment><comments>http://www.blogjava.net/vista/archive/2006/12/05/85483.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/vista/comments/commentRss/85483.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/vista/services/trackbacks/85483.html</trackback:ping><description><![CDATA[
		<!--开始头部--> 
<table cellspacing="0" width="100%" border="0"><tbody><tr><td valign="top" align="left"><a href="http://www.huihoo.com/jboss/index.html"><img alt="Huihoo - Enterprise Open Source" src="http://www.huihoo.com/huihoo.org.jpg" align="left" border="0" /></a></td></tr></tbody></table><!--结束头部--><!--开始中部--><table cellspacing="0" cellpadding="3" width="100%" align="center" border="0"><tbody><tr width="100%"><td width="1%"></td><!--开始正文--><td width="98%"><hr width="98%" noshade="" size="1" />
 Last Modified: <font color="red">2006.02.23</font><br /><center><h4>JBoss 4.0.2集群指南</h4></center><br />(来源：http://www.javaresearch.org ) <br /><br /><br />bromon原创 请尊重版权<br /><br />    本文主要讲解JBoss cluster的基本知识以及简单的配置方法，其间涉及了一些jboss的补充知识。<br /><br />一、材料准备： <br /><br />1、    JBoss 4.0.2    <br /><br />JBoss各个版本之间差异比较大，即使同为jboss 4.x的版本，内部组件的版本也不一致，所以请尽量使用同一版本的server。目前已经证明可以配置cluster的版本多为jboss 3.2.6和jboss 4.0.2。<br /><br />2、    Apache 2.0.54<br /><br />3、    Apache mod_jk-1-2-13-apache-2-0-54<br /><br />二、安装：<br /><br />1、    jboss4.0.2与apache 2.0.54的安装请自行搞定。假设jboss的安装目录为%jboss%，apache安装目录为%apache%。<br /><br />2、    mod_jk的安装。<br /><br />从apache.org获得文件mod_jk-1-2-13-apache-2-0-54.so，将该文件拷贝到%apache%\ modules。<br /><br />三、jboss cluster入门<br /><br />    Jboss 支持如下类型的cluster：EJB、web、JNDI、JMS，我们主要了解web cluster。<br />Web cluster实际上可以划分为两个话题：负载均衡 (load balance) 和状态同步。它们是互相独立的，单独配置。<br /><br />负载均衡的概念比较简单，重要的是负载均衡的粒度。可以选择针对每个request的均衡，或者是针对每个用户的均衡。选择不同的粒度，需要不同的状态同步方式。<br /><br />1、基于request的负载均衡<br /><br />    该种方式下，负载均衡器 (load balancer)会根据各个node的状况，把每个http request进行分发。使用这样的均衡策略，就必须在多个node之间复制用户的session，实时保持整个cluster的用户状态同步，这种操作被称为session复制(session replication)。Jboss的实现原理是使用拦截器(interceptor)，根据用户的同步策略拦截request，做同步处理后再交给server产生响应。<br /><br />    该方法的优点是客户不会被绑定都具体的node，只要还有一个node存活，用户状态都不会丢失，cluster都能够继续工作。缺点是node之间通信频繁，响应速度有影响，多并发、高频操作的情况下性能下降比较厉害。<br /><br />2、    基于用户的负载均衡<br /><br />该种方式下，当用户发出第一个request后，负载均衡器动态的把该用户分配到某个节点，并记录该节点的jvm路由，以后该用户的所有request都会被绑定这个jvm路由，用户只会与该server发生交互，这种策略被称为粘性session(session sticky)。<br /><br />该方法的优点是响应速度快，多个节点之间无须通信。缺点也很明显，某个node死掉以后，它负责的所有用户都会丢失session。<br /><br />四、实战<br /><br />1、负载均衡<br /><br />    Jboss的负载均衡目前有两种方案，一是使用apache的mod_jk，二是使用jboss自带的负载均衡模块。下面分别讲解这两种配置。<br /><br />mod_jk的配置<br /><br />1、    请确认%apache%\modules下已经有mod_jk-1-2-13-apache-2-0-54.so文件。<br />2、    修改%apache%\conf\httpd.conf    在文件末尾添加:    Include conf/mod_jk2.conf<br />3、    在%apache%\conf下新建文件    mod_jk2.conf        文件内容如下：<br /><br /># Load mod_jk module. Specify the filename<br /># of the mod_jk lib you’ve downloaded and<br /># installed in the previous section<br />LoadModule jk_module modules/mod_jk-1-2-13-apache-2-0-54.so<br /># Where to find workers.properties<br />JkWorkersFile conf/workers2.properties<br /># Where to put jk logs<br />JkLogFile logs/mod_jk.log<br /># Set the jk log level [debug/error/info]<br />JkLogLevel info<br /># Select the log format<br />JkLogStampFormat "[%a %b %d %H:%M:%S %Y] "<br /># JkOptions indicate to send SSL KEY SIZE,<br />JkOptions +ForwardKeySize +ForwardURICompat -ForwardDirectories<br /># JkRequestLogFormat set the request format<br />JkRequestLogFormat "%w %V %T"<br />JkMount /* loadbalancer<br /><br />其中JkMount /* loadbalancer的意思是，把所有的请求都发给loadbalancer处理。可以通过修改url来控制发送某些request。<br />4、在%apache%\conf下新建文件    workers2.properties        其内容为：<br /><br />worker.list=loadbalancer,server1,server2<br /><br /># Define the first node...<br />worker.server1.port=8009<br />worker.server1.host=172.16.0.116<br />worker.server1.type=ajp13<br />worker.server1.lbfactor=1<br />worker.server1.local_worker=1<br />worker.server1.cachesize=10<br /><br /># Define the first node...<br />worker.server2.port=8009<br />worker.server2.host=172.16.32.88<br />worker.server2.type=ajp13<br />worker.server2.lbfactor=1<br />worker.server2.local_worker=1<br />worker.server2.cachesize=10<br /><br /># Now we define the load-balancing behaviour<br />worker.loadbalancer.type=lb<br />worker.loadbalancer.balanced_workers=server1,server2<br />worker.loadbalancer.sticky_session=1<br /><br />其中对于node的命名规则是worker.节点名.xxxx。所以上述文件定义了两个节点：server1和server2。8009端口是jboss默认的ajp端口，另外需要注意的是worker.server2.lbfactor参数，它是节点的负载加权，它的值越大，获得负载的机会就越大。可以根据node的硬件性能进行调整。worker.loadbalancer.sticky_session参数是指定是否使用粘性session。<br /><br />所有需要负载均衡的节点，都必须在worker.loadbalancer.balanced_workers参数中列举出来。<br /><br />请记住所有node的名称和它对应着哪台机器，后面的配置中会使用。<br /><br />尝试启动apache：%apache\bin\apache.exe，正常情况下没有任何提示。如果你使用的jk是2.0的，那么配置文件的写法完全不同，由于mod_jk2已经停止开发，所以apache并没有提供任何讲解，对于配置文件的编写也没有任何指导。<br /><br />Jboss自带均衡器的配置<br /><br />    将文件夹%jboss%\docs\examples\varia\loadbalancer\loadbalancer.sar拷贝到%jboss%\server\all\deploy下，并且修改loadbalancer.sar\loadbalancer.sar\META-INF\jboss-service.xml，在&lt;host&gt;标签中类出所有节点，在&lt;sticky-session&gt;标签中指定是否使用粘性session。配置完成。<br /><br />    该均衡器的缺点是负载能力相对不高，配置参数太少，比如无法指定不同节点的负载加权，所以后面都以mod_jk为例，不再讲解jboss自带的负载均衡器的内容。<br /> <br /><br />    负载均衡的配置基本完成，启动jboss，其中过程中会列出DefaultPatition中所有的节点：<br />run.bat -c all<br /><br /> <img src="http://www.huihoo.com/jboss/clustering/i/1_195.jpg" /><br /><br />任何节点的关闭与启动都会在cluster中广播，比如加如一个新节点后，其他节点会得到以下提示：<br /> <br /><img src="http://www.huihoo.com/jboss/clustering/i/2_149.jpg" /><br /><br />2、session sticky配置<br /><br />    apache应该会以粘性session的方式分发请求。部署一个应用测试一下，你会发现粘性session没有起作用。因为我们还没有给jboss配置jvm路由( jvmRoute)，apache就无法知道究竟哪些session是属于哪个节点的。我们继续往下：<br /><br />    修改server1机器上的jboss的配置文件：%jboss%\server\all\deploy\jbossweb-tomcat55.sar\ META-INF\ jboss-service.xml<br /><br />    在110行有：&lt;attribute name="UseJK"&gt;false&lt;/attribute&gt;，将它改为true。值得注意的是在这行标签上面有一段注释，要求你在server.xml中必须有：<br />Engine name="jboss.web" jmvRoute="Node1" defaultHost="localhost"<br /><br />    请注意这里有一个气死人不偿命的小bug，jboss的官方文档把 jvmRoute写成了jmvRoute，就是v和m两个字母的颠倒让我郁闷了三天，翻遍了jboss.com和theserverside.com。都是直接拷贝的错，吐血吐到脱水啊。<br /><br />    下面需要修改server1上的%jboss%\server\all\deploy\jbossweb-tomcat55.sar\ server.xml，在32行左右有：<br /><br />&lt;Engine name="jboss.web" defaultHost="localhost"&gt;<br /><br />给它增加一个jvmRoute属性：<br /><br />&lt;Engine jvmRoute="server1" name="jboss.web" defaultHost="localhost"&gt;<br /><br />请注意，jvmRoute的值必须和mod_jk中的节点名字正确对应，否则无法正确路由。Cluster中的所有节点都应该做相应的配置。<br /><br />Jboss的配置完成了，下面需要在你的web应用中修改配置文件，让它支持集群。<br /><br />在WEB-INF\web.xml中加入属性：    &lt;distributable/&gt;<br /><br />Ok，基于用户的cluster完成了，每个用户会绑定都某个节点上进行交互。这种绑定是如何完成的呢？原来apache把客户分发到节点后，该节点会在用户的session id后面加上此节点的路由名称，变成这个样子：<br /><br />Efdfxxd98daja87daj76da2dka**,server1<br /><br />    有了这个标志，就能分辨该session属于哪个节点。<br /><br />3、session replication配置<br /><br />    下面要做的是基于request的cluster，也就让各个节点之间互相复制session状态。有两种复制模式，同步与异步。使用同步的方式，jboss会把session复制的操作和对request的响应放到一个应用事务(application transaction)，session复制完成后才去处理request。异步复制则发送session复制的消息后马上处理request，session复制则会稍有延迟。但是在多框架的web页面中，这样的集群方式会有问题。由于frame在同一时间发出多个request，会造成一些混乱，这也是采用基于用户的集群方式的原因之一。<br /><br />    JBoss 4.0.2中采用了Jboss cache来实现session复制，实际上就是一个分布式缓存，由于session id中包含了jvm route，所以能够分辨session属于哪个节点。Session的更新类似于hibernate中的乐观锁，有了更新之后就让session的版本号增加，其他节点通过对比版本号来决定是否同步session状态。<br /><br />    配置session replication首先需要编辑<br />%jboss% server\all\deploy\jbossweb-tomcat55.sar\META-INF\ jboss-service.xml，88行左右有：<br />&lt;attribute name="SnapshotMode"&gt;instant&lt;/attribute&gt;<br />这就是刚才提到的复制模式，instant为立即复制，如果设为interval 那么系统会在延迟一段时间再进行复制，时间长度在&lt;attribute name="SnapshotInterval"&gt;2000&lt;/attribute&gt;中指定，单位是毫秒。<br /><br />单独配置这一个地方还不够，在%jboss% server\all\deploy\ tc5-cluster-service.xml中有：<br /><br />&lt;attribute name="CacheMode"&gt;REPL_ASYNC&lt;/attribute&gt;<br /><br />这里才真正决定复制是同步的还是异步的，可以指定为REPL_ASYNC(异步)或者REPL_SYNC(同步)。<br /><br />在这个文件下面一点，还有一个config标签，里面指定了各个节点在进行session复制的时候如何通信，有udp和tcp两种可选，如果使用udp方式，那么应该将udp的lookback属性指定为true，因为windows上有一个叫做media sense的东西会影响udp multicast。注意如果你不了解multi address的ip规则，请不要随便修改mcast_addr的值。如果采用tcp方式的话，应该指定bind_addr的值为本机ip，并且在TCPPING标签的initial_hosts属性中列出所有节点，格式是”机器名[端口号]”，比如在我们的例子中，就应该这样配置tcp(以其中一个节点为例)：<br /><br />&lt;config&gt;<br />&lt;TCP bind_addr="172.16.0.116" start_port="7810" loopback="true"/&gt;<br />&lt;TCPPING initial_hosts="172.16.0.116[7810],172.16.32.88[7810]" port_range="3" timeout="3500"<br />num_initial_members="3" up_thread="true" down_thread="true"/&gt;<br />&lt;MERGE2 min_interval="5000" max_interval="10000"/&gt;<br />&lt;FD shun="true" timeout="2500" max_tries="5" up_thread="true" down_thread="true" /&gt;<br />&lt;VERIFY_SUSPECT timeout="1500" down_thread="false" up_thread="false" /&gt;<br />    &lt;pbcast.NAKACK down_thread="true" up_thread="true" gc_lag="100"<br />         retransmit_timeout="3000"/&gt;<br />    &lt;pbcast.STABLE desired_avg_gossip="20000" down_thread="false" up_thread="false" /&gt;<br />    &lt;pbcast.GMS join_timeout="5000" join_retry_timeout="2000" shun="false"<br />print_local_addr="true" down_thread="true" up_thread="true"/&gt;<br />&lt;pbcast.STATE_TRANSFER up_thread="true" down_thread="true"/&gt;<br />&lt;/config&gt;<br /><br />    JBoss的clustering版主建议尽量使用udp。不过在Sobey内部，建议使用tcp方式，经测试可能有不明物体在影响udp通信，导致Timeout异常。<br /><br />    在%jboss%\ server\all\deploy\ cluster-service.xml中也有关于udp和tcp的配置信息，在4.0以前版本的jboss中，会以这个文件为主配置，4.0以后都以tc5-cluster-service.xml为主配置。<br /><br />    Jboss的配置完成了，最后需要在web应用中增加配置信息，控制session复制的粒度。在WEB-INF\    jboss-web.xml中增加以下内容：<br /><br />&lt;replication-config&gt;<br />    &lt;replication-trigger&gt;SET_AND_NON_PRIMITIVE_GET&lt;/replication-trigger&gt;<br />    &lt;replication-granularity&gt;SESSION&lt;/replication-granularity&gt;<br />  &lt;/replication-config&gt;<br /><br />其中replication-trigger是指定哪些操作引发session的版本更新，它的取值有：<br /><br />SET_AND_GET        <br />SET_AND_NON_PRIMITIVE_GET<br />SET<br /><br />replication-granularity是复制粒度，可以取session或attribute。如果取为attribute有可能导致复制失败，这是目前版本的jboss cache的一个bug，等待修正。<br /><br />部署项目，测试，如果配置没有问题，可以在%jboss%\0server\all\log\server.log中发现类似于这样的信息：<br /><br />DEBUG [org.jboss.web.tomcat.tc5.session.JBossCacheManager] check to see if needs to store and replicate session with id Im9-qpuaXppMS+xXwE3M+Q**.server1 <br /><br />DEBUG [org.jboss.web.tomcat.tc5.session.ClusteredSession] processSessionRepl(): session is dirty. Will increment version from: 20 and replicate.<br /><br />    Session replication配置的成功率比较低，情况也很复杂，请仔细操作。<br /><br />五、分布式热部署(distributable hot deploy)<br /><br />    在一个节点很多的cluster中，如果部署应用的时候必须把程序文件拷贝到每个机器上的话，那实在太愚蠢了，幸好通过all启动的jboss自动支持分布式热部署。把支持cluster的应用（通常需要打包成war文件），放到%jboss%\server\all\farm下，那么处于同一cluster中的其他节点会自动下载并且部署，jboss把这个称为Farm deploy。如下图：<br /><br /><img src="http://www.huihoo.com/jboss/clustering/i/farm.jpg" /><br /><br />End 2005-7-11 Released by bromon </td><!--结束正文--><td width="1%"></td></tr></tbody></table><!--结束中部--><hr width="98%" noshade="" size="1" /><!--开始底部--><script language="javascript" src="../../public/bottom.js"></script><table cellspacing="0" cellpadding="0" width="760" align="center" border="0"><tbody><tr><td align="middle"><font size="2">© 2006 Huihoo</font><br /></td></tr></tbody></table><!--结束底部--><img src ="http://www.blogjava.net/vista/aggbug/85483.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/vista/" target="_blank">Vista</a> 2006-12-05 09:30 <a href="http://www.blogjava.net/vista/archive/2006/12/05/85483.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>vista 精神之 － 类库篇</title><link>http://www.blogjava.net/vista/archive/2006/09/29/72826.html</link><dc:creator>Vista</dc:creator><author>Vista</author><pubDate>Fri, 29 Sep 2006 07:05:00 GMT</pubDate><guid>http://www.blogjava.net/vista/archive/2006/09/29/72826.html</guid><wfw:comment>http://www.blogjava.net/vista/comments/72826.html</wfw:comment><comments>http://www.blogjava.net/vista/archive/2006/09/29/72826.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/vista/comments/commentRss/72826.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/vista/services/trackbacks/72826.html</trackback:ping><description><![CDATA[一，一个功能强大的数据库连接池<br /><img height="19" src="http://www.blogjava.net/Emoticons/emcake.gif" width="19" border="0" />   <a href="/tonyzhou00/archive/2006/09/28/72566.html">http://www.blogjava.net/tonyzhou00/archive/2006/09/28/72566.html</a><img src ="http://www.blogjava.net/vista/aggbug/72826.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/vista/" target="_blank">Vista</a> 2006-09-29 15:05 <a href="http://www.blogjava.net/vista/archive/2006/09/29/72826.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>