spring boot概念
【微服務系列】Spring SpringMVC SpringBoot SpringCloud概念、關系及區別
“越來越多的企業選擇使用spring boot 開發系統,spring boot牛在什么地方?難不難學?心動不如行動,讓我們一起開始學習吧!”
使用Spring boot ,可以輕松的創建獨立運行的程序,非常容易構建獨立的服務組件,是實現分布式架構、微服務架構利器。Spring boot簡化了第三方包的引用,通過提供的starter,簡化了依賴包的配置。
Spring boot的優點
- 輕松創建獨立的Spring應用程序。
- 內嵌Tomcat、jetty等web容器,不需要部署WAR文件。
- 提供一系列的“starter” 來簡化的Maven配置。
- 開箱即用,盡可能自動配置Spring。
spring boot 快速入門
通過構建簡單的REST應用,了解spring boot的開發基本流程,驗證其簡單、易用特性。
環境要求
Spring Boot 2.0.0.BUILD-SNAPSHOT 要求 Java 8 和 Spring Framework 5.0.2以上,Maven 3.2 以上或者Gradle 4。
本文使用 Spring Boot 1.5.9 、 Java8 和 Spring Framework 5.0.2.RELEASE以上,Maven 3.2。開發工具使用sping官方提供的spring suit tool 3.9.1(STS)。
1.File - New - Module
2.選項的是Spring Initializr(官方的構建插件,需要聯網) ,一定要選擇jdk
3.填寫項目基本信息
-
Group:
組織ID,一般分為多個段,這里我只說兩段,第一段為域,第二段為公司名稱。域又分為org、com、cn
等等,其中org為非營利組織,com為商業組織
。如阿里、淘寶(com.alibaba/com.taobao) -
Artifact:
唯一標識符,一般是項目名稱
4.選擇包
Spring Initializr
為我們提供了很多的選項,不同的選項有不同的作用,在初期我們只需要依賴Web -> Web
就可以了,選擇好依賴包之后點擊Next
->Finish
5.輸入項目名
6.目錄結構如下
- src
-main
-java
-package
#主函數,啟動類,運行它如果運行了 Tomcat、Jetty、Undertow 等容器
-SpringbootApplication
-resouces
#存放靜態資源 js/css/images 等
- statics
#存放 html 模板文件
- templates
#主要的配置文件,SpringBoot啟動時候會自動加載application.yml/application.properties
- application.yml
#測試文件存放目錄
-test
# pom.xml 文件是Maven構建的基礎,里面包含了我們所依賴JAR和Plugin的信息
- pom
7.pom.xml 文件的 依賴
因為使用了Spring Initializr插件,所以如下的配置都不需要我們自己去寫啦,需要注意的是版本要選擇RELEASE,穩定版本BUG少
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>cn.kgc</groupId>
<artifactId>springboot1</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>springboot1</name>
<description>我用的第一個maven工程</description>
<!--版本采用的是最新的 2.0.1.RELEASE
TODO 開發中請記得版本一定要選擇 RELEASE ,因為是穩定版本且BUG少-->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.5.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<!-- 默認就內嵌了Tomcat 容器,如需要更換容器也極其簡單-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- 測試包,當我們使用 mvn package 的時候該包并不會被打入,因為它的生命周期只在 test 之內-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<!-- 編譯插件 -->
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
8.主函數入口
注意事項:一個項目中切記不要出現多個main函數,否在在打包的時候spring-boot-maven-plugin將找不到主函數(主動指定打包主函數入口除外…)
package cn.kgc;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
/*我的第一個springboot程序
其中 @RestController 等同于 (@Controller 與 @ResponseBody)*/
@RestController
@SpringBootApplication
public class Springboot1Application {
public static void main(String[] args) {
SpringApplication.run(Springboot1Application.class, args);
}
@GetMapping("/demo1")
public String demo1(){
return "Hello World!";
}
}
9.初窺配置文件
從啟動日志中可以發現,SpringBoot默認的端口是 8080 ,那么如果端口被占用了怎么辦呢?不要慌,問題不大,配置文件分分鐘解決你的困擾…
修改application.properties屬性文件
# 默認的 8080 我們將它改成 9090
server.port=9090
# 未定義上下文路徑之前 地址是 http://localhost:8080 定義了后 http://localhost:9090 你能在tomcat做的事情,配置文件都可以
server.servlet.context-path=/springboot1
10.啟動項目,查看控制臺輸出
SpringBoot啟動的時候我們可以看到控制臺如下內容,可以在在resouces目錄下添加指定命名的的文件類型有.txt、.jpg、.gif、.jpeg等等
本文原創作者:唐亞峰
本文原創鏈接:http://blog.battcn.com/2018/04/22/springboot/v2-config-properties/
版權聲明:本博客所有文章除特別聲明外,均采用CC BY-NC-SA 3.0許可協議。轉載請注明出處!