Spring Cloud Spring Boot mybatis分散式微服務雲架構(一)快速入門
快速入門
本章主要目標完成Spring Boot基礎專案的構建,並且實現一個簡單的Http請求處理,通過這個例子對Spring Boot有一個初步的瞭解,並體驗其結構簡單、開發快速的特性。
系統要求:
- Java 7及以上
- Spring Framework 4.1.5及以上
本文采用Java 1.8.0_73
、Spring Boot 1.3.2
除錯通過。
使用Maven構建專案
- 通過
SPRING INITIALIZR
工具產生基礎專案 - 解壓專案包,並用IDE以
Maven
專案匯入,以IntelliJ IDEA 14
為例:- 選單中選擇
File
–>New
–>Project from Existing Sources...
- 選擇解壓後的專案資料夾,點選
OK
- 點選
Import project from external model
並選擇Maven
,點選Next
到底為止。 - 若你的環境有多個版本的JDK,注意到選擇
Java SDK
的時候請選擇Java 7
以上的版本
- 選單中選擇
專案結構解析
通過上面步驟完成了基礎專案的建立,如上圖所示,Spring Boot的基礎結構共三個檔案(具體路徑根據使用者生成專案時填寫的Group所有差異):
src/main/java
下的程式入口:Chapter1Application
src/main/resources
下的配置檔案:application.properties
src/test/
下的測試入口:Chapter1ApplicationTests
生成的Chapter1Application
和Chapter1ApplicationTests
類都可以直接執行來啟動當前建立的專案,由於目前該專案未配合任何資料訪問或Web模組,程式會在載入完Spring之後結束執行。
引入Web模組
當前的pom.xml
內容如下,僅引入了兩個模組:
spring-boot-starter
:核心模組,包括自動配置支援、日誌和YAMLspring-boot-starter-test
:測試模組,包括JUnit、Hamcrest、Mockito<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies>
引入Web模組,需新增
spring-boot-starter-web
模組:<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency>
編寫HelloWorld服務
- 建立
package
命名為com.didispace.web
(根據實際情況修改) - 建立
HelloController
類,內容如下@RestController public class HelloController { @RequestMapping("/hello") public String index() { return "Hello World"; } }
- 啟動主程式,開啟瀏覽器訪問
http://localhost:8080/hello
,可以看到頁面輸出Hello World
編寫單元測試用例
開啟的
src/test/
下的測試入口Chapter1ApplicationTests
類。下面編寫一個簡單的單元測試來模擬http請求,具體如下:@RunWith(SpringJUnit4ClassRunner.class) @SpringApplicationConfiguration(classes = MockServletContext.class) @WebAppConfiguration public class Chapter1ApplicationTests { private MockMvc mvc; @Before public void setUp() throws Exception { mvc = MockMvcBuilders.standaloneSetup(new HelloController()).build(); } @Test public void getHello() throws Exception { mvc.perform(MockMvcRequestBuilders.get("/hello").accept(MediaType.APPLICATION_JSON)) .andExpect(status().isOk()) .andExpect(content().string(equalTo("Hello World"))); } }
使用
MockServletContext
來構建一個空的WebApplicationContext
,這樣我們建立的HelloController
就可以在@Before
函式中建立並傳遞到MockMvcBuilders.standaloneSetup()
函式中。- 注意引入下面內容,讓
status
、content
、equalTo
函式可用import static org.hamcrest.Matchers.equalTo; import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content; import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
至此已完成目標,通過Maven構建了一個空白Spring Boot專案,再通過引入web模組實現了一個簡單的請求處理。
相關推薦
Spring Cloud Spring Boot mybatis分散式微服務雲架構(一)快速入門
快速入門本章主要目標完成Spring Boot基礎專案的構建,並且實現一個簡單的Http請求處理,通過這個例子對Spring Boot有一個初步的瞭解,並體驗其結構簡單、開發快速的特性。系統要求:Java 7及以上Spring Framework 4.1.5及以上本文采用Ja
Spring Cloud Spring Boot mybatis分布式微服務雲架構(一)快速入門
springboot springcloud mybatis eureka config 快速入門本章主要目標完成Spring Boot基礎項目的構建,並且實現一個簡單的Http請求處理,通過這個例子對Spring Boot有一個初步的了解,並體驗其結構簡單、開發快速的特性。 系統要求:J
springcloud Spring Boot mybatis分散式微服務雲架構(六):配置中心
下面針對該Controller編寫測試用例驗證正確性,具體如下。當然也可以通過瀏覽器外掛等進行請求提交驗證。 @RunWith(SpringJUnit4ClassRunner.class) @SpringApplicationConfiguration(classes =
spring cloud + spring boot + springmvc+mybatis分散式微服務雲架構
做一個微服務架構需要的技術整理:View: H5、Vue.js、Spring Tag、React、angularJsSpring Boot/Spring Cloud:Zuul、Ribbon、Feign、Turbine、Hystrix、Oauthor2、Sleuth、API G
Spring Cloud Spring Boot mybatis分布式微服務雲架構(五)
Spring Cloud Spring Boot mybatis 架構 首先,回顧並詳細說明一下在快速入門中使用的@Controller、@RestController、@RequestMapping註解。如果您對Spring MVC不熟悉並且還沒有嘗試過快速入門案例,建議先看一下快速入門的內
Spring Cloud Spring Boot mybatis分布式微服務雲架構(二)
Spring Cloud Spring Boot mybatis 架構 下面針對該Controller編寫測試用例驗證正確性,具體如下。當然也可以通過瀏覽器插件等進行請求提交驗證。 @RunWith(SpringJUnit4Cla***unner.class) @SpringApplic
Spring Cloud Spring Boot mybatis分布式微服務雲架構(六)RESTfu
web 模塊 Spring 下面針對該Controller編寫測試用例驗證正確性,具體如下。當然也可以通過瀏覽器插件等進行請求提交驗證。 @RunWith(SpringJUnit4Cla***unner.class) @SpringApplicationConfiguration(class
Spring Cloud Spring Boot mybatis分布式微服務雲架構(十)
Spring cloud Spring Boot 架構 Java 在完成了上述配置後,其實已經可以生產文檔內容,但是這樣的文檔主要針對請求本身,而描述主要來源於函數等命名產生,對用戶並不友好,我們通常需要自己增加一些說明來豐富文檔內容。如下所示,我們通過@ApiOperation註解來給API
Spring Cloud Spring Boot mybatis分布式微服務雲架構(三)屬性配置文件詳解(1)
定義 public 配置數據庫連接 clas cep and xml配置 其他 PE 相信很多人選擇Spring Boot主要是考慮到它既能兼顧Spring的強大功能,還能實現快速開發的便捷。我們在Spring Boot使用過程中,最直觀的感受就是沒有了原來自己整合Spri
Spring Cloud Spring Boot mybatis分布式微服務雲架構(二)使用Intellij中的Spring Initializr來快速構建Spring Boot/Cloud工程
follow 體驗 alt initial ali roo 進行 依賴管理 img 在之前的所有Spring Boot和Spring Cloud相關博文中,都會涉及Spring Boot工程的創建。而創建的方式多種多樣,我們可以通過Maven來手工構建或是通過腳手架等方式快
Spring Cloud+Spring Boot+Mybatis+shiro +微服務 企業分散式微服務雲架構技術分享
1. 介紹Commonservice-system是一個大型分散式、微服務、面向企業的JavaEE體系快速研發平臺,基於模組化、服務化、原子化、熱插拔的設計思想,使用成熟領先的無商業限制的主流開源技術構建。採用服務化的元件開發模式,可實現複雜的業務功能。提供驅動式開發模式
spring cloud + spring boot +...分布式微服務雲架構
doc uid pri dfs lar title bin util feign 做一個微服務架構需要的技術整理: View: H5、Vue.js、Spring Tag、React、angularJs Spring Boot/Spring Cloud:Zuul、Ribbon
spring cloud + spring boot +..分布式微服務雲架構
spring springboot springcloud java 框架 做一個微服務架構需要的技術整理:View: H5、Vue.js、Spring Tag、React、angularJsSpring Boot/Spring Cloud:Zuul、Ribbon、Feign、Turbin
spring cloud + spring boot +分布式微服務雲架構
Spring Cloud Spring Boot config 做一個微服務架構需要的技術整理: View: H5、Vue.js、Spring Tag、React、angularJs Spring Boot/Spring Cloud:Zuul、Ribbon、Feign、Turbine、Hystri
Java架構-(四)整合spring cloud雲服務架構 - 企業分散式微服務雲架構構建
今天正式給大家介紹了Spring Cloud - 企業分散式微服務雲架構構建,我這邊結合了當前大部分企業的通用需求,包括技術的選型比較嚴格、苛刻,不僅要用業界最流行的技術,還要和國際接軌,在未來的5~10年內不能out。作為公司的架構師,也要有一種放眼世界的眼光,不僅要給公司做好的技術選
Spring Cloud分散式微服務雲架構原始碼分析 — Eureka
在看具體原始碼前,我們先回顧一下之前我們所實現的內容,從而找一個合適的切入口去分析。首先,服務註冊中心、服務提供者、服務消費者這三個主要元素來說,後兩者(也就是Eureka客戶端)在整個執行機制中是大部分通訊行為的主動發起者,而註冊中心主要是處理請求的接收者。所以,我們可
(一)spring cloud互聯網分布式微服務雲平臺規劃分析--spring cloud平臺整體規
互聯 common 可用 mys ext 收集 eureka 支付 總線 導語 近期公司孵化了一個互聯網產品,隨著業務發展,產品運營後用戶數據量(過億)、業務數據量(過100億)較大,技術團隊配合產品、運營快速定制化開發, 還要考慮產品涉及的資金安全、消息的及時性、業務的
spring cloud互聯網分布式微服務雲平臺規劃分析--spring cloud服務統一配置中心
基礎 ges ide ring water mave config 開發 通過 1.介紹鴻鵠雲架構【服務統一配置中心】為分布式系統中的外部配置提供服務器和客戶端支持。使用commonservice-config,可以在所有環境中管理應用程序的外部屬性。應用程序可通過從開發人
spring cloud互聯網分布式微服務雲平臺規劃分析--spring cloud定時調度平臺
cli uart type mys 分享 springmvc 任務 編寫 ava 1.介紹 鴻鵠雲架構【定時調度平臺】是一個完全由Java編寫的開源任務調度框架,為企業在任務調度提供了簡單卻強大的機制。開發人員根據業務規則,使用調度平臺簡單配置,就可以讓任務在特定時間特定階
分散式微服務雲架構dubbo+zookeeper+springmvc+mybatis+shiro+redis例項
原始碼結構 JEESZ驅動式專案構建 內建高效可靠的程式碼生成器 支援多種資料模型,根據資料庫表生成常規重複性程式碼,使研發工程師更專注於業務邏輯程式碼的實現,大幅提升其工作效率,解放其重複性工作 OPEN CI 開源規範化專案管理解決方案,實現軟體流水線式