代码编织梦想

0. 需求

        通常项目开发过程中,会经历多种环境转换,典型的如开发环境(dev)、测试环境(test)和生产环境(prod)。在这三种不同的环境下,连接数据库时使用的配置信息是不同的,即三个不同环境对应三个不同的数据库。

        现在的需求是:当在不同的环境下,想通过修改配置文件来连接不同的数据库。比如在开发过程中启动项目时,想连接开发环境对应的数据库,可以在配置文件中指定 environment = dev。其他环境类似,此时就需要用到Spring为我们提供的Profile功能。

1. 采用一个配置文件的情况

        当SpringBoot项目只使用一个配置文件(application.yml或application.properties)时,如果想在这个配置文件中通过配置切换不同数据源,可以按照如下步骤:

1.1. 数据源类

package com.shg.spring.ioc.bean;

import lombok.Data;

@Data
public class MyDataSource {
    
    private String username;

    private String password;

    private String url;
    private String driver;
    
}

1.2. 数据源配置类

package com.shg.spring.ioc.config;

import com.shg.spring.ioc.bean.MyDataSource;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Profile;

@Configuration
public class MyDataSourceConfig {

    @Value("${jdbc.user.dev}")
    private String usernameForDev;
    @Value("${jdbc.password.dev}")
    private String passwordForDev;
    @Value("${jdbc.jdbcUrl.dev}")
    private String urlForDev;
    @Value("${jdbc.driverClass.dev}")
    private String driverForDev;

    @Value("${jdbc.user.test}")
    private String usernameForTest;
    @Value("${jdbc.password.test}")
    private String passwordForTest;
    @Value("${jdbc.jdbcUrl.test}")
    private String urlForTest;
    @Value("${jdbc.driverClass.test}")
    private String driverForTest;

    @Value("${jdbc.user.prod}")
    private String usernameForProd;
    @Value("${jdbc.password.pro}")
    private String passwordForProd;
    @Value("${jdbc.jdbcUrl.pro}")
    private String urlForProd;
    @Value("${jdbc.driverClass.pro}")
    private String driverForProd;

    @Profile(value = {"default", "dev"})
    @Bean
    public MyDataSource dev() {
        MyDataSource myDataSource = new MyDataSource();
        myDataSource.setDriver(driverForDev);
        myDataSource.setUrl(urlForDev);
        myDataSource.setUsername(usernameForDev);
        myDataSource.setPassword(passwordForDev);
        return myDataSource;
    }

    @Profile(value = {"test"})
    @Bean
    public MyDataSource test() {
        MyDataSource myDataSource = new MyDataSource();
        myDataSource.setDriver(driverForTest);
        myDataSource.setUrl(urlForTest);
        myDataSource.setUsername(usernameForTest);
        myDataSource.setPassword(passwordForTest);
        return myDataSource;
    }

    @Profile(value = {"prod"})
    @Bean
    public MyDataSource prod() {
        MyDataSource myDataSource = new MyDataSource();
        myDataSource.setDriver(driverForProd);
        myDataSource.setUrl(urlForProd);
        myDataSource.setUsername(usernameForProd);
        myDataSource.setPassword(passwordForProd);
        return myDataSource;
    }
}

1.3 DAO层用到数据源

package com.shg.spring.ioc.dao;

import com.shg.spring.ioc.bean.MyDataSource;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;

@Repository
public class HelloDao {

    // DAO层需要注入数据源
    @Autowired
    private MyDataSource myDataSource;

    // 保存发货信息
    public void saveDelivery() {
        System.out.println("保存发货信息...用的数据源信息是:" + myDataSource);
    }

}

1.4. 配置文件

spring.application.name=spring-01-ioc

spring.profiles.active=dev

jdbc.jdbcUrl.dev=jdbc:mysql://localhost:3306/dev
jdbc.driverClass.dev=com.mysql.jdbc.Driver
jdbc.user.dev=root
jdbc.password.dev=123

jdbc.jdbcUrl.test=jdbc:mysql://localhost:3306/test
jdbc.driverClass.test=com.mysql.jdbc.Driver
jdbc.user.test=root
jdbc.password.test=123

jdbc.jdbcUrl.prod=jdbc:mysql://localhost:3306/prod
jdbc.driverClass.prod=com.mysql.jdbc.Driver
jdbc.user.prod=root
jdbc.password.prod=123

1.5. 测试代码

package com.shg.spring.ioc;

import com.shg.spring.ioc.dao.HelloDao;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext;

@SpringBootApplication
public class Spring01IocApplication {

    public static void main(String[] args) {
        ConfigurableApplicationContext ioc = SpringApplication.run(Spring01IocApplication.class, args);
        HelloDao helloDao = ioc.getBean(HelloDao.class);
        helloDao.saveDelivery();
    }
    
}

 1.6. 测试结果

 1.6.1 配置文件中的spring.profiles=dev

1.6.2 配置文件中的spring.profiles=test

1.6.3 配置文件中的spring.profiles=prod

 2. 采用多个配置文件的情况

         上面的例子中,只使用一个配置文件。需要在这个配置文件中配置三种环境的配置信息,感觉不太好...

        【你也可能会反驳说,我直接使用一组配置信息,不分什么dev,test和prod环境,在配置类中也不用标注@Profile注解,而是在部署对应环境的时候,修改这个数据源的配置信息,这当然也是可以的,但是不要忘了我们现在是在讨论 Profile这个功能,这样举例子会更加清楚明了】

        下面我们采用另一种方式,来实现我们的需求,即:在不同的环境下,可以直接通过修改配置文件来连接不同的数据库。

2.1 . 三个环境对应的配置文件

2.1.1 dev环境的配置信息

2.1.2 test环境的配置信息

 2.1.3 prod环境的配置信息

2.2. 数据源类

package com.shg.spring.ioc.bean;

import lombok.Data;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

@Data
@Component
public class MyDataSource {

    @Value("${jdbc.user}")
    private String usernameForDev;
    
    @Value("${jdbc.password}")
    private String passwordForDev;
    
    @Value("${jdbc.jdbcUrl}")
    private String urlForDev;
    
    @Value("${jdbc.driverClass}")
    private String driverForDev;
    
}

2.3. DAO层需要用到数据源

package com.shg.spring.ioc.dao;

import com.shg.spring.ioc.bean.MyDataSource;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;

@Repository
public class HelloDao {

    // DAO层需要注入数据源
    @Autowired
    private MyDataSource myDataSource;

    // 保存发货信息
    public void saveDelivery() {
        System.out.println("保存发货信息...用的数据源信息是:" + myDataSource);
    }

}

2.4. 在主配置文件中开启需要使用哪个环境的配置文件

2.4.1. 开启dev

测试结果:

2.4.2. 开启test

测试结果:

2.4.3. 开启prod

测试结果:

3. 使用建议

        在实际项目中,推荐在不同环境使用不同的配置文件。 

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_23388169/article/details/142648487

springboot学习(五):springboot之profile详解_花伦同学ko的博客-爱代码爱编程_profile springboot

在使用springboot中,application.properties和application.yml这两个是默认的配置文件,有时我们想使用指定的配置文件,那么就需要什么Profile。 我们在编写指定的配置文件时,文件名可以是: application-{profile}.properties/yml 一:properties格式: 我们创建了

springboot——profile多环境运行_逐墨飞扬的博客-爱代码爱编程

Profile的应用场景 假如有开发、测试、生产三个不同的环境,需要定义三个不同环境下的配置。 SpringBoot有三种方式支持profile 方式一: 基于properties文件类型,在文件名称中添加profile

SpringBoot之profile详解-爱代码爱编程

SpringBoot中使用配置文件application.properties&application.yml两种方式,在这两种方式下分别对应各自的profile配置方式,同时还存在命令行、虚拟机、Program arguments三种方式分别访问指定profile: 1、application.properties   创建配置文件applic

SpringBoot中profile的使用与切换-爱代码爱编程

一、profile是什么 其实,早在Spring3.1版本时,profile已经出来了。所以,我需要知道的是profile是什么为什么使用它并且知道如何使用它。profile 可以让 Spring 对不同的环境提供不同配置的功能,可以通过激活、指定参数等方式快速切换环境。 换句话说,就是我们需要在不同的场景下使用不同的配置,profile的出现就是要解决

springboot自学之路-02(创建springboot项目的三种方式)-爱代码爱编程

新手入门,讲解一下创建springboot项目的三种方式。 目录 方式一:通过idea自带的spring initlalizr创建 方式二:通过https://start.spring.io/初始化创建(需联网) 方式三:自行创建 方式一:通过idea自带的spring initlalizr创建 打开idea,file->new->

SpringBoot中的两种配置文件-爱代码爱编程

SpringBoot中的配置文件 一、application.properties二、application.yml1、yaml基础语法2、yaml支持的三种数据结构:三、配置文件值注入(1)@Value(2)@ConfigurationProperties将属性注入到实体类中(3)@Value和@ConfigurationProperties的区

SpringBoot(快速使用Spring的方式)-爱代码爱编程

1. SpringBoot概述 SpringBoot概念 SpringBoot提供了一种快速使用Spring的方式,基于约定优于配置的思想,可以让开发人员不必在配置与逻辑业务之间进行思维的切换,全身心的投入到逻辑业务的代码编写中,从而大大提高了开发的效率SpringBoot功能 自动配置 Spring Boot的自动配置是一个运行时

springboot配置profile-爱代码爱编程

-dev :开发环境 端口设置8081 -pro :生产环境 端口设置8082 -test:测试环境 端口设置8083 然后直接运行 显示没有激活配置文件,这不是错误 我们可以通过主配置文件中的profile属性指定对不同环境的配置文件进行激活 spring.profiles.active用来激活指定的配置文件的

springboot激活profiles的几种方式-爱代码爱编程

多环境是最常见的配置隔离方式之一,可以根据不同的运行环境提供不同的配置信息来应对不同的业务场景,在SpringBoot内支持了多种配置隔离的方式,可以激活单个或者多个配置文件。 激活的profiles要在项目内创建对应的配置文件,格式为application-{profile}.yml。 一、命令行方式 命令一:运行时指定,使用--spring.

springboot配置-爱代码爱编程

8-SpringBoot配置-profile SpringBoot配置-profile 1. profile是用来完成不同环境下,配置动态切换功能的。 我们在开发Spring Boot 应用时,通常同一套程序会被安装到不同环境,例如:开发、测试、生产等。其中数据库地址、服务器端口等等配置都不同,如果每次打包时,都要修改配置文件,那么非常麻烦。prof

springboot中的profile的使用_profile中定义的properties plugin中能用吗-爱代码爱编程

SpringBoot中的profile的使用 简介:本文通过案例讲解SpringBoot中的profile的使用。 概述 profile是用来完成不同环境下的,配置的动态切换功能的。 配置方式 properties

在线订餐革命:spring boot 点餐系统-爱代码爱编程

第二章关键技术的研究 2.1相关技术 网上点餐系统是在Java + MySQL开发环境的基础上开发的。Java是一种服务器端脚本语言,易于学习,实用且面向用户。全球超过35%的Java驱动的互联网站点使用Java。MySQL

spring boot房屋租赁平台:现代化解决方案-爱代码爱编程

1 绪论 1.1 研究背景 中国的科技的不断进步,计算机发展也慢慢的越来越成熟,人们对计算机也是越来越更加的依赖,科研、教育慢慢用于计算机进行管理。从第一台计算机的产生,到现在计算机已经发展到我们无法想象。给我们的生活改变很

spring boot 进阶-爱代码爱编程

  在上篇文章中,我们创建了一个RESTFul风格的接口项目,并且分析了它的相关依赖,这里我们就来看一下这个项目还有什么值得我们分析的地方。前面提到的,在SpringBoot的场景启动器中,我们提供了一些自动配置的功能,那

java项目实战ii基于java+spring boot+mysql的免税商品优选购物商城(源码+数据库+文档)-爱代码爱编程

目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发,CSDN平台Java领域新星创作者 一、前言 随着全球贸易的日益繁荣和消费者需求的多样化,免税商品购物已成为众多旅行者和消费者的热门选择。为了提供一个更加便捷、高效且优质的免税商品购物体验,我们精心打造了一款基