Profiles
JHipster comes with two Spring profiles:
dev
for development: it focuses on ease of development and productivityprod
for production: it focuses on performance and scalability
Those profiles come in two different configurations:
- The Maven/Gradle profiles are used at build time. For example
./mvnw -Pprod package
or./gradlew -Pprod bootJar
will package a production application. - The Spring profiles work at run time. Some Spring beans will behave differently, depending on the profile.
Spring profiles are set by Maven/Gradle, so we have a consistency between the two methods: you will have a prod
profile on Maven/Gradle and Spring at the same time.
Note: Spring profiles are used to configure the JHipster application properties, so you should be interested in reading our common application properties documentation.
By default, JHipster will use the dev
profile
If you run the application without Maven/Gradle, launch the “Application” class (you can probably run it directly from your IDE by right-clicking on it).
If you run the application with Maven, run ./mvnw
to use our Maven Wrapper, or mvn
to use your own Maven installation.
If you run the application with Gradle, run ./gradlew
to use our Gradle Wrapper, or gradle
to use your own Gradle installation.
When using Angular 2+ and Maven if you need to do a clean run with webpack compilation enabled for dev
profile you can pass the webapp
param as below
./mvnw -Pdev,webapp
Note Gradle automatically runs webpack compilation in dev
profile if front end has changed (only at start up, for live reload use npm start
or yarn start
).
In production, JHipster has to run with the prod
profile
You can run JHipster in production directly using Maven or Gradle:
- With Maven, run
./mvnw -Pprod
(ormvn -Pprod
) - With Gradle, run
./gradlew -Pprod
(orgradle -Pprod
)
If you want to package your application as an executable WAR file, you should provide Maven or Gradle with a profile. E.g.,:
- With Maven, run
./mvnw -Pprod package
(ormvn -Pprod package
) - With Gradle, run
./gradlew -Pprod bootJar
(orgradle -Pprod bootJar
)
When you run your production application from a WAR file, the default is to use the same profile(s) as used during packaging. If you want to override this, you can explicitly provide an alternative in VM argument:
java -jar jhipster-0.0.1-SNAPSHOT.jar --spring.profiles.active=...
Spring profiles switches
JHipster comes with three additional profiles used as switches:
api-docs
to enable swaggerno-liquibase
to disable liquibasetls
to enable TLS security and use the HTTP/2 protocol (see the TLS and HTTP/2 documentation)
These can be used along with both the dev
and prod
profiles. Please note that by default, the api-docs
profile is not enabled in prod
and enabled in dev
by setting the spring.profiles.group.dev
profile group property in application.yml
.
api-docs
, no-liquibase
, tls
are only used at runtime:
- In your IDE, run your main application class with
spring.profiles.active=dev,no-liquibase
(please note you need to include thedev
orprod
profile explicitly) - With a packaged application:
./java -jar jhipster-0.0.1-SNAPSHOT.war --spring.profiles.active=prod,no-liquibase
With Maven, you can also use those profiles directly:
./mvnw -Pprod,api-docs,no-liquibase
./mvnw -Pdev,no-liquibase
With Gradle, you can also use those profiles directly:
./gradlew -Pprod -Papi-docs -Pno-liquibase
./gradlew -Pno-liquibase