目录

创建一个spring boot 项目spring boot 中的配置体系配置文件与 Profile代码控制与Profile

创建一个spring boot 项目

基于 Spring Boot 创建 Web 应用程序的方法有很多,我们选择在idea中直接进行创建,服务器URL选择Spring Initializer 网站,类型选择Maven项目,java版本根据jdk版本进行选择。 然后添加相应依赖以及选择spring boot版本

接下来我们写一个Controller

@RestController

@RequestMapping("/user")

public class UserController {

// 请求映射,用于处理请求

@RequestMapping("/zcx")

public Userinfo getUserInfo() {

// 创建Userinfo对象

Userinfo userinfo = new Userinfo();

// 设置age属性

userinfo.setAge("45");

// 设置name属性

userinfo.setName("zcx-yyds");

// 返回Userinfo对象

return userinfo;

}

}

现在我们需要对这个应用程序进行打包,使用idea上的打包工具,点击package进行打包 我们将得到一个springboot1-0.0.1-SNAPSHOT.jar文件,而这个 jar 文件就是可以直接运行的可执行文件,内置了 Tomcat Web 服务器。我们直接使用如下命令进行运行这个Spring boot程序。

java -jar springboot1-0.0.1-SNAPSHOT.jar

然后我们使用postman来进行项目访问测试,得到如下返回结果,证明我们的程序服务已经启动成功了。

现在我们已经明白如何构建、打包以及运行一个简单的 Web 应用程序了。

spring boot 中的配置体系

在 Spring Boot 中,其核心设计理念是对配置信息的管理采用约定优于配置,也就是说约定大于配置。 Spring Boot中的Profile是一个非常有用的功能,它可以让我们在不修改代码的情况下,通过配置文件来控制程序的行为。 在Spring Boot中,Profile是一种用于控制应用程序行为的机制。通过使用不同的Profile,我们可以根据不同的环境或场景来加载不同的配置信息,从而实现应用程序的灵活配置。

配置文件与 Profile

根据环境的不同而存在很多套配置。假设我们存在如下所示的配置文件集合: 配置文件application-dev.properties中的代码为:

server.port=8080

spring.datasource.url=jdbc:mysql://localhost:3306/dev_db

spring.datasource.username=root

spring.datasource.password=666666

配置文件application-prod.properties中的代码为:

server.port=8080

spring.datasource.url=jdbc:mysql://localhost:3306/prod_db

spring.datasource.username=root

spring.datasource.password=666666

常见的配置文件命名方式有以下几种: /{application}-{profile}.properties /{label}/{application}-{profile}.properties

在 Spring Boot 中,我们可以在主 application.properties 中使用如下的配置方式来激活当前所使用的 Profile:

spring.profiles.active = dev

当然还有以下几种方式启动Profile:

在主 application.properties指定要激活的Profile。

spring.profiles.active = dev

在启动命令中指定Profile。

java -jar springboot1-0.0.1-SNAPSHOT.jar --spring.profiles.active=prod

在程序中显示设置Profile。例如:

@SpringBootApplication

public class Springboot1Application {

public static void main(String[] args) {

SpringApplication app = new SpringApplication(Springboot1Application.class);

app.setAdditionalProfiles("dev");

app.run(args);

}

}

这将激活名为prod的Profile。

代码控制与Profile

在 Spring Boot 中,Profile 这一概念的应用场景还包括动态控制代码执行流程。为此,我们需要使用 @Profile 注解,Profile注解可以用于指定某个类或方法在特定的配置环境下生效。只要是被@Component或@Configuration注解的类都可以使用@Profile注解。 使用一个示例来了解Profile注解的使用方法:

@Configuration

public class DataSourceConfig {

@Bean

@Profile("dev")

public DataSource devDataSource() {

//创建 dev 环境下的 DataSource

return null;

}

@Bean()

@Profile("prod")

public DataSource prodDataSource() {

//创建 prod 环境下的 DataSource

return null;

}

}

通过这种方式,可以达到与使用配置文件相同的效果。 我们来看一个更为详细具体的例子:

创建一个接口 MyService:

public interface MyService {

void doSomething();

}

创建两个不同的实现类,分别用于不同的配置文件。

@Component

@Profile("prod")

public class ProdMyService implements MyService {

@Override

public void doSomething() {

System.out.println("Prod service is running.");

}

}

@Component

@Profile("dev")

public class DevMyService implements MyService {

@Override

public void doSomething() {

System.out.println("Dev service is running.");

}

}

上述示例中,我们创建了两个不同的实现类,一个用于 development 配置文件,另一个用于 production 配置文件。@Profile 注解分别标记了它们,以便 Spring 知道在哪个配置文件下激活它们。 3. 在 Spring 配置文件(例如 application.properties 或 application.yml)中指定要激活的配置文件,例如: application.properties:

spring.profiles.active=prod

将 spring.profiles.active 设置为 development,表示我们希望激活的开发配置文件。 4. 创建一个启动类,以演示如何使用 MyService:

@SpringBootApplication

public class Springboot1Application implements CommandLineRunner {

// 声明一个注入的MyService对象

@Autowired

private MyService myService;

// 声明一个名为run的方法,用来启动Spring应用

public static void main(String[] args) {

// 调用SpringApplication的run方法,传入Springboot1Application类和args参数

SpringApplication.run(Springboot1Application.class, args);

}

// 方法run,用来执行Spring应用的业务逻辑

@Override

public void run(String... args) {

// 调用myService的doSomething方法

myService.doSomething();

}

}

通过结果我们发现运行这个应用程序时,它会根据配置文件中的 spring.profiles.active 属性来选择相应的实现类。 如果你还想了解更多内容请参考spring boot官网。

推荐文章

评论可见,请评论后查看内容,谢谢!!!
 您阅读本篇文章共花了: