zoukankan      html  css  js  c++  java
  • 【转】Spring Boot Profile使用

    http://blog.csdn.net/he90227/article/details/52981747

    摘要: spring Boot使用@Profile注解可以实现不同环境下配置参数的切换,任何@Component或@Configuration注解的类都可以使用@Profile注解。 例如: @Configuration @Profile("production") public class Produc...

    Spring Boot使用@Profile注解可以实现不同环境下配置参数的切换,任何@Component@Configuration注解的类都可以使用@Profile注解。

    例如:

    @Configuration
    @Profile("production")
    public class ProductionConfiguration {
        // ...
    }
    

    通常,一个项目中可能会有多个profile场景,例如下面为test场景:

    @Configuration
    @Profile("test")
    public class TestConfiguration {
        // ...
    }
    

    在存在多个profile情况下,你可以使用spring.profiles.active来设置哪些profile被激活。spring.profiles.include属性用来设置无条件的激活哪些profile。

    例如,你可以在application.properties中设置:

    spring.profiles.active=dev,hsqldb
    

    或者在application.yaml中设置:

    spring.profiles.active:dev,hsqldb
    

    spring.profiles.active属性可以通过命令行参数或者资源文件来设置,其查找顺序,请参考Spring Boot特性

    自定义Profile注解

    @Profile注解需要接受一个字符串,作为场景名。这样每个地方都需要记住这个字符串。Spring的@Profile注解支持定义在其他注解之上,以创建自定义场景注解。

    @Target({ElementType.TYPE, ElementType.METHOD})
    @Retention(RetentionPolicy.RUNTIME)
    @Profile("dev")
    public @interface Dev {
    }
    

    这样就创建了一个@Dev注解,该注解可以标识bean使用于@Dev这个场景。后续就不再需要使用@Profile("dev")的方式。这样即可以简化代码,同时可以利用IDE的自动补全:)

    多个Profile例子

    下面是一个例子:

    package com.javachen.example.service;
    
    public interface MessageService {
      String getMessage();
    }
    

    对于MessageService接口,我们可以有生产和测试两种实现:

    package com.javachen.example.service;
    
    import org.springframework.beans.factory.annotation.Value;
    import org.springframework.context.annotation.Profile;
    import org.springframework.stereotype.Component;
    
    @Component
    @Profile({ "dev" })
    public class HelloWorldService implements MessageService{
    
      @Value("${name:World}")
      private String name;
    
      public String getMessage() {
        return "Hello " + this.name;
      }
    
    }
    
    package com.javachen.example.service;
    
    import org.springframework.beans.factory.annotation.Value;
    import org.springframework.context.annotation.Profile;
    import org.springframework.stereotype.Component;
    
    @Component
    @Profile({ "prod" })
    public class GenericService implements MessageService {
    
      @Value("${hello:Hello}")
      private String hello;
    
      @Value("${name:World}")
      private String name;
    
      @Override
      public String getMessage() {
        return this.hello + " " + this.name;
      }
    
    }
    

    Application类为:

    @SpringBootApplication
    public class Application implements CommandLineRunner {
      private static final Logger logger = LoggerFactory.getLogger(Application.class);
    
      @Autowired
      private MessageService messageService;
    
      @Override
      public void run(String... args) {
        logger.info(this.messageService.getMessage());
        if (args.length > 0 && args[0].equals("exitcode")) {
          throw new ExitException();
        }
      }
    
      public static void main(String[] args) throws Exception {
        SpringApplication.run(Application.class, args);
      }
    }
    

    实际使用中,使用哪个profile由spring.profiles.active控制,你在resources/application.properties中定义spring.profiles.active=XXX,或者通过-Dspring.profiles.active=XXXXXX可以是dev或者prod或者dev,prod需要注意的是:本例中是将@Profile用在Service类上,一个Service接口不能同时存在超过两个实现类,故本例中不能同时使用dev和prod。

    通过不同的profile,可以有对应的资源文件application-{profile}.properties。例如,application-dev.properties内容如下:

    name=JavaChen-dev
    

    application-prod.properties内容如下:

    name=JavaChen-prod
    

    接下来进行测试。spring.profiles.active=dev时,运行Application类,查看日志输出。

    2016-02-22 15:45:18,470 [main] INFO  com.javachen.example.Application - Hello JavaChen-dev
    

    spring.profiles.active=prod时,运行Application类,查看日志输出。

    2016-02-22 15:47:21,270 [main] INFO  com.javachen.example.Application - Hello JavaChen-prod
    

    logback配置多Profile

    在resources目录下添加logback-spring.xml,并分别对dev和prod进行配置:

    <?xml version="1.0" encoding="UTF-8"?>
    <configuration>
        <!--<include resource="org/springframework/boot/logging/logback/base.xml" />-->
    
        <springProfile name="dev">
            <logger name="com.javachen.example" level="TRACE" />
            <appender name="LOGFILE" class="ch.qos.logback.core.ConsoleAppender">
                <encoder>
                    <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
                </encoder>
            </appender>
        </springProfile>
    
        <springProfile name="prod">
            <appender name="LOGFILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
                <File>log/server.log</File>
                <rollingPolicy
                        class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                    <FileNamePattern>log/server_%d{yyyy-MM-dd}.log.zip</FileNamePattern>
                </rollingPolicy>
                <layout class="ch.qos.logback.classic.PatternLayout">
                    <pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern>
                </layout>
            </appender>
        </springProfile>
    
        <root level="info">
            <appender-ref ref="LOGFILE" />
        </root>
    
        <logger name="com.javachen.example" level="DEBUG" />
    </configuration>
    

    这样,就可以做到不同profile场景下的日志输出不一样。

    maven中的场景配置

    使用maven的resource filter可以实现多场景切换。

    <profiles>
        <profile>
            <id>prod</id>
            <activation>
                <activeByDefault>true</activeByDefault>
            </activation>
            <properties>
                <build.profile.id>prod</build.profile.id>
            </properties>
        </profile>
        <profile>
            <id>dev</id>
            <properties>
                <build.profile.id>dev</build.profile.id>
            </properties>
        </profile>
    </profiles>
    
    <build>
            <filters>
                <filter>application-${build.profile.id}.properties</filter>
            </filters>
    
            <resources>
                <resource>
                    <filtering>true</filtering>
                    <directory>src/main/resources</directory>
                </resource>
            </resources>
    </build> 
    

    这样在maven编译时,可以通过-P参数指定maven profile即可。

    总结

    使用Spring Boot的Profile注解可以实现多场景下的配置切换,方便开发中进行测试和部署生产环境。

    本文中相关代码在github上面。

  • 相关阅读:
    如何利用python制作微信好友头像照片墙?
    机器学习入门路线和资源
    突然“被辞职”的时候,原来可以拿到这么多钱!
    一个致命的 Redis 命令,导致公司损失 400 万
    程序员:想知道你每天按了多少次键盘吗?
    想了解真实的中国历史吗?建议看看这10部历史纪录片,受益终生!
    SpringBlade 2.0-RC3 发布,全新的微服务开发平台
    Syncd-开源自动化部署工具
    学习Spring Boot看这两个开源项目就够了!非得值得收藏的资源
    大型视频直播平台架构由浅入深详细讲解
  • 原文地址:https://www.cnblogs.com/exmyth/p/7151244.html
Copyright © 2011-2022 走看看