java ee - Singleton session bean -
singleton session bean has been introduced address problems ?? sharing data common beans ??
how problem managed in ejb 3.0 , versions before ?
if retains client specific conversational state , single instance having clients'(that trying access concurrently) specific data in it?? secure??
if can use static final variables , static initializer block or static methods initialize them (as static variables per class data not per instance data) in other session beans, sharing common data across beans, need of singleton session bean ?
is design have business methods in singleton?? if so, response time client requests served single instance more when served multiple instances.
moreover, while singleton bean allows concurrent access of single bean instance multiple clients, default lock type (write lock) in default concurrency type (container managed) block other threads accessing bean until method over, , , seems disadvantage right ??
it helpful if give clear & simple usecase no other beans fit singleton bean does
thanks in advance :)
yes.
typically data stored in static variables. static variables not great variety of reasons including unit testing. additionally, static variables require kind of synchronization, , strict reading of ejb spec not allow though in practice worked fine.
typically state stored in singleton not client-specific application-specific. example, caching global configuration state or caching global state database, perhaps refreshing periodic non-persistent timer.
there isn't, see #2.
no, singleton beans not fit request-based business logic. yes, default container concurrency write lock, single thread @ time. should use
@lock(read)
or@concurrencymanagement(bean)
needed.as mentioned in #3, typically "global" application state needs shared across beans. find singleton session beans useful application configuration , managing application-wide timers.
Comments
Post a Comment