Java Mailing List Archive

http://www.junlu.com/

Google
Google
Mailing List
Home
Forum Home
JBoss - Java Application Server
Tomcat - JSP/Servlet container
Struts - A MVC web framework
iText - An open source PDF Java Library
JDOM - JDOM XML Parser
JSP - A mailing list about Java Server Pages specification and reference
J2EE - A mailing list for Java(tm) 2 Platform, Enterprise Edition
J2EE Pattern - An interest list for Sun Java Center J2EE Pattern Catalog
Servlet - A mailing list for discussion about Sun Microsystem's Java Servlet API Technology
Struts & Hibernate
Subjects
JSP editor plugin for eclipse ?
org apache jasper JasperException: Unable to compile class for JSP
Tomcat: Connection reset by peer: socket write error
Cannot retrieve definition for form bean null
Struts Tiles Tutorial (free Struts training)
Where do I download Tomcat 4 0 6?
Data Access Object (DAO) pattern, example DAO 's
Where to download Tomcat v 4 1 24 from?
Tomcat 5 0 16 Requested resource not available
Servlet : Session invalidate
Oracle Connection Pooling in 3 2 2
Servlet action is currently unavailable
Tomcat/Struts Unicode Encoding/Decoding problems
Running a Simple JMS Example
Tomcat and webapplication specific java library path
Mapping in workers2 properties
org apache jasper JasperException
problem with html:text bean throwing exception
Cannot find message resources under key org apache struts action
   MESSAGE
Cannot find message resources under key org apache struts action MESSAGE
invalid direct reference problem with solution
Tool for jsp debug Try Sysdeo Eclipse Plugin
Tomcat 5 Cannot load JDBC driver class 'null ' SQL state: null
weblogic ejbc
java properties file
Jboss 3 2 3 Coyote Can 't re
Tomcat 5, Apache2 and mod jk2 integration problem
JBoss example problem new to J2EE
Value attribute of <html:checkbox
url string for connecting jboss to oracle
javax servlet ServletException: BeanUtils populate
5 0 18: Windows XP Pro vs Windows 2000
HTTP Status 404 The requested resource is not available
 
-none-

-none-

2007-10-01       - By Daniel M Garland

 Back
OK I've figured out what's happening, but not how to fix it!

I'm running a single Tomcat instance that is hosting some virtual hosts,
and we have three Tapestry web applications. For those unfamiliar with
Tapestry, a Visit object is defined to represent the user's session and
is sort of a facade to avoid working directly with HttpSession. Hence in
a cluster this Visit object is propagated around the cluster.

Now, what seems to be the case is that Tomcat is getting muddled up with
the different Visit classes in each separate application; which is not
good. Not only are the classes in different java packages, but they have
unique serialVersionIDs. This then gives me the error:

java.io.InvalidClassException: com.mydomain.Visit; local class
incompatible: stream classdesc serialVersionUID = -139355480
5485899996, local class serialVersionUID = 8444624889687850885

and it turns out that -1393554805485899996 is the Visit object from a
completely different web application.

I'm trying to figure out what changes to my config I made when I went
from my old hardware to a new setup, and I believe that the only change
is that we configured each virtual host to use its own <cluster>
element, rather than having a single cluster for the engine; but I
would've thought that having three seperate clusters on different ports/
addresses would help to prevent this sort of thing happening, rather
than cause it?

Any other reasons why my serialized objects are being confused in this
way?

Daniel M Garland wrote:
> Hi all,
>
> I've been running two Tomcat 5.5.20 servers in a cluster for some time
> on Mac OSx but we've recently moved to 64-bit architecture (Debian etch)
> . I tried as far as possible to keep the config the same, so only the OS
> has changed (and I also got the Apache Portable Runtime going). However
> since moving to this new setup I'm starting to see the following
> messages in my catalina.out:
>
> 25-Sep-2007 (See http://Sep-2007.ora-code.com) 16:35:11 org.apache.catalina.cluster.session.DeltaManager
> messageReceived
> SEVERE: Manager []: Unable to receive message through TCP channel
> java.lang.ClassNotFoundException:
> com.mycompany.someSerialiazbleObject
>
> and sometimes in other web apps I see instead of ClassNotFoundException:
>
> java.io.InvalidClassException:
> org.mycomapny.someOtherSerializableObject; local class incompatible:
> stream classdesc serialVersionUID = -1393554805485899996, local class
> serialVersionUID = 8444624889687850885
>
> Now I did some homework here and I've tried the following without success:
>
> 1) I've compiled the java files on the server's themselves, so I am sure
> that the correct class versions are being used
> 2) The object implements java.io.Serializable, and has a generated
> serial ID from Eclipse. Incidentally, this Long value matches the local
> class serialVersionUID, so I have no idea where the 'stream'
> serialVersionUID comes from.
> 3) I have the same code running on both the Tomcat servers.
>
> What I would like to know is where I am supposed to look next for some
> answers to this problem. Is there any more information from my config
> that would be relevant to post here?
>
> Thanks in advance, my first 'tomcat-users' post :)
>
> Dan Garland
> daniel.garland@(protected)
>
> -- Stack Trace --
> 25-Sep-2007 (See http://Sep-2007.ora-code.com) 16:35:11 org.apache.catalina.cluster.session.DeltaManager
> messageReceived
> SEVERE: Manager []: Unable to receive message through TCP channel
> java.lang.ClassNotFoundException:
> com.mycompany.someSerialiazbleObject
>         at java.net.URLClassLoader$1.run(URLClassLoader.java:200)
>         at java.security.AccessController.doPrivileged(Native Method)
>         at java.net.URLClassLoader.findClass(URLClassLoader.java:188)
>         at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
>         at java.lang.ClassLoader.loadClass(ClassLoader.java:251)
>         at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:319)
>         at java.lang.Class.forName0(Native Method)
>         at java.lang.Class.forName(Class.java:242)
>         at
> java.io.ObjectInputStream.resolveClass(ObjectInputStream.java:574)
>         at
> org.apache.catalina.cluster.session.ReplicationStream.resolveClass
(ReplicationStream.java:84)
>
>         at
> java.io.ObjectInputStream.readNonProxyDesc(ObjectInputStream.java:1538)
>         at
> java.io.ObjectInputStream.readClassDesc(ObjectInputStream.java:1460)
>         at
> java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1693)
>         at
> java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1299)
>         at java.io.ObjectInputStream.readObject(ObjectInputStream.java:339)
>         at
> org.apache.catalina.cluster.session.DeltaRequest$AttributeInfo.readExternal
(DeltaRequest.java:334)
>
>         at
> org.apache.catalina.cluster.session.DeltaRequest.readExternal(DeltaRequest
.java:246)
>
>         at
> org.apache.catalina.cluster.session.DeltaManager.loadDeltaRequest
(DeltaManager.java:697)
>
>         at
> org.apache.catalina.cluster.session.DeltaManager.handleSESSION_DELTA
(DeltaManager.java:1572)
>
>         at
> org.apache.catalina.cluster.session.DeltaManager.messageReceived(DeltaManager
.java:1522)
>
>         at
> org.apache.catalina.cluster.session.DeltaManager.messageDataReceived
(DeltaManager.java:1271)
>
>         at
> org.apache.catalina.cluster.session.ClusterSessionListener.messageReceived
(ClusterSessionListener.java:85)
>
>         at
> org.apache.catalina.cluster.tcp.SimpleTcpCluster.receive(SimpleTcpCluster
.java:1167)
>
>         at
> org.apache.catalina.cluster.tcp.ClusterReceiverBase.messageDataReceived
(ClusterReceiverBase.java:426)
>
>         at
> org.apache.catalina.cluster.io.ObjectReader.execute(ObjectReader.java:107)
>         at
> org.apache.catalina.cluster.tcp.TcpReplicationThread.drainChannel
(TcpReplicationThread.java:138)
>
>         at
> org.apache.catalina.cluster.tcp.TcpReplicationThread.run(TcpReplicationThread
.java:69)
>
>
> __ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ __
> This email has been scanned by the MessageLabs Email Security System.
> For more information please visit http://www.messagelabs.com/email
> __ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ __
>
> -- ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ------
> To start a new topic, e-mail: users@(protected)
> To unsubscribe, e-mail: users-unsubscribe@(protected)
> For additional commands, e-mail: users-help@(protected)
>
>
> __ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ __
> This email has been scanned by the MessageLabs Email Security System.
> For more information please visit http://www.messagelabs.com/email
> __ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ __
>

__ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ __
This email has been scanned by the MessageLabs Email Security System.
For more information please visit http://www.messagelabs.com/email
__ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ ____ __

-- ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ------
To start a new topic, e-mail: users@(protected)
To unsubscribe, e-mail: users-unsubscribe@(protected)
For additional commands, e-mail: users-help@(protected)


©2008 junlu.com - Jax Systems, LLC, U.S.A.