Socket error Windows getInputStream

V

vicky7909

Hello,

Java version is 1.5.0_09. I am trying to connect from a Windows
machine to another Windows machine using sockets . Getting a socket
error for the following line. and throws EOFException

Socket s = null;
ObjectInputStream sin = null;
ObjectOutputStream sout = null;

s = new Socket( host, port );
sout = new ObjectOutputStream( s.getOutputStream() );

//write data to socket
sout.writeObject( req );
sout.flush();

InputStream is = s.getInputStream() );
sin = new ObjectInputStream( is ); // This line gives error

If I step into ObjectInputStream, I see:

public ObjectInputStream(InputStream in) throws IOException {
verifySubclass();
bin = new BlockDataInputStream(in);
handles = new HandleTable(10);
vlist = new ValidationList();
enableOverride = false;
readStreamHeader(); // This line gives error
bin.setBlockDataMode(true);
}


However, the same code works when I try to connect from Linux(Red Hat
Enterprise Linux WS release 4 (Nahant Update 5)) to Windows. Turned
off Windows firewall but no luck.

On the Windows Server I am trying to connect to a server agent waiting
on port 2002 that helps me connect to Citrix running on that machine.
The agent runs as a Windows service.

What could be wrong here?

Stack Trace

java.io.EOFException
at java.io_ObjectInputStream
$PeekInputStream.readFully(ObjectInputStream.java:2228)
at java.io_ObjectInputStream
$BlockDataInputStream.readShort(ObjectInputStream.java:2694)
at java.io_ObjectInputStream.readStreamHeader(ObjectInputStream.java:
761)
at java.io_ObjectInputStream.<init>(ObjectInputStream.java:277)
....
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:
202)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:
173)
at
org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:
213)
at
org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:
178)
at
org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:
126)
at
org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:
105)
at
org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:
107)
at
org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:
148)
at
org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:
869)
at org.apache.coyote.http11.Http11BaseProtocol
$Http11ConnectionHandler.processConnection(Http11BaseProtocol.java:
664)
at
org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:
527)
at
org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:
80)
at org.apache.tomcat.util.threads.ThreadPool
$ControlRunnable.run(ThreadPool.java:684)
at java.lang.Thread.run(Thread.java:595)
 
K

Knute Johnson

Hello,

Java version is 1.5.0_09. I am trying to connect from a Windows
machine to another Windows machine using sockets . Getting a socket
error for the following line. and throws EOFException

Socket s = null;
ObjectInputStream sin = null;
ObjectOutputStream sout = null;

s = new Socket( host, port );
sout = new ObjectOutputStream( s.getOutputStream() );

//write data to socket
sout.writeObject( req );
sout.flush();

InputStream is = s.getInputStream() );
sin = new ObjectInputStream( is ); // This line gives error

If I step into ObjectInputStream, I see:

public ObjectInputStream(InputStream in) throws IOException {
verifySubclass();
bin = new BlockDataInputStream(in);
handles = new HandleTable(10);
vlist = new ValidationList();
enableOverride = false;
readStreamHeader(); // This line gives error
bin.setBlockDataMode(true);
}


However, the same code works when I try to connect from Linux(Red Hat
Enterprise Linux WS release 4 (Nahant Update 5)) to Windows. Turned
off Windows firewall but no luck.

On the Windows Server I am trying to connect to a server agent waiting
on port 2002 that helps me connect to Citrix running on that machine.
The agent runs as a Windows service.

What could be wrong here?

Stack Trace

java.io.EOFException
at java.io_ObjectInputStream
$PeekInputStream.readFully(ObjectInputStream.java:2228)
at java.io_ObjectInputStream
$BlockDataInputStream.readShort(ObjectInputStream.java:2694)
at java.io_ObjectInputStream.readStreamHeader(ObjectInputStream.java:
761)
at java.io_ObjectInputStream.<init>(ObjectInputStream.java:277)
...
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:
202)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:
173)
at
org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:
213)
at
org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:
178)
at
org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:
126)
at
org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:
105)
at
org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:
107)
at
org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:
148)
at
org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:
869)
at org.apache.coyote.http11.Http11BaseProtocol
$Http11ConnectionHandler.processConnection(Http11BaseProtocol.java:
664)
at
org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:
527)
at
org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:
80)
at org.apache.tomcat.util.threads.ThreadPool
$ControlRunnable.run(ThreadPool.java:684)
at java.lang.Thread.run(Thread.java:595)

I'm not sure what your problem is. I've done this quite a few times
between Windows machines with no problem. If the communications is
two-way it is usually necessary to create the ObjectOutputStream before
the ObjectInputStream. That can cause some problems but it is usually
hangs and not EOFExceptions.

Probably the simplest thing you can do here is write a couple of test
programs and see if you can see where the problem is actually happening.
Sometimes removing all the other code gets you to the problem in the
original code.
 
V

vicky7909

That means the other end has already closed the connection, or possibly
an intermediate router has timed out.

So how do I get around this? I was able to connect until day before
and suddenly I started getting this error.

Thanks for posting your answer in both forums
 
V

vicky7909

So how do I get around this? I was able to connect until day before
and suddenly I started getting this error.

Thanks for posting your answer in both forums


It worked after rebooting Windows a couple of times. I made no code
change.
 
K

Knute Johnson

I'm probably going to set-up an alternate dev. environment on Linux -
just in case. I lost half a day.

They both have problems and they are different. There are a lot of
posts here "My xyz works on Linux but not on XP" or vice versa.

I'm fighting one now where a server program running on a Windows machine
gets stopped by random blow ups of svchost.exe. It will run for weeks
without a problem and then stop two or three times in one day. It's
enough to drive you nuts.
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

Forum statistics

Threads
473,764
Messages
2,569,566
Members
45,041
Latest member
RomeoFarnh

Latest Threads

Top