Вопрос по spring – @PersistenceContext EntityManager потокобезопасность в Spring и Java EE

12

EntityManager являетсяnot thread-safe по определению. Спецификация сервлетов говорит, что в нераспределенной среде и без реализацииSingleThreadModel, естьonly one servlet instance per definition.

Поэтому в Java EE, когда вы вводитеEntityManager сквозь@PersistenceContext в поле сервлета - это не потокобезопасно:

<code>public class MyServlet extends HttpServlet {

    // Not thread-safe, should be using EMF instead.
    @PersistenceContext
    private EntityManager em;
}
</code>

Is this correct to say that even though the default scope of Spring beans is singleton, the EntityManager is thread-safe as the Spring uses ThreadLocal to bind its transaction and EntityManager to it?

Is the above Servlets example still valid in Spring? Is it still not thread-safe?

Does the ThreadLocal approach works only for Spring managed beans and plain servlet is not one of those?

As far as I remember, it's the container responsibility to inject the EntityManager. In Glassfish Java EE implementation, it was the application server who discovers the @PersistenceContext as injection point.
How does it look like in Spring? Is the Spring Framework responsible for discovering those annotations or it's responsibility of the JPA implementor?

Ваш Ответ

1   ответ
6

3 и 4 - Spring не обращает внимания ни на один класс, который не является Spring Bean. Поэтому весна не обращает на вас вниманияMyServlet учебный класс. Поэтому ответ на

2) is no 3) only Spring managed Beans 4) it is Springs responsibility, because Spring is the Container

На вопрос 1). Это работает таким образом, поэтому использование Spring Injected Entity Manager эффективно сохраняет потоки.

Спасибо, Ральф. Таким образом, говоря "2) нет" Вы имеете в виду, что он не ориентирован на многопотоковое исполнение, потому что этот сервлет не является бином Spring, поэтому на самом делеno injection will occur at all? Можно ли пометить такой сервлет как боб Spring? Я как-то чувствую, что это довольно необычная, не рекомендуемая и грязная идея - это просто теоретический вопрос для понимания механизма Spring. Piotr Nowicki
Я имею в виду, что это совсем не Spring bean (именно об этом первый абзац), поэтому здесь нет инъекций иem будет нулевым - Проверьте это, если оно не равно нулю, тогда происходит что-то действительно странное. Один из способов сделать это бобом весной - это@Configurable но для этого нужен настоящий AspectJ, и я понятия не имею, работает ли это для сервлетов.

Похожие вопросы