Hi Nathan,
Note that I moved this discussion to the JBossRemoting users forum.
There are two different phenomena in your stacktraces. The first one shows a client hanging, waiting for a response to an invocation, in this case the response to an invocation on an EJB3. The fact that it's hanging means that, for some reason, the server isn't supplying a result. Do you see anything going on in server.log?
The second stacktrace shows a worker thread sitting in a read() call, waiting for some work to do. It's perfectly natural.
A timeout value for both the client side read() and the server side read() can be configured on the server. Where you do the configuring depends on which subsystem you want to configure. For EJB3, for example, go to $JBOSS_HOME/server/$CONFIG/deploy/ejb3-connectors-jboss-beans.xml and add "timeout" to the "InvokerLocator" property. For example,
<property name="invokerLocator">
<value-factory bean="ServiceBindingManager" method="getStringBinding">
<parameter>
jboss.remoting:type=Connector,name=DefaultEjb3Connector,handler=ejb3
</parameter>
<parameter>
<null />
</parameter>
<parameter>socket://${jboss.bind.address}:${port}/?timeout=60000</parameter>
<parameter>
<null />
</parameter>
<parameter>3873</parameter>
</value-factory>
would set the timeout to one minute on both the client and server side.
-Ron