I have gone through various books on stateful and stateless session bean and how they work. I want to know the real usage of these ejbs and advantages over using plain java classes. Basically when do you go for stateless ejbs and when do you go for stateful ejbs. I want a real time application.
相关问题
- Is JavaEE really portable?
- Tables not getting auto-created in Apache Derby wh
- Is it legal to inject a @Stateful into an MDB?
- ClassNotFoundException marshaling EJB parameters
- EJB3 Client Lookup
相关文章
- How do I access EJB bean when inside a custom Conv
- Is there a Problem with JPA Entities, Oracle 10g a
- How can I avoid the Warning “firstResult/maxResult
- EJB3 DataSource DataSource.getConnection
- How to test EJB method call with Arquillian Weld E
- How to configure embedded OpenEJB container for te
- Configurable values to MDB annotations
- How to get the invoker name in EJB interceptor'
the usage of these type of ejbs are usually in service layer as service classes.
EJB3 stateless and stateful bean are actually POJO (with some annotations) and they don't have any big difference with normal classes.
but in term of usage, they have some abilities that you can't find in normal classes like:
stateless or stateful: - if a task or process can be done in a single step (by a single method call) stateless is the right option like a authentication process - if a task needs a series of method calls (more than one) and you need to keep previous results to use them in next call, then go for stateful. like a shipping process (select items, add/remove and then do the transaction)
http session or stateful?
ejbs can be served in application server and they may have different type of clients like a normal swing application or ..., so you can't relay on http session in these cases.
if your appserver and webserver are different (distributed) its not good idea keep data in http session and pass/getback it to/from app server (network overhead).
Stateless session bean are lightweight: they do not store information about a specific user. They are usually used in a static way. For example a client ask for a product information will communicate with a stateless session bean. ("You want the price of product 'YXZ', here you go!")
Stateful session bean however remember's the client information. They contains data about the user actions. For example, let's say a user go through a shopping cart. The steps will be stored in a stateful session bean (for example, user it at the payment step).
You really need both type of session bean in any website. Unless you web site is so basic that anything can be done with stateless session bean (a read-only web site really).
Any web site that track a user through cookies, will need a stateful session bean. Be aware however that you can decide to put very little session information in a session bean and store that information in a database. But you still need some session management.
An example is a shopping cart stateful session bean that tracks a client's product choices and can execute a sale when requested.
Developers prefer to maintain state in web layer in modern enterprise applications. I have never seen a real world web application using Stateful Session Bean. It is a scalability issue also.