views:

231

answers:

3

I want to build a JEE application (EAR) which not only provides web service(WAR) or direct JMS request (EJB), but I would like to also accept the socket request (e.g. UDP packet).

I have tried writing a listener with java.net.DatagramSocket, letting it run as separate process, and redirecting the request to my EAR application.

the question is.. how can I build such socket listener into my JEE (EAR) applcation seamlessly?

thanks.

+1  A: 

As far as I know it doesn't conform to the spec.

deamon
+1  A: 

Everything should be controlled by the container, because it's the only way to have a scaling application using JEE.

A few options:

stacker
+2  A: 

The right approach would be to create a JCA adapter for that. JCA adapter can be used for outbound or inbound connectivity. You're allowed to start thread or schedule work in a JCA adpater. The inbound connectivity from the JCA adapter to the EJB is done using custom message-driven bean.

  • The adapter start a socket listener and manage the connection from remote clients
  • When a packet is received, a message is delivered to a custom MDB
  • The MDB can then delegate the processing to other EJBs

You can even start transaction from the JCA connector so that the delivery of the message/packet to the EJB is transacted. JCA is part of the JEE specifications and is supported by all application servers.

Another approach (but not compliant with the spec), is to start the thread that listens to the socket from a ServletContextListener. The thread will run in the web layer and you can call the EJB as usual. Dependency injection will not work, but JNDI lookup should still be ok.

ewernli