Kirk Lund created GEODE-1024:
--------------------------------
Summary: NotAuthorizedException fails serialization because
Principal member field is not serializable
Key: GEODE-1024
URL: https://issues.apache.org/jira/browse/GEODE-1024
Project: Geode
Issue Type: Bug
Components: management
Reporter: Kirk Lund
While running Geode with LDAP security, I hit this failure:
{noformat}
7420-2: [warning 2016/02/25 19:24:34.134 PST bridgegemfire1_latvia_7420
<ServerConnection on port 26419 Thread 19> tid=0xa5] Server connection from
[identity(latvia(invalidgemfire1_latvia_7480:7480:loner):49923:843f9b1b:invalidgemfire1_latvia_7480,connection=1;
port=49924]: Unexpected Exception
com.gemstone.gemfire.SerializationException: failed serializing object
at
com.gemstone.gemfire.internal.cache.tier.sockets.Message.serializeAndAddPart(Message.java:371)
at
com.gemstone.gemfire.internal.cache.tier.sockets.Message.addObjPart(Message.java:302)
at
com.gemstone.gemfire.internal.cache.tier.sockets.Message.addObjPart(Message.java:285)
at
com.gemstone.gemfire.internal.cache.tier.sockets.BaseCommand.writeException(BaseCommand.java:636)
at
com.gemstone.gemfire.internal.cache.tier.sockets.BaseCommand.writeException(BaseCommand.java:620)
at
com.gemstone.gemfire.internal.cache.tier.sockets.command.PutUserCredentials.cmdExecute(PutUserCredentials.java:61)
at
com.gemstone.gemfire.internal.cache.tier.sockets.BaseCommand.execute(BaseCommand.java:175)
at
com.gemstone.gemfire.internal.cache.tier.sockets.ServerConnection.doNormalMsg(ServerConnection.java:796)
at
com.gemstone.gemfire.internal.cache.tier.sockets.ServerConnection.doOneMessage(ServerConnection.java:923)
at
com.gemstone.gemfire.internal.cache.tier.sockets.ServerConnection.run(ServerConnection.java:1168)
at
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at
com.gemstone.gemfire.internal.cache.tier.sockets.AcceptorImpl$1$1.run(AcceptorImpl.java:561)
at java.lang.Thread.run(Thread.java:745)
Caused by: java.io.NotSerializableException: com.sun.jndi.ldap.LdapCtx
at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1184)
at
java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1548)
at
java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1509)
at
java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1432)
at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1178)
at
java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1548)
at
java.io.ObjectOutputStream.defaultWriteObject(ObjectOutputStream.java:441)
at java.lang.Throwable.writeObject(Throwable.java:985)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:497)
at
java.io.ObjectStreamClass.invokeWriteObject(ObjectStreamClass.java:1028)
at
java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1496)
at
java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1432)
at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1178)
at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:348)
at
com.gemstone.gemfire.internal.InternalDataSerializer.writeSerializableObject(InternalDataSerializer.java:2364)
at
com.gemstone.gemfire.internal.InternalDataSerializer.basicWriteObject(InternalDataSerializer.java:2229)
at
com.gemstone.gemfire.DataSerializer.writeObject(DataSerializer.java:3241)
at
com.gemstone.gemfire.internal.util.BlobHelper.serializeTo(BlobHelper.java:76)
at
com.gemstone.gemfire.internal.cache.tier.sockets.Message.serializeAndAddPart(Message.java:369)
... 13 more
{noformat}
While troubleshooting, I found that NotAuthroizedException has a
non-serializable member field of type java.security.Principal.
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)