Spring
Общие
Модули
Что я использовал
- Inversion of Control-контейнер: конфигурирование компонентов приложений и управление жизненным циклом Java-объектов.
- Фреймворк доступа к данным: работает с системами управления реляционными базами данных на Java-платформе, используя JDBC- и ORM-средства и обеспечивая решения задач, которые повторяются в большом числе Java-based environments.
- Фреймворк управления транзакциями: координация различных API управления транзакциями и инструментарий настраиваемого управления транзакциями для объектов Java.
- Фреймворк MVC: каркас, основанный на HTTP и сервлетах, предоставляющий множество возможностей для расширения и настройки (customization).
- Фреймворк удалённого доступа: конфигурируемая передача Java-объектов через сеть в стиле RPC, поддерживающая RMI, CORBA,HTTP-based протоколы, включая web-сервисы (SOAP).
- Фреймворк аутентификации и авторизации: конфигурируемый инструментарий процессов аутентификации и авторизации, поддерживающий много популярных и ставших индустриальными стандартами протоколов, инструментов, практик через дочерний проект Spring Security (ранее известный как Acegi).
- Тестирование: каркас, поддерживающий классы для написания модульных и интеграционных тестов.
- Фреймворк аспектно-ориентированного программирования: работает с функциональностью, которая не может быть реализована возможностями объектно-ориентированного программирования на Java без потерь.
Что я не использовал
- Фреймворк удалённого управления: конфигурируемое представление и управление Java-объектами для локальной или удалённой конфигурации с помощью JMX.
- Фреймворк работы с сообщениями: конфигурируемая регистрация объектов-слушателей сообщений для прозрачной обработки сообщений из очереди сообщений с помощью JMS, улучшенная отправка сообщений по стандарту JMS API.
Transactional
Если выбрасывется checked исключение, то происходит commit, а не rollback.
Для выполнения rollback при checked исключении нужно его прописать в самой аннотации в аттрибуте rollbackFor.
Data / Repository
Как сделать findByXXX, countByXXX:
Формирование методов в репозитории 2.0.8
Формирование методов в репозитории 1.11.3
Как сделать limit, pageable (см. ниже про Pageable):
Лимит выдачи / постраничная выдача результатов
Возможно вместо лимита стоит использовать интерфейс с Pageable.
JPA with Hibernate, p. 262, 11.2.1 Understanding database-level concurrency - графически описаны уровни изоляции транзакция и проблемы при выборе конкретного варианта.
Interface based projections
Security
@EnableGlobalMethodSecurity(prePostEnabled = true, securedEnabled = true)
Securing methods with annotations
@Secured @EnableGlobalMethodSecurity(jsr250Enabled=true)
@RolesAllowed
Using expressions for method-level security
Аннотация | Описание |
---|---|
@PreAuthorize | Restricts access to a method before invocation based on the result of evaluating an expression |
@PostAuthorize | Allows a method to be invoked, but throws a security exception if the expression evaluates to false |
@PostFilter | Allows a method to be invoked, but filters the results of that method based on an expression |
@PreFilter | Allows a method to be invoked, but filters input prior to entering the method |
Cloud Messaging / Kafka
В разных версиях настройка отличается, все похоже но есть свои особенности.
Spring boot 1.5.14 / cloud stream binder kafka 1.2.1
spring.cloud.stream.bindings.my-sink.group: group8
spring.cloud.stream.kafka.bindings.my-sink.consumer.configuration.autoCommitIntervalMs: 36000000
spring.kafka.consumer.groupId: group8
spring.kafka.consumer.autoCommitInterval: 36000000
Spring boot 2.0.3 / cloud stream binder kafka 2.0.0
spring.cloud.stream.kafka.binder.configuration.group.id=group7
spring.cloud.stream.kafka.binder.configuration.auto.commit.interval.ms=3600000