it-swarm-ru.tech

Должен ли я использовать EJB3 или Spring для своего бизнес-уровня?

Моя команда разрабатывает новый сервис-ориентированный продукт с веб-интерфейсом. При обсуждении того, какие технологии мы будем использовать, мы остановились на работе сервера приложений JBoss, веб-интерфейса Flex (с возможностью развертывания на рабочем столе с использованием Adobe AIR) и веб-служб для взаимодействия клиента и сервера.

Мы зашли в тупик, когда речь заходит о том, какую серверную технологию использовать для нашей бизнес-логики. Главный аргумент - между EJB3 и Spring, при этом нашими основными проблемами являются масштабируемость и производительность, а также удобство сопровождения базы кода.

Вот мои вопросы:

  1. Каковы аргументы за или против EJB3 против Spring?
    • Какие подводные камни можно ожидать с каждым?
    • Где я могу найти хорошую информацию о тестах?
71
Justin Standard

Там не будет большой разницы между EJB3 и Spring на основе производительности. Мы выбрали Spring по следующим причинам (не упомянутым в вопросе):

  • Spring направляет архитектуру в направлении, которое более легко поддерживает модульное тестирование. Например, вставьте фиктивный объект DAO для модульного тестирования вашего бизнес-уровня или используйте объект Spring MockHttpRequest для модульного тестирования сервлета. Мы поддерживаем отдельную конфигурацию Spring для модульных тестов, которая позволяет нам изолировать тесты для определенных уровней.
  • Основным драйвером была совместимость. Если вам нужно поддерживать более одного сервера приложений (или, в конечном итоге, вы захотите перейти с JBoss на Glassfish и т.д.), Вы, по сути, будете нести свой контейнер (Spring) с собой, а не полагаться на совместимость между различными реализациями Спецификация EJB3.
  • Spring позволяет выбирать технологии для Persistence, удаленного взаимодействия объектов и т.д. Например, мы также используем интерфейс Flex и используем протокол Hessian для связи между Flex и Spring.
72
John Stauffer

Ясно, что разрыв между EJB3 и Spring намного меньше, чем был. Тем не менее, один из недостатков EJB3 теперь заключается в том, что вы можете внедрять только в bean-компонент, поэтому вы можете в конечном итоге превратить компоненты в bean-компоненты, которые не нужны.

Аргумент о модульном тестировании в настоящее время довольно неактуален - EJB3 явно спроектирован так, чтобы его было легче тестировать.

Приведенный выше аргумент совместимости также не имеет значения: используете ли вы EJB3 или Spring, вы все еще зависите от сторонних реализаций менеджеров транзакций, JMS и т.д.

Однако для меня это поддержка со стороны сообщества. Работая над проектом EJB3 в прошлом году, просто было мало людей, которые использовали его и говорили о своих проблемах. Spring, правильно или неправильно, чрезвычайно распространен, особенно на предприятии, и это облегчает поиск человека, у которого есть та же проблема, которую вы пытаетесь решить.

37
PEELY

Каковы аргументы за или против EJB3 против Spring? Spring всегда вводит новшества и признает ограничения реального мира. Spring предлагал простоту и элегантность для серверов приложений Java 1.4 и не требовал версии спецификации J2EE, к которой никто не имел доступа в 2004 - 2006 годах. На данный момент это почти религиозная дискуссия, которую вы могут быть втянуты в - Spring + abstraction + open-source против Java спецификации Enterprise Edition (Java EE) 5.0.

Я думаю, что Spring дополняет больше, чем конкурирует со спецификациями Java EE. Поскольку функции, которые когда-то были уникальными для Spring, продолжают включаться в спецификацию, многие будут утверждать, что EJB 3 предлагает "достаточно хороший" набор функций для большинства внутренних бизнес-приложений.

Какие подводные камни можно ожидать с каждой из них? Если вы рассматриваете это как проблему постоянства (Spring + JPA) по сравнению с EJB3, вы на самом деле не делаете такой большой выбор.

Где найти хорошую информацию о бенчмарке? Я некоторое время не следил за результатами теста specj , но они были популярны для какое-то время. Кажется, что каждый поставщик (IBM, JBOSS, Oracle и Sun) все меньше и меньше интересуется наличием совместимого сервера. Списки становятся короче и короче сертифицированных поставщиков по мере того, как вы переходите от 1.3, 1.4. 1,5 Java Enterprise Edition. Я думаю, что времена гигантского сервера, который полностью соответствует всем спецификациям, прошли.

18
Brian

Я определенно рекомендую EJB3 на весну. Мы находим, что он более оптимизирован, более приятен для кодирования и лучше поддерживается. В прошлом я использовал Spring и обнаружил, что он очень запутанный, и не так хорошо документирован, как EJB3 (или JPA, я думаю, в конце дня)

  1. Начиная с EJB3 вам больше не нужно иметь дело с внешними конфигурационными файлами, и есть только один POJO, который вы аннотируете для каждой таблицы базы данных. Этот POJO может быть без проблем передан на ваш веб-уровень. IDE, такие как Netbeans, могут даже автоматически генерировать эти POJO для вас. Мы использовали EJB3 в качестве бэкэнда для довольно большого количества крупномасштабных приложений и не заметили никаких проблем с производительностью. Ваш компонент Session Bean может быть легко представлен в виде веб-служб, которые вы можете использовать в своем интерфейсе Flex. Сессионные компоненты легко блокировать на уровне метода или класса для назначения ролей и тому подобного, если вам это нужно.

Я не могу так много говорить о весне, так как пробовал всего несколько недель. Но мое общее впечатление об этом было очень плохим. Это не означает, что это плохая структура, но наша команда нашла EJB3 лучшим для уровня персистентности/бизнеса.

9
rustyshelf

Я склонен предпочесть Spring над EJB3, но моя рекомендация будет заключаться в том, какой подход вы выберете, попробуйте придерживаться написания POJO и, где возможно, использовать стандартные аннотации, такие как аннотации JSR, такие как @PostConstruct, @PreDestroy и @Resource, которые работают с обоими EJB3 или весна, чтобы вы могли выбрать любой каркас, который вы предпочитаете.

например Вы можете выбрать какой-нибудь проект, чтобы использовать Guice вместо IoC.

Если вы хотите использовать внедрение перед запросом, например, в веб-приложении, вы можете обнаружить, что Guice немного быстрее для внедрения зависимостей, чем Spring.

Сессионные компоненты в основном сводятся к внедрению зависимостей и транзакциям; так что EJB3 и Spring действительно похожи на это. Где у Spring Edge есть лучшее внедрение зависимости и более приятные абстракции для таких вещей, как JMS

7
James Strachan

я использовал очень похожую архитектуру в прошлом. Spring + Java 1.5 + Actionscript 2/3 в сочетании с Flex Data Services сделали все это очень простым (и увлекательным!) Для написания кода. тем не менее, внешний интерфейс Flex означает, что вам нужны достаточно мощные клиентские машины.

2
Soumitra

По поводу вашего вопроса:

Каковы аргументы за или против EJB3 против Spring?

Я предлагаю прочитать ответ экспертов: ОТВЕТ НА: EJB 3 И СРАВНИТЕЛЬНЫЙ АНАЛИЗ ВЕСНЫ Марком Фишером . Прочитайте комментарии, чтобы найти замечания Резы Рахмана (EJB 3.0).

1
krams

Еще одна вещь в пользу Spring - это то, что большинство других инструментов/фреймворков имеют лучшую поддержку для интеграции с пружиной, большинство из них также используют Spring внутри (например, activemq, camel, CXF и т.д.).

Он также более зрелый, и в нем гораздо больше ресурсов (книг, статей, лучших практик и т.д.) И опытных разработчиков, чем для EJB3.

0
kamal.gs