it-swarm.com.ru

Ускорьте время запуска Spring Boot

У меня есть приложение Spring Boot. Я добавил много зависимостей (к сожалению, все они мне нужны), и время запуска значительно возросло. Просто выполнение SpringApplication.run(source, args) занимает 10 секунд. 

Хотя это не так уж много по сравнению с тем, к чему «привыкли», я недоволен тем, что это занимает так много, в основном потому, что это нарушает процесс разработки. Само приложение на данный момент довольно маленькое, поэтому я предполагаю, что большую часть времени оно связано с добавленными зависимостями, а не с самими классами приложения.

Я предполагаю, что проблема заключается в сканировании пути к классам, но я не уверен, как:

  • Подтвердите, что это проблема (то есть, как «отладить» Spring Boot)
  • Если это действительно причина, как я могу ограничить ее, чтобы она стала быстрее? Например, если я знаю, что какая-то зависимость или пакет не содержит ничего, что Spring должен сканировать, есть ли способ ограничить это? 

Я предполагаю это:

будет ускорять вещи, но это даже не сработало на этом этапе. Я вижу некоторые другие усилия в самой Spring Boot, например:

но это выглядит для Tomcat.

Эта статья:

хотя он нацелен на интеграционные тесты, предлагает использовать lazy-init=true, однако я не знаю, как применить это ко всем bean-компонентам в Spring Boot с использованием конфигурации Java - есть ли здесь какие-нибудь указатели?

Любые (другие) предложения будут приветствоваться.

58
steady rain

Spring Boot делает много автоматической настройки, которая может не потребоваться. Поэтому вы можете захотеть сузить только автоконфигурацию, которая необходима для вашего приложения. Чтобы увидеть полный список включенных автоконфигураций, просто запустите протоколирование org.springframework.boot.autoconfigure в режиме DEBUG (logging.level.org.springframework.boot.autoconfigure=DEBUG в application.properties). Другой вариант - запустить приложение весенней загрузки с параметром --debug: Java -jar myproject-0.0.1-SNAPSHOT.jar --debug 

Там будет что-то вроде этого в выводе:

=========================
AUTO-CONFIGURATION REPORT
=========================

Изучите этот список и включите только те автоконфигурации, которые вам нужны:

@Configuration
@Import({
        DispatcherServletAutoConfiguration.class,
        EmbeddedServletContainerAutoConfiguration.class,
        ErrorMvcAutoConfiguration.class,
        HttpEncodingAutoConfiguration.class,
        HttpMessageConvertersAutoConfiguration.class,
        JacksonAutoConfiguration.class,
        ServerPropertiesAutoConfiguration.class,
        PropertyPlaceholderAutoConfiguration.class,
        ThymeleafAutoConfiguration.class,
        WebMvcAutoConfiguration.class,
        WebSocketAutoConfiguration.class,
})
public class SampleWebUiApplication {

Код был скопирован из это сообщение в блоге .

36
luboskrnac

Пока что голосование с наибольшим количеством голосов не является неправильным, но оно не идет вглубь, которую мне нравится видеть, и не дает никаких научных доказательств. Команда Spring Boot выполнила упражнение по сокращению времени запуска Boot 2.0, и в тикете 11226 содержится много полезной информации. Существует также билет 7939 , открытый для добавления информации о времени к оценке состояния, но, похоже, у него нет конкретного ETA.

Наиболее полезный и методичный подход для отладки запуска загрузки был сделан Дэйвом Сайером. https://github.com/dsyer/spring-boot-startup-bench

У меня был похожий вариант использования, поэтому я воспользовался подходом Дейва к микро-бенчмаркингу с JMH и побежал с ним. Результатом является boot-benchmark project. Я разработал его так, чтобы его можно было использовать для измерения времени запуска любого приложения Spring Boot, используя исполняемый файл jar, созданный bootJar (ранее называемый bootRepackage в Boot 1.5) задачей Gradle. Не стесняйтесь использовать его и оставить отзыв.

Мои выводы следующие:

  1. ЦП имеет значение. Много. 
  2. Запуск JVM с -Xverify: нет помогает значительно.
  3. Исключение ненужных автоконфигураций помогает.
  4. Дейв рекомендовал аргумент JVM -XX: TieredStopAtLevel = 1 , но мои тесты не показали существенного улучшения с этим. Кроме того, -XX:TieredStopAtLevel=1, вероятно, замедлит ваш первый запрос.
  5. Были отчеты разрешения имени хоста были медленными, но я не обнаружил, что это является проблемой для приложений, которые я тестировал.
14
Abhijit Sarkar

Как описано в этом вопросе/ответе, я думаю, что лучший подход состоит в том, чтобы вместо добавления только тех, которые, по вашему мнению, вам нужны, исключить зависимости, которые, как вы знаете, вам не нужны.

Смотрите: Минимизируйте время запуска весенней загрузки

В итоге:

Вы можете увидеть, что происходит под одеялом, и включить ведение журнала отладки так же просто, как указать --debug при запуске приложения из командной строки. Вы также можете указать debug = true в вашем application.properties.

Кроме того, вы можете установить уровень ведения журнала в application.properties так же просто, как:

logging.level.org.springframework.web: DEBUG logging.level.org.hibernate: ОШИБКА

Если вы обнаружите автоматически настроенный модуль, который вам не нужен, его можно отключить. Документы для этого можно найти здесь: http://docs.spring.io/spring-boot/docs/current-SNAPSHOT/reference/htmlsingle/#using-boot-disabling-specific-auto-configuration

Пример будет выглядеть так:

@Configuration
@EnableAutoConfiguration(exclude={DataSourceAutoConfiguration.class})
public class MyConfiguration {
}
6
pczeus

Spring Boot 2.2.M1 добавил функцию для поддержки отложенной инициализации в Spring Boot.

По умолчанию при обновлении контекста приложения создается каждый компонент в контексте и внедряются его зависимости. Напротив, когда определение bean-компонента сконфигурировано для ленивой инициализации, оно не будет создано, и его зависимости не будут внедрены до тех пор, пока это не понадобится.

Включение отложенной инициализации Установите spring.main.lazy-initialization в true

Для более подробной информации, пожалуйста, проверьте Док

4
Niraj Sonawane

Если вы пытаетесь оптимизировать процесс разработки для ручного тестирования, я настоятельно рекомендую использовать devtools .

Приложения, использующие spring-boot-devtools, автоматически перезапустятся всякий раз, когда файлы на пути к классам меняются.

Просто перекомпилируйте - и сервер перезагрузится сам (для Groovy вам нужно только обновить исходный файл). если вы используете IDE (например, «vscode»), он может автоматически компилировать ваши файлы Java, поэтому простое сохранение файла Java может инициировать перезапуск сервера, косвенно - и Java становится такой же цельной, как Groovy в это отношение.

Прелесть этого подхода в том, что при постепенном перезапуске происходит короткое замыкание на некоторых этапах запуска с нуля, поэтому ваша служба будет работать быстрее и быстрее!


К сожалению, это не помогает со временем запуска для развертывания или автоматического модульного тестирования.

0
nobar