Help us understand the problem. What is going on with this article?

spring-boot-devtoolsで開発効率上げようぜ、的な。 (Spring Boot 1.3)

More than 3 years have passed since last update.

はじめに

Spring Boot 1.3で、spring-boot-devtoolsという開発補助モジュールが導入されるということで、
その概説(DevTools in Spring Boot 1.3)の雑な訳と所感を書いてみました。
(一部、執筆時のReference Guideの記載に合わせて補足をしています)

DevTools in Spring Boot 1.3

Spring Boot 1.3では、spring-boot-devtoolsっていう開発作業に便利なモジュールが使えるようになるよ!
使うためには、dependency追加してね。

pom.xml
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
    </dependency>
</dependencies>
build.gradle
dependencies {
    compile("org.springframework.boot:spring-boot-devtools")
}

ちょっとした前置き

以下、「開発段階では自動で○○するようになる」という記述がありますが、"開発段階 ≠ Production"の判断はアプリケーションの起動方法によって自動で判別されます。
具体的には、java -jarでの起動であったり、他の特別なクラスローダを使用した場合には"Production"として扱われます。

Property Defaults

Spring Boot 1.2でThymeleaf使ってるとき、spring.thymeleaf.cacheの設定でテンプレートのキャッシュをoffにできるのはご存知の通り。
この設定はお手軽だけど、開発中に「cacheがon/offどっちか」を常に気にしてないのはメンドイよね。
というわけで、開発段階ではテンプレートエンジン(ThymeleafFreemarkerGroovy TemplatesVelocity、あとMustache)のcacheをデフォルトでoffにするようにしたよ。

Automatic Restart

JRebelSpring Loaded使ってる人は知ってると思うけど、自動リロード便利だよね。
でもこの辺のツール使おうと思うとIDEの設定いじったりしなきゃいけないし、ものによってはお金かかる!

それらの"instant reload"技術よりはちょっと遅いけど、似たようなことできるようにしたよ。
spring-boot-devtoolsをincludeしていたら、classpathで捕捉してるすべてのファイルを対象として、
ファイルに変更があったら、アプリケーションを自動で再起動するようになるよ。

補足

デフォルトでは、Thymeleafのテンプレートやcss、jsなどのリコンパイル不要なstaticファイルなどが変更されても、Automatic Restartは実行されません。(そもそも再起動が不要だから)
ただし、次に記述するLiveReloadのトリガにはなります。
Automatic Restartのトリガ対象から外すためには、下記のプロパティが利用可能です。

  • spring.devtools.restart.exclude
    • デフォルトの例外対象を無視して、完全に例外を指定しなおす場合に利用
      • e.g. spring.devtools.restart.exclude=static/**,public/**
  • spring.devtools.restart.additional-exclude
    • デフォルトの例外対象(/resource/staticなど)はそのままに、例外対象を追加する場合に利用

同じように、classpath外のファイルをAutomatic Restartの対象にしたい場合、spring.devtools.restart.additional-pathsプロパティで指定が可能です。

LiveReload

"cache properties"や"automatic restarts"の動作を画面に反映させるためには、ブラウザで更新ボタンをクリックする必要があって、面倒だよね。
LiveReload機能を使うと、ブラウザの更新を行うための通知を自動でしてくれるので、アプリが再起動した直後にブラウザが自動更新されるようになるよ!
そのためのBrowser Extensionは無料でインストールできるから、livereload.comからGetしてね。
(Chrome、Firefox、Safariが対応してる)

補足

LiveReloadの機能は1アプリケーションに対してのみ有効です。
例えば複数のアプリケーションを起動している場合、最初に起動した1つのみがLiveReloadの対象になります。

Remote Debug Tunneling

DockerLatticeを使ったことがあると分かると思うけど、デバッグするのが凄く面倒だよね。
リモートデバッグするために、-Xdebugオプションつけて適切なportにフォワーディングして・・・っていう設定もやらなくちゃいけないし。

Spring Boot 1.3では、JDWP(the Java Debug Wire Protocol)を使って、
「サーバ側では80と443portだけ空いてる」状態でも、シンプルな設定でリモートデバッグができるようになるよ。

Remote Update and Restart

リモートデバッグだけじゃなくて、リモートで動いているアプリの更新・再起動もできるよ!
つまり、ローカルでファイルを変更したら、それがリモートサーバのアプリに反映されるってこと。

補足

この機能はデフォルトでは無効になっています。
利用するためには、spring.devtools.remote.secretをsetする必要があります。

例えば、my-appというサービスをCloud Foundlyのhttps://myapp.cfapps.ioに対してデプロイしている場合の設定手順は以下のようになります。

  1. my-appのapplication.propertiesにspring.devtools.remote.secretをセットしたものをデプロイ。
    • (LocalとRemoteのマッチングのために利用されるだけなので、値は何でもOK。)
  2. IDEのRun Configurationで、main classにorg.springframework.boot.devtools.RemoteSpringApplicationを指定
  3. Program argumentshttps://myapp.cfapps.ioを指定

この設定で起動した場合、以下のようなコンソール出力となります。

  .   ____          _                                              __ _ _
 /\\ / ___'_ __ _ _(_)_ __  __ _          ___               _      \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` |        | _ \___ _ __  ___| |_ ___ \ \ \ \
 \\/  ___)| |_)| | | | | || (_| []::::::[]   / -_) '  \/ _ \  _/ -_) ) ) ) )
  '  |____| .__|_| |_|_| |_\__, |        |_|_\___|_|_|_\___/\__\___|/ / / /
 =========|_|==============|___/===================================/_/_/_/
 :: Spring Boot Remote :: 1.3.0.BUILD-SNAPSHOT

2015-06-10 18:25:06.632  INFO 14938 --- [           main] o.s.b.devtools.RemoteSpringApplication   : Starting RemoteSpringApplication on pwmbp with PID 14938 (/Users/pwebb/projects/spring-boot/code/spring-boot-devtools/target/classes started by pwebb in /Users/pwebb/projects/spring-boot/code/spring-boot-samples/spring-boot-sample-devtools)
2015-06-10 18:25:06.671  INFO 14938 --- [           main] s.c.a.AnnotationConfigApplicationContext : Refreshing org.springframework.context.annotation.AnnotationConfigApplicationContext@2a17b7b6: startup date [Wed Jun 10 18:25:06 PDT 2015]; root of context hierarchy
2015-06-10 18:25:07.043  WARN 14938 --- [           main] o.s.b.d.r.c.RemoteClientConfiguration    : The connection to http://localhost:8080 is insecure. You should use a URL starting with 'https://'.
2015-06-10 18:25:07.074  INFO 14938 --- [           main] o.s.b.d.a.OptionalLiveReloadServer       : LiveReload server is running on port 35729
2015-06-10 18:25:07.130  INFO 14938 --- [           main] o.s.b.devtools.RemoteSpringApplication   : Started RemoteSpringApplication in 0.74 seconds (JVM running for 1.105)

Video Preview

詳しいことはreference guide読んでね。
あと、videoも用意したよ。
DevTools in Spring Boot 1.3(Demo)

所感

Remote Update and Restartが超強力。
これによって、

コード書く→コンパイルする→デプロイ(ファイルを配置して起動)する→ブラウザで更新する

って作業が、

コード書く→ブラウザに自動で反映される

だけになって、コーディング"だけ"してりゃいいって状態に持っていけそうです。

参考文献

Getting Started with Spring Boot 1.3 & DevTools
Spring Boot 1.3 News #渋谷Java

Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
Comments
No comments
Sign up for free and join this conversation.
If you already have a Qiita account
Why do not you register as a user and use Qiita more conveniently?
You need to log in to use this function. Qiita can be used more conveniently after logging in.
You seem to be reading articles frequently this month. Qiita can be used more conveniently after logging in.
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
ユーザーは見つかりませんでした