Spring Boot的简单使用(二)

Spring Boot的优点

回顾一下我们如何搭建一个SSM(Spring,Spring MVC,MyBatis)web框架,配置web.xml,将权限交给Spring,设置Spring容器的配置文件application.properties,开启自动扫包、配置数据库文件、引用数据源、文件资源过滤等等一系统繁琐的操作之后,我们才能够搭建起来一个框架,光是配置就得耗费我们大把的时间。但是,使用Spring Boot就可以让我们从繁琐的配置工作中解脱出来,将主要的精力集中到编码上。

启动一个简单的Spring Boot

参照Spring Boot快速开始文档,我们先在MyEclipse里面创建一个简单java的maven项目。

New Project,选择Maven Project


勾选创建简单工程,点击Next


填写Group Id和Artifict Id,点击Finish


打开pom文件,按照官网提供的启动方式,引入Spring Boot依赖

    <!-- Add typical dependencies for a web application -->
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <version>1.5.7.RELEASE</version>
        </dependency>
    </dependencies>

在项目src/main/java的目录下,新建一个包com.init.springCloud,再创建一个我们的Spring Boot启动类FirstApplication,为这个启动类添加一个main()方法

package com.init.springCloud;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class FirstApplication {

	public static void main(String[] args) {
		SpringApplication.run(FirstApplication.class, args);
	}

}

使用@SpringBootApplication注解标明我们的项目是一个Spring Boot项目,@SpringBootApplication注解是一个整合了多个注解的集合注解,能够完成以前我们需要在配置文件中配置的自动扫包等等的功能。


完成上面启动类的创建,我们的第一个Spring Boot项目也完成了,这个时候,运行main()方法,启动我们的Spring Boot,控制台会输出如图的信息

在控制台我们看到项目的端口是8080,访问一下http://localhost:8080,出现以下页面,我们的项目就算是搭建成功了


补充:Spring Boot是采用内部插件的方式启动项目的,所以这里没有项目名称

Spring Boot的控制器

在com.init.springCloud包下新建class类MyController,为Controller类添加@Controller注解,为方法添加@GetMapping和@ResponseBody注解

package com.init.springCloud;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.ResponseBody;

@Controller
public class MyController {

	@GetMapping("/hello")
	@ResponseBody
	public String hello(){
		return "hello";
	}
	
}

之后运行FirstApplication启动类的main()方法,启动项目,访问http://localhost:8080/hello,在浏览器返回了我们的“hello字符串”,Spring Boot的Controller控制器也就测试通过了。


Spring Boot的Rest风格控制器

我们演示让Rest风格的控制器返回一个Person类的JsonString,先在com.init.springCloud包下新建class类Person,这里使用了lombok的解决方案,按步骤操作的同学根据自己实际情况改写Person类

package com.init.springCloud;
import lombok.Data;
@Data
public class Person {
	private Integer id;		//主键ID
	private String name;		//姓名
	private Integer age;		//年龄	
}

之后继续在com.init.springCloud包下创建class类MyRestController,使用@RestController标识这是一个Rest风格的控制器,在方法上使用@RequestMapping注解,value属性代表请求路径和参数,method用GET的方式请求(按照Rest风格,查询数据使用的是GET方式),produces表示我们产出的是一个JSON字符串。

package com.init.springCloud;

import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class MyRestController {
	@RequestMapping(value = "/person/{id}", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
	public Person getPerson(@PathVariable Integer id){
		Person person = new Person();
		person.setId(id);
		person.setName("Spirit");
		person.setAge(22);
		return person;
	}
}

配置完毕以后,运行FirstApplication启动类的main()方法,启动项目,访问http://localhost:8080/person/1,在浏览器端看到了我们的JSON数据,Rest风格的控制器也测试通过了。


Spring boot配置

Spring Boot会默认读取application.properties或者application.yml(yaml语言,这里不细讲了,有需要的同学可自行查阅资料),读取配置文件的先后顺序或者说优先级分别是:

A:根目录的config文件夹下的application.properties
B:根目录下的application.properties
C:src/main/resources目录的config文件夹下的application.properties
D:src/main/resources目录下的application.properties


如果同时配置了多个application.properties,配置文件里又同时存在相同的某个属性,但是属性值不一样,后面读取的配置文件属性值不会覆盖前一个文件的属性值!

使用自定义的配置文件启动Spring Boot项目

我们在src/main/resources下面新建一个名为myapp.properties的file,在这个配置文件里面写上自己的一个配置属性

test.user.name = Spirit

为了查看这个是否读取到我们的属性值,我们在com.init.springCloud包下创建class类MyConfigController,用于在浏览器端请求并展示这个属性值

package com.init.springCloud;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.ResponseBody;

@Controller
public class MyConfigController {
	
	@Autowired
	private ApplicationContext ctx;
	
	@GetMapping("/prop")
	@ResponseBody
	public String getName(){
		return ctx.getEnvironment().getProperty("test.user.name");
	}
	
}

最后在com.init.springCloud包下创建class类MyConfigApplication作为我们自定义的启动类,内容如下:

package com.init.springCloud;

import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;

@SpringBootApplication
public class MyConfigApplication {

	public static void main(String[] args) {
		new SpringApplicationBuilder(MyConfigApplication.class).properties("spring.config.location=classpath:/myapp.properties").run(args);
	}
	
}

运行MyConfigApplication的main()方法,启动Spring Boot,访问http://localhost:8080/prop,在浏览器端看到我们的请求结果,自定义配置类以及自定义的启动方式就生效了。


多环境下配置文件的切换

按照传统的部署方式,我们通常是把本地的war包或者class字节码文件里面需要修改的文件或者配置等等的一系列信息修改了以后,再放到生产环境或者拿给测试人员做测试。配置文件的大量修改,造成了不必要的工作量,而且繁多的配置容易导致修改的时候出错,Spring Boot恰好提供了那么一种多环境下配置文件切换的方式,可以让我们做最小的修改就能完成生产线的切换,比如从开发状态切换到测试状态,或者切换到产品状态。

我们在src/main/resources目录下新建三个配置文件,分别是application-dev.properties、application-test.properties、application-prod.properties

然后在三个配置文件里面分别写上自定义的属性:

test.user.name = Spirit in dev
test.user.name = Spirit in test
test.user.name = Spirit in prod

之后在src/main/resources目录下的application.properties文件里配置激活对应的配置文件

spring.profiles.active = dev

运行FirstApplication类的main()方法,访问http://localhost:8080/prop,在浏览器端可以看到我们的请求结果,对应环境的配置就被激活了。


结合多环境的配置文件,我们也可以在代码中指定运行环境,不同作用的代码在相应的运行环境下起作用。在com.init.springCloud包下创建class类BeanConfiguration,并用@Configuration注解标知类,用@Bean和@profile标知一个初始化运行的方法,@Profile写明运行时环境,我们就能在项目启动运行时看到方法内部打印出来的信息。注:方法内部使用了Java8的lambda表达式。

package com.init.springCloud;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Profile;

@Configuration
public class BeanConfiguration {
    @Bean
    @Profile("dev")
    public Runnable test1() {
        System.out.println("开发环境使用的 Bean");
        return () -> {};
    }
    
    @Bean
    @Profile("test")
    public Runnable test2() {
        System.out.println("测试环境使用的 Bean");
        return () -> {};
    }
    
    @Bean
    @Profile("prod")
    public Runnable test3() {
        System.out.println("生产环境使用的 Bean");
        return () -> {};
    }
    
}

之后运行FirstApplication类的main()方法,我们注意到控制台输出的信息里面打印出了对应环境的语句。


动态热部署

Spring Boot为我们提供了动态热部署,能然我们实时更新了代码之后自行重新启动项目。在Spring Boot官网文档里面搜索devtools,找到下面提供的maven依赖,拷入到自己的pom文件里面。

为了各位方便操作,我把依赖粘贴出来:

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <optional>true</optional>
    </dependency>
</dependencies>

保存并重启我们的项目,这个时候代码如果做了修改,项目就会自动重新启动,编译部署。

源码点击这里

Spring Cloud系列:

Spring Cloud介绍与环境搭建(一)

Spring Boot的简单使用(二)

Spring Cloud服务管理框架Eureka简单示例(三)

Spring Cloud服务管理框架Eureka项目集群(四)

Spring Cloud之Eureka客户端健康检测(五)

Netflix之第一个Ribbon程序(六)

Ribbon负载均衡器详细介绍(七)

Spring Cloud中使用Ribbon(八)

具有负载均衡功能的RestTemplate底层原理(九)

OpenFeign之第一个Feign程序(十)

OpenFeign之feign使用简介(十一)

Spring Cloud中使用Feign(十二)

Netflix之第一个Hystrix程序(十三)

Netflix之Hystrix详细分析(十四)

Spring Cloud中使用Hystrix(十五)

Netflix之第一个Zuul程序(十六)

Spring Cloud集群中使用Zuul(十七)

Netflix之Zuul的进阶应用(十八)

消息驱动之背景概述(十九)

消息中间件之RabbitMQ入门讲解(二十)

消息中间件之Kafka入门讲解(二十一)

Spring Cloud整合RabbitMQ或Kafka消息驱动(二十二)

阅读更多
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/MrSpirit/article/details/79975963
个人分类: Spring Cloud
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭
关闭