Hi

At present I m trying Session replication only..
I think i need tomcat1 and tomcat2..
Am i correct?

Thanks


On 6/20/07, Raghupathy, Gurumoorthy <[EMAIL PROTECTED]>
wrote:

Try to remove  tomcat1,tomcat2, from the workers.properties

It should be something like

worker.list=loadbalancer

Thanks
Guru
-----Original Message-----
From: shiva sha [mailto:[EMAIL PROTECTED]
Sent: 20 June 2007 09:30
To: Tomcat Users List
Subject: Re: Session Replication in Tomcat5.5.17

Hi I follwoed ur given URLs...
But no luck..
This is my configuraion

Apache Version : 2.2.4
Tomcat Version : 5.5.17
JDK          :  1.6.0_01
Win 2000

workers.properties

worker.list=tomcat1,tomcat2,loadbalancer

# First tomcat server

worker.tomcat1.type=ajp13
worker.tomcat1.host=192.168.10.30
worker.tomcat1.port=8009
worker.tomcat1.lbfactor=1
worker.tomcat1.connection_pool_timeout=600
worker.tomcat1.socket_keepalive=1
worker.tomcat1.socket_timeout=60
worker.tomcat1.cachesize=20
worker.tomcat1.cache_timeout=180
worker.tomcat1.recycle_timeout=180

# Second tomcat server

worker.tomcat2.type=ajp13
worker.tomcat2.host=192.168.10.50
worker.tomcat2.port=9009
worker.tomcat2.lbfactor=1
worker.tomcat2.connection_pool_timeout=600
worker.tomcat2.socket_keepalive=1
worker.tomcat2.socket_timeout=60
worker.tomcat2.cachesize=20
worker.tomcat2.cache_timeout=180
worker.tomcat2.recycle_timeout=180

worker.tomcat2.lbfactor=100
worker.loadbalancer.type=lb
worker.loadbalancer.sticky_session=True
worker.loadbalancer.balance_workers=tomcat1,tomcat2

Below is the Tomcat1 server.xml.


<Server port="8005" shutdown="SHUTDOWN">

  <Listener className="org.apache.catalina.core.AprLifecycleListener" />
  <Listener
className="org.apache.catalina.mbeans.ServerLifecycleListener"
/>
  <Listener className="
org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
  <Listener className="
org.apache.catalina.storeconfig.StoreConfigLifecycleListener"/>


  <GlobalNamingResources>


    <Environment name="simpleValue" type="java.lang.Integer"
value="30"/>

    <Resource name="UserDatabase" auth="Container"
              type="org.apache.catalina.UserDatabase"
       description="User database that can be updated and saved"
           factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
          pathname="conf/tomcat-users.xml" />

  </GlobalNamingResources>

  <Service name="Catalina">

    <!-- Define a non-SSL HTTP/1.1 Connector on port 8080 -->
    <Connector port="8081" maxHttpHeaderSize="8192"
               maxThreads="150" minSpareThreads="25"
maxSpareThreads="75"
               enableLookups="false" redirectPort="8443"
acceptCount="100"
               connectionTimeout="20000" disableUploadTimeout="true" />

    <!-- Define an AJP 1.3 Connector on port 8009 -->
    <Connector port="8009"
               enableLookups="false" redirectPort="8443"
protocol="AJP/1.3"
/>

    <!-- Define the top level container in our container hierarchy -->
    <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1">

      <Realm className="org.apache.catalina.realm.UserDatabaseRealm"
             resourceName="UserDatabase"/>

      <!-- Define the default virtual host
           Note: XML Schema validation will not work with Xerces 2.2.
       -->
      <Host name="localhost" appBase="webapps"
       unpackWARs="true" autoDeploy="true"
       xmlValidation="false" xmlNamespaceAware="false">


        <Cluster
className="org.apache.catalina.cluster.tcp.SimpleTcpCluster
"
                 managerClassName="
org.apache.catalina.cluster.session.DeltaManager"
                 expireSessionsOnShutdown="false"
                 useDirtyFlag="true"
                 notifyListenersOnReplication="true">

            <Membership

className="org.apache.catalina.cluster.mcast.McastService"
                mcastAddr="228.0.0.4"
                mcastBindAddress="192.168.10.30"
                mcastPort="45564"
                mcastFrequency="500"
                mcastDropTime="3000"/>

            <Receiver
                className="
org.apache.catalina.cluster.tcp.ReplicationListener"
                tcpListenAddress="auto"
                tcpListenPort="4001"
                tcpSelectorTimeout="100"
                tcpThreadCount="6"/>

            <Sender
                className="
org.apache.catalina.cluster.tcp.ReplicationTransmitter"
                replicationMode="pooled"
                ackTimeout="15000"
                waitForAck="true"/>

            <Valve className="
org.apache.catalina.cluster.tcp.ReplicationValve"

filter=".*\.gif;.*\.js;.*\.jpg;.*\.png;.*\.htm;.*\.html;.*\.css;.*\.txt;
"/>

            <Deployer className="
org.apache.catalina.cluster.deploy.FarmWarDeployer"
                      tempDir="/tmp/war-temp/"
                      deployDir="/tmp/war-deploy/"
                      watchDir="/tmp/war-listen/"
                      watchEnabled="false"/>

            <ClusterListener className="
org.apache.catalina.cluster.session.ClusterSessionListener"/>
        </Cluster>


      </Host>

    </Engine>

  </Service>

</Server>

For Tomcat2 i had changed the below elements only..

<Server port="9005" shutdown="SHUTDOWN">
<Connector port="9081" maxHttpHeaderSize="8192"
               maxThreads="150" minSpareThreads="25"
maxSpareThreads="75"
               enableLookups="false" redirectPort="8443"
acceptCount="100"
               connectionTimeout="20000" disableUploadTimeout="true" />

    <!-- Define an AJP 1.3 Connector on port 8009 -->
    <Connector port="9009"
               enableLookups="false" redirectPort="8443"
protocol="AJP/1.3"
/>
<Membership

className="org.apache.catalina.cluster.mcast.McastService"
                mcastAddr="228.0.0.4"
                mcastBindAddress="192.168.10.50"
                mcastPort="45564"
                mcastFrequency="500"
                mcastDropTime="3000"/>

Program code..

I had designed a bean and servlet like this..

import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
import com.bean.SessionCart;

public class SessionStoreServlet extends HttpServlet
{


public synchronized void init (ServletConfig config) throws
ServletException

{
        super.init();

}


public void doPost (HttpServletRequest req, HttpServletResponse res)
    throws ServletException, IOException
{

    StringBuffer HTML = new StringBuffer();
    res.setContentType("text/html");
    PrintWriter out = res.getWriter();
    SessionCart sc;
    HttpSession session = req.getSession(true);


        sc= new SessionCart();
        session.putValue("Cart",sc);

        String userName=req.getParameter("loginid");


        ((SessionCart)session.getValue("Cart")).setName(userName);

        out.println("Your account number is " +
((SessionCart)session.getValue("Cart")).getName());
    }

    }
and Bean is like this..

package com.bean;

public class SimpleBean implements java.io.Serializable {


    private String name = null;
    private int age = 0;


    public SimpleBean() {}

    public String getName() {
        return name;
    }

    public void setName(String s) {
        name = s;
    }

}

HTML like this

<form method="POST" action="servlet/SessionStoreServlet">
<input type="text" name="loginid" size="20"></p>
<input type="password" name="password" size="20"></td>
<td width="50%"><input type="submit" value="Submit" name="B1"></td>
      <td width="50%"><input type="reset" value="Reset" name="B2"></td>

I had paste the mod_jk.dll in conf/modules..

What i m trying is
First i started the Apache and then Tomcat1,Tomcat2..
I run the html file in Tomcat1 and the given value is stored in session
and
displays the same.
Then stop the Tomcat1..
If i run the same HTML i want to show the session value which is stored
in
Tomcat instance1..
But i can not get the old session value..It will start new session
only..
Session is not get replicated across Tomcat instances...

Is there is any wrong in my steps?

Replication memebers are added sucessfully in both tomcat instances..
i.e,
replication member messages

are shown in Tomcats but session is not get replicated..

Pls help..
If possible give tested code and server.xml, workers.properties ..
Bcoz no one document is clear abor mod_jk..
I m confused ..
Thanks




On 6/19/07, Peter Rossbach <[EMAIL PROTECTED]> wrote:
>
> Look at current tomcat docs
>
> http://tomcat.apache.org/tomcat-5.5-doc/cluster-howto.html
> http://tomcat.apache.org/connectors-doc/reference/workers.html
> http://tomcat.apache.org/connectors-doc/generic_howto/workers.html
>
>
> Peter
>
>
>
> Am 18.06.2007 um 17:45 schrieb shiva sha:
>
> > Hi
> > I try to implement Session replication in Tomcat5.5.17 using Apache
> > HttpServer2.0.5.
> > I had downloaded mod_jk.dll and placed this dll into
apache/modules/.
> > I had configured both server.xml in Tomcat1 and Tomcat2 and
> > workers.properties in Apache  in Windows 2000 environment.
> > But no luck bcoz tomcat server throws error like no member is
> > active in the
> > cluster
> > Pls send code samples and how to replicate the session in
> > tomcat.
> > Pls send workers.pro, httpd.conf,servers.xmls and docs for how to
> > do or
> > reference url for this..
> >
> > Thanks
> > Shiva
>
>
> ---------------------------------------------------------------------
> To start a new topic, e-mail: users@tomcat.apache.org
> To unsubscribe, e-mail: [EMAIL PROTECTED]
> For additional commands, e-mail: [EMAIL PROTECTED]
>
>

---------------------------------------------------------------------
To start a new topic, e-mail: users@tomcat.apache.org
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]


Reply via email to