Spring Boot探路者之helloworld

Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。
简单的说将java的各大流行框架通过页面配置整合起来,省去了项目初建花费大量时间去组装调试的过程,从而简化了项目框架搭建流程。内置了tomcat,jetty等容器,无需再通过tomcat部署war包的方式部署项目。目前在微服务架构中应用很广泛。
下面就简单介绍下使用流程:

1.配置下载项目

访问网站http://start.spring.io/,根据自己的情况选择maven或gradle和spring boot版本
点击“Switch to the full version”配置自己项目说明
这里写图片描述
在创建项目的下方可以根据自己的需求选择合适框架依赖。
选择好后点击“Generate Project”下载项目工程。
也可以通过安装ide插件支持,如eclipse安装spring tools tips,新建spring starter project项目

2.项目结构

和maven项目一样这里就不多少了,有一个*Application类的主程序,运行即可启动程序。

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

3.编写demo代码

1.Controller编写

@RestController
@RequestMapping("/user")
public class UserController {
    @Autowired
    private UserServie userServie;

    @RequestMapping(value="/sayHello/{id}",method = RequestMethod.GET)
    public String sayHello(@PathVariable Long id){
        return userServie.sayHello(id);
    }
    @RequestMapping(value="",method = RequestMethod.POST)
    public Long save(@RequestBody User user){
        return userServie.addUser(user);
    }

    @RequestMapping(value="/list",method = RequestMethod.GET)
    public List<User> list(){
        return userServie.findList();
    }
}

spring boot默认的包扫描是从Application同级包路径自上而下扫描注入。
2.单元测试
使用RestTemplate进行Controller接口测试,
添加测试包依赖

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
@RunWith(SpringRunner.class)
@SpringBootTest(webEnvironment = WebEnvironment.RANDOM_PORT)
public class HelloworldApplicationTests {
    @Autowired
    private TestRestTemplate restTemplate;
    @Test
    public void testSayHello() throws Exception {
        HttpHeaders requestHeaders = new HttpHeaders();
        requestHeaders.setContentType(MediaType.APPLICATION_JSON);
        requestHeaders.setAccept(Collections.singletonList(MediaType.APPLICATION_JSON));
        User user = new User();
        user.setAge(30);
        user.setBirthday(new Date());
        user.setName("tom");
        HttpEntity<User> request = new HttpEntity<User>(user, requestHeaders);
        Long id = restTemplate.postForObject("/user", request, Long.class);
        Assert.assertEquals(restTemplate.getForEntity("/user/sayHello/{id}", String.class,  id).getBody(), "hello tom");;
    }

    @Test
    public void testSayHelloNoFound() throws Exception {
        Assert.assertEquals(restTemplate.getForEntity("/user/sayHello/{id}", String.class,  -1).getBody(), "not found");;
    }

    @Test
    public void testsave() throws Exception {
        HttpHeaders requestHeaders = new HttpHeaders();
        requestHeaders.setContentType(MediaType.APPLICATION_JSON);
        requestHeaders.setAccept(Collections.singletonList(MediaType.APPLICATION_JSON));
        User user = new User();
        user.setAge(30);
        user.setBirthday(new Date());
        user.setName("jetty");
        HttpEntity<User> request = new HttpEntity<User>(user, requestHeaders);
        Assert.assertNotNull(restTemplate.postForEntity("/user", request, Long.class).getBody());
    }

    @Test
    public void testList() throws Exception {
        Assert.assertTrue(restTemplate.getForEntity("/user/list", List.class).getBody().size() > 0);
    }
}

TestRestTemplate是对RestTemplate进行了包装.
3.server启动配置
1)配置文件配置,如:application.properties

server.port=8000
server.context-path=/helloworld

可以安装spring tools tips插件,配置参数可以提示
这里写图片描述
2)实现接口EmbeddedServletContainerCustomizer

@Override
    public void customize(ConfigurableEmbeddedServletContainer container) {
        container.setPort(8000);
        container.setContextPath("/helloworld");
    }

3)命令行启动参数配置
java -jar -Dserver.port=8000 helloworld.jar

4.部署方式

1.集成tomcat或jetty通过命令启动
spring boot默认集成了tomcat,如果使用jetty修改pom,排除tomcat依赖,增加jetty依赖

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-tomcat</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jetty</artifactId>
        </dependency>

在使用maven打成jar使用java命令启动
2.部署到JavaEE容器
1)改启动类,继承 SpringBootServletInitializer 并重写 configure 方法

public class HelloworldApplication extends SpringBootServletInitializer{

    private static final Logger logger = LoggerFactory.getLogger(SpringBootSampleApplication.class);

    @Override
    protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
        return builder.sources(this.getClass());
    }

}

修改pom文件中jar 为 war

<packaging>war</packaging>

修改pom,排除tomcat插件,同上。打包部署到容器启动即可。

5.开发调试

springBoot对调试支持很好,使用热启动,修改之后可以实时生效,需要修改以下的配置:

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <optional>true</optional>
        </dependency>
...
<plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <fork>true</fork>
                </configuration>
            </plugin>
        </plugins>

该模块在完整的打包环境下运行的时候会被禁用。

6.使用Linux服务的方式启动、停止、重启

1.首先在 pom.xml 中配置插件

 <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <executable>true</executable>
                </configuration>
            </plugin>
        </plugins>
    </build>

2.上传jar包到服务器,假设部署路径为 /var/apps/myapp.jar ,使用命令做一个软连接到 /etc/init.d 目录,命令:
ln -s /var/apps/myapp.jar /etc/init.d/myapp
3.给jar文件授予可执行权限,命令:
chmod +x myapp.jar
4.我们可以使用service myapp start|stop|restart 来对应用进行启停了
执行命令后将得到形如 Started|Stopped [PID] 的结果反馈。
默认PID文件路径:/var/run/appname/appname.pid
默认日志文件路径:/var/log/appname.log

5.使用自定义的.conf文件来变更默认配置,方法如下:
在jar包相同路径下创建一个.conf文件,名称应该与.jar的名称相同,如myapp.conf,其内容配置可以如下:

JAVA_HOME=/usr/local/jdk
JAVA_OPTS=-Xmx1024M
LOG_FOLDER=/data/logs/myapp

实例源码:https://github.com/slimina/springboot-study

猜你喜欢

转载自blog.csdn.net/tianwei7518/article/details/69486910