mirror of
https://github.com/spring-projects/spring-boot.git
synced 2024-08-29 03:06:45 +08:00
cf24af0bfb
Prior to this commit LoggingSystem initialization would happen multiple times. Once to configure "quiet" logging, and again to configure correct settings once the Application was initialized. This could cause problems if `logging.groovy` logback files were used. The logging system is now only initialized once (when possible) by following these steps: - Standard logging initialization occurs via the actual logging implementation used (e.g. logback will load a logback.xml file if it exists) - beforeInitization() is called to prevent early log output. Implementations now either use a Filter or simply set the root logging level. - initialize() is called with an optional log configuration file (e.g a custom logback.xml location) and an optional log output file (the default is null indicating console only output). The initialize() method will attempt to prevent double initialization by checking if a standard configuration file exists. Double initialization now only occurs in the following situations: - The user has a standard configuration file (e.g. classpath:logback.xml) but also specifies a logging.config property. Double initialization is required since the specified configuration file supersedes the default. - The user has a standard configuration file (e.g. classpath:logback.xml) and specifies a logging.file property. Double initialization is required since the standard configuration may use a ${LOG_FILE} reference. In addition this commit removes the `logging.console` option and now assumes that logging either occurs only to console or to both the console and a file. This restriction helps simplify the LoggingSystem implementations. If file only logging is required a custom logback.xml can be used. Fixes gh-1091 See gh-1612, gh-1770 |
||
---|---|---|
.. | ||
spring-boot-sample-actuator | ||
spring-boot-sample-actuator-log4j | ||
spring-boot-sample-actuator-log4j2 | ||
spring-boot-sample-actuator-noweb | ||
spring-boot-sample-actuator-ui | ||
spring-boot-sample-amqp | ||
spring-boot-sample-aop | ||
spring-boot-sample-batch | ||
spring-boot-sample-data-elasticsearch | ||
spring-boot-sample-data-gemfire | ||
spring-boot-sample-data-jpa | ||
spring-boot-sample-data-mongodb | ||
spring-boot-sample-data-redis | ||
spring-boot-sample-data-rest | ||
spring-boot-sample-data-solr | ||
spring-boot-sample-flyway | ||
spring-boot-sample-hornetq | ||
spring-boot-sample-integration | ||
spring-boot-sample-jersey | ||
spring-boot-sample-jersey1 | ||
spring-boot-sample-jetty | ||
spring-boot-sample-jta-atomikos | ||
spring-boot-sample-jta-bitronix | ||
spring-boot-sample-jta-jndi | ||
spring-boot-sample-liquibase | ||
spring-boot-sample-parent-context | ||
spring-boot-sample-profile | ||
spring-boot-sample-secure | ||
spring-boot-sample-servlet | ||
spring-boot-sample-simple | ||
spring-boot-sample-tomcat | ||
spring-boot-sample-tomcat8-jsp | ||
spring-boot-sample-tomcat-multi-connectors | ||
spring-boot-sample-tomcat-ssl | ||
spring-boot-sample-traditional | ||
spring-boot-sample-velocity | ||
spring-boot-sample-web-freemarker | ||
spring-boot-sample-web-groovy-templates | ||
spring-boot-sample-web-jsp | ||
spring-boot-sample-web-method-security | ||
spring-boot-sample-web-secure | ||
spring-boot-sample-web-secure-custom | ||
spring-boot-sample-web-secure-jdbc | ||
spring-boot-sample-web-static | ||
spring-boot-sample-web-ui | ||
spring-boot-sample-web-velocity | ||
spring-boot-sample-websocket | ||
spring-boot-sample-ws | ||
spring-boot-sample-xml | ||
pom.xml | ||
README.adoc |
The following java samples are provided: * link:spring-boot-sample-simple[spring-boot-sample-simple] -- A simple command line application * link:spring-boot-sample-tomcat[spring-boot-sample-tomcat] -- Embedded Tomcat * link:spring-boot-sample-jetty[spring-boot-sample-jetty] -- Embedded Jetty * link:spring-boot-sample-actuator[spring-boot-sample-actuator] -- Simple REST service with production features * link:spring-boot-sample-actuator-ui[spring-boot-sample-actuator-ui] -- A web UI example with production features * link:spring-boot-sample-actuator-noweb[spring-boot-sample-actuator-noweb] -- A production features sample with no web application * link:spring-boot-sample-actuator-log4j[spring-boot-sample-actuator-log4j] -- A production features sample using log4j for logging (instead of logback) * link:spring-boot-sample-web-ui[spring-boot-sample-web-ui] -- A thymeleaf web application * link:spring-boot-sample-web-static[spring-boot-sample-web-static] -- A web application serving static files * link:spring-boot-sample-web-freemarker[spring-boot-sample-web-freemarker] -- A web application using Freemarker templates * link:spring-boot-sample-web-velocity[spring-boot-sample-web-velocity] -- A web application using Velocity templates * link:spring-boot-sample-web-groovy-templates[spring-boot-sample-web-groovy-templates] -- A web application using native Groovy templates * link:spring-boot-sample-web-jsp[spring-boot-sample-web-jsp] -- A web application using JSP templates * link:spring-boot-sample-web-tomcat8-jsp[spring-boot-sample-tomcat8-jsp] -- A web application using JSP templates with Tomcat 8 * link:spring-boot-sample-web-tomcat-multi-connectors[spring-boot-sample-tomcat-multi-connectors] -- A web application using multiple connectors in tomcat, showing how to customize the Tomcat server * link:spring-boot-sample-web-secure[spring-boot-sample-web-secure] -- A web application with typical Security configuration enabling a login form * link:spring-boot-sample-web-method-security[spring-boot-sample-web-method-security] -- A web application with Security configuration enabling global method security * link:spring-boot-sample-secure[spring-boot-sample-secure] -- example showing Spring Security in a non-web application * link:spring-boot-sample-servlet[spring-boot-sample-servlet] -- example showing a "raw" `Servlet` returning plaintext content * link:spring-boot-sample-ws[spring-boot-sample-ws] -- A simple contract-first SOAP web service with Spring Web Services * link:spring-boot-sample-websocket[spring-boot-sample-websocket] -- A web application with Websocket support on the client and server * link:spring-boot-sample-flyway[spring-boot-sample-flyway] -- Example showing database migrations with Flyway * link:spring-boot-sample-liquibase[spring-boot-sample-liquibase] -- Example showing database migrations with Liquibase * link:spring-boot-sample-amqp[spring-boot-sample-amqp] -- Example showing message-oriented application using RabbitMQ * link:spring-boot-sample-hornetq[spring-boot-sample-hornetq] -- Example showing message-oriented application using HornetQ * link:spring-boot-sample-batch[spring-boot-sample-batch] -- Define and run a Batch job in a few lines of code * link:spring-boot-sample-data-jpa[spring-boot-sample-data-jpa] -- Spring Data JPA + Hibernate + HSQLDB * link:spring-boot-sample-data-mongodb[spring-boot-sample-data-mongodb] -- Spring Data Mongo repositories * link:spring-boot-sample-data-solr[spring-boot-sample-data-solr] -- Spring Data Solr repositories * link:spring-boot-sample-data-redis[spring-boot-sample-data-redis] -- Simple usage of Spring Data Redis * link:spring-boot-sample-data-rest[spring-boot-sample-data-rest] -- Crud repositories exposed as REST endpoints * link:spring-boot-sample-integration[spring-boot-sample-integration] -- A spring integration application * link:spring-boot-sample-profile[spring-boot-sample-profile] -- example showing Spring's `@profile` support * link:spring-boot-sample-parent-context[spring-boot-sample-parent-context] -- example showing an `ApplicationContext` with a parent * link:spring-boot-sample-aop[spring-boot-sample-aop] -- shows explicit usage of Spring AOP * link:spring-boot-sample-traditional[spring-boot-sample-traditional] -- shows more traditional WAR packaging (but also executable using `java -jar`) * link:spring-boot-sample-xml[spring-boot-sample-xml] -- Example show how Spring Boot can be mixed with traditional XML configuration (we generally recommend using Java `@Configuration` whenever possible)