各位好,帮忙处理下面的问题呀,apache2.2+tomcat6.0 集群,登录不了,应该是session不能共享。apache 配置:
<Location /server-status>
SetHandler server-status
Order Deny,Allow
Deny from all
Allow from all
</Location>
<Location /balancer-manager>
SetHandler balancer-manager
Order Deny,Allow
Deny from all
Allow from all
</Location>ProxyRequests Off
ProxyPass / balancer://tomcatcluster/ stickysession=jsessionid nofailover=On
ProxyPass /MobileBusiness http://localhost:80/MobileBusiness/
ProxyPassReverse / balancer://tomcatcluster/
ProxyPassReverse /ccas balancer://tomcatcluster/ccas/
ProxyPassReverse /clpay balancer://tomcatcluster/clpay/<proxy balancer://tomcatcluster> 
BalancerMember ajp://127.0.0.1:8011 loadfactor=1 route=tomcat1 
#BalancerMember ajp://192.168.1.104:8012 loadfactor=1 route=tomcat2 
BalancerMember ajp://127.0.0.1:8013 loadfactor=1 route=tomcat3 
</proxy> <VirtualHost *:80> 
    ServerAdmin [email protected]
    ServerName localhost
    ErrorLog logs/dummy-host.example.com-error_log
    CustomLog logs/dummy-host.example.com-access_log common 
    ProxyPass / balancer://cluster/ stickysession=jsessionid nofailover=On 
    ProxyPassReverse / balancer://cluster/
</VirtualHost>
tomcat 配置:<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"  channelSendOptions="8">
<Manager className="org.apache.catalina.ha.session.BackupManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"
mapSendOptions="6"/><!-- <Manager className="org.apache.catalina.ha.session.DeltaManager"
expireSessionsOnShutdown="false"
mapSendOptions="6"
notifyListenersOnReplication="true"/> --><Channel className="org.apache.catalina.tribes.group.GroupChannel">
<Membership className="org.apache.catalina.tribes.membership.McastService"
bind="127.0.0.1"
address="228.0.0.4"
port="45564"
frequency="500"
dropTime="3000"/>
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
address="auto"
port="4001"
autoBind="100"
selectorTimeout="5000"
maxThreads="6"/>
<!--<Receiver
className="org.apache.catalina.cluster.tcp.ReplicationListener"
tcpListenAddress="auto"
tcpListenPort="4002"
tcpSelectorTimeout="100"
tcpThreadCount="6"/>--><!-- replicationMode="pooled"
ackTimeout="15000" -->
<Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
<Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
</Sender>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/>-->
<Interceptor className="org.apache.catalina.tribes.group.interceptors.ThroughputInterceptor"/>
</Channel>
<Valve className="org.apache.catalina.ha.tcp.ReplicationValve"
filter=".*\.gif;.*\.js;.*\.jpg;.*\.png;.*\.htm;.*\.html;.*\.css;.*\.txt;"/>
<!-- <Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/> -->
<Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer"
tempDir="/tmp/war-temp/"
deployDir="/tmp/war-deploy/"
watchDir="/tmp/war-listen/"
watchEnabled="false"/>
<ClusterListener className="org.apache.catalina.ha.session.JvmRouteSessionIDBinderListener"/>
<ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
</Cluster>web.xml
里增加:<distributable/>可就是登录不了,,获取验证码的时候也会报空指针异常

解决方案 »

  1.   

    你把tomcat只剩下一个试试看,一个tomcat没有共享问题。如果能行,那还得看看Cluster那里的事了。
      

  2.   

    apache 配置:
    <Location /server-status>
    SetHandler server-status
    Order Deny,Allow
    Deny from all
    Allow from all
    </Location>
    <Location /balancer-manager>
    SetHandler balancer-manager
    Order Deny,Allow
    Deny from all
    Allow from all
    </Location>ProxyRequests Off
    ProxyPass / balancer://tomcatcluster/ stickysession=jsessionid nofailover=On
    ProxyPass /MobileBusiness http://localhost:80/MobileBusiness/
    ProxyPassReverse / balancer://tomcatcluster/
    ProxyPassReverse /ccas balancer://tomcatcluster/ccas/
    ProxyPassReverse /clpay balancer://tomcatcluster/clpay/<proxy balancer://tomcatcluster>  
    BalancerMember ajp://127.0.0.1:8011 loadfactor=1 route=tomcat1  
    #BalancerMember ajp://192.168.1.104:8012 loadfactor=1 route=tomcat2  
    BalancerMember ajp://127.0.0.1:8013 loadfactor=1 route=tomcat3  
    </proxy>  <VirtualHost *:80>  
      ServerAdmin [email protected]
      ServerName localhost
      ErrorLog logs/dummy-host.example.com-error_log
      CustomLog logs/dummy-host.example.com-access_log common  
      ProxyPass / balancer://cluster/ stickysession=jsessionid nofailover=On  
      ProxyPassReverse / balancer://cluster/
    </VirtualHost>
    tomcat 配置:<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster" channelSendOptions="8">
    <Manager className="org.apache.catalina.ha.session.BackupManager"
    expireSessionsOnShutdown="false"
    notifyListenersOnReplication="true"
    mapSendOptions="6"/><!-- <Manager className="org.apache.catalina.ha.session.DeltaManager"
    expireSessionsOnShutdown="false"
    mapSendOptions="6"
    notifyListenersOnReplication="true"/> --><Channel className="org.apache.catalina.tribes.group.GroupChannel">
    <Membership className="org.apache.catalina.tribes.membership.McastService"
    bind="127.0.0.1"
    address="228.0.0.4"
    port="45564"
    frequency="500"
    dropTime="3000"/>
    <Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
    address="auto"
    port="4001"
    autoBind="100"
    selectorTimeout="5000"
    maxThreads="6"/>
    <!--<Receiver
    className="org.apache.catalina.cluster.tcp.ReplicationListener"
    tcpListenAddress="auto"
    tcpListenPort="4002"
    tcpSelectorTimeout="100"
    tcpThreadCount="6"/>--><!-- replicationMode="pooled"
    ackTimeout="15000" -->
    <Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
    <Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
    </Sender>
    <Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
    <Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/>-->
    <Interceptor className="org.apache.catalina.tribes.group.interceptors.ThroughputInterceptor"/>
    </Channel>
    <Valve className="www.cctv40.cnorg.apache.catalina.ha.tcp.ReplicationValve"
    filter=".*\.gif;.*\.js;.*\.jpg;.*\.png;.*\.htm;.*\.html;.*\.css;.*\.txt;"/>
    <!-- <Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/> -->
    <Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer"
    tempDir="/tmp/war-temp/"
    deployDir="/tmp/war-deploy/"
    watchDir="/tmp/war-listen/"
    watchEnabled="false"/>
    <ClusterListener className="org.apache.catalina.ha.session.JvmRouteSessionIDBinderListener"/>
    <ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
    </Cluster>看起来没问题啊。。
      

  3.   


    一个tomcat能登录成功,,,两个tomcat登录后不能成功跳转到相应的页面