SpringCloud基于RestTemplate微服務(wù)項(xiàng)目案例解析
基于RestTemplate微服務(wù)項(xiàng)目
在寫SpringCloud搭建微服務(wù)之前,我想先搭建一個(gè)不通過springcloud只通過SpringBoot和Mybatis進(jìn)行模塊之間額通訊。然后在此基礎(chǔ)上再添加SpringCloud框架。
下面先對(duì)案例做個(gè)說明
該項(xiàng)目有一個(gè)maven父模塊,其中里面有三個(gè)子模塊:
serverspringcloud:整體父工程。
serverspringcloud-api:公共子模塊,放公共實(shí)體對(duì)象。
serverspringcloud-provider-dept-8001:部門微服務(wù)提供者。
serverspringcloud-consumer-dept-80:部門微服務(wù)消費(fèi)者。調(diào)用部分微服務(wù)提供者接口進(jìn)行CRUD操作。
一、構(gòu)建父工程
主要步驟:
(1) 創(chuàng)建一個(gè)Maven父工程并命名serverspringcloud
(2) 打包方式為POM
(3) 在pom.xml中定義各依賴的版本號(hào)(若Module中pom.xml的依賴沒有指定版本號(hào),則會(huì)根據(jù)父工程的版本號(hào)加入依賴)
1、創(chuàng)建一個(gè)Maven父工程
2、打包方式為POM
3、在pom.xml中定義各依賴的版本號(hào)
<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>com.jincou.springcloudrest</groupId> <artifactId>serverspringcloud</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>pom</packaging> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <maven.compiler.source>1.8</maven.compiler.source> <maven.compiler.target>1.8</maven.compiler.target> <junit.version>4.12</junit.version> <log4j.version>1.2.17</log4j.version> <lombok.version>1.16.18</lombok.version> </properties> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>1.5.9.RELEASE</version> <type>pom</type> <scope>import</scope> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.0.4</version> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.0.31</version> </dependency> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.3.0</version> </dependency> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-core</artifactId> <version>1.2.3</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>${junit.version}</version> <scope>test</scope> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>${log4j.version}</version> </dependency> </dependencies> </dependencyManagement> <build> <finalName>serverspringcloud</finalName> <resources> <resource> <directory>src/main/resources</directory> <filtering>true</filtering> </resource> </resources> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-resources-plugin</artifactId> <configuration> <delimiters> <delimit>$</delimit> </delimiters> </configuration> </plugin> </plugins> </build> <!-- 說明下當(dāng)你剛開始創(chuàng)建父工程的時(shí)候是沒有下面這些信息的,當(dāng)你在父工程下每新建一個(gè)子模塊那么在這里都會(huì)添加一個(gè)子模塊的信息--> <modules> <module>serverspringcloud-api</module> <module>serverspringcloud-provider-dept-8001</module> <module>serverspringcloud-consumer-dept-80</module> </modules> </project> pom.xml
二、構(gòu)建serverspringcloud-api(公共子模塊)
主要步驟
(1) 在父工程下新建Maven的Module,打包方式為jar
(2)在該Module下pom.xml中加入其它需要的依賴
(3) 完成后先clean一下Maven項(xiàng)目,然后再install提供給其它模塊調(diào)用
1、在父工程下新建Maven的Module,打包方式為jar
在創(chuàng)建完子模塊后看下pom.xml的Overview視圖的一些信息。
2、 在該Module下pom.xml中加入其它需要的依賴
<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> <parent> <groupId>com.jincou.springcloudrest</groupId> <artifactId>serverspringcloud</artifactId> <version>0.0.1-SNAPSHOT</version> </parent> <!-- 我在創(chuàng)建時(shí)沒有重新指明groupId那就默認(rèn)用父類的groupId --> <artifactId>serverspringcloud-api</artifactId> <!-- 該子模塊下目前我并沒有添加新的jar --> </project>
pom.xml3、我在這里面添加了一個(gè)Dept實(shí)體
Dept實(shí)體
package com.jincou.springcloud.entities; import java.io.Serializable; public class Dept implements Serializable { private Long deptno; // 主鍵 private String dname; // 部門名稱 private String db_source;// 來自那個(gè)數(shù)據(jù)庫,因?yàn)槲⒎?wù)架構(gòu)可以一個(gè)服務(wù)對(duì)應(yīng)一個(gè)數(shù)據(jù)庫,同一個(gè)信息被存儲(chǔ)到不同數(shù)據(jù)庫 public Dept(String dname) { super(); this.dname = dname; } public Dept(Long deptno, String dname, String db_source) { super(); this.deptno = deptno; this.dname = dname; this.db_source = db_source; } public Dept() { super(); } public Long getDeptno() { return deptno; } public void setDeptno(Long deptno) { this.deptno = deptno; } public String getDname() { return dname; } public void setDname(String dname) { this.dname = dname; } public String getDb_source() { return db_source; } public void setDb_source(String db_source) { this.db_source = db_source; } }
三、創(chuàng)建部門微服務(wù)提供者
步驟:這個(gè)就比較復(fù)雜了,具體看下面的圖
下面就展示幾個(gè)比較重要的環(huán)節(jié)
1、pom.xml文件
(1)先看下pom.xml的Overview視圖的一些信息。
(2)pom.xml
<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> <parent> <groupId>com.jincou.springcloudrest</groupId> <artifactId>serverspringcloud</artifactId> <version>0.0.1-SNAPSHOT</version> </parent> <artifactId>serverspringcloud-provider-dept-8001</artifactId> <dependencies> <!-- 引入自己定義的api通用包,可以使用Dept部門Entity --> <dependency> <groupId>com.jincou.springcloudrest</groupId> <artifactId>serverspringcloud-api</artifactId> <version>${project.version}</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> </dependency> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-core</artifactId> </dependency> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jetty</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> </dependency> <!-- 修改后立即生效,熱部署 --> <dependency> <groupId>org.springframework</groupId> <artifactId>springloaded</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> </dependency> </dependencies> </project>
2、application.yml
server: port: 8001 #端口號(hào) mybatis: config-location: classpath:mybatis/mybatis.cfg.xml # mybatis配置文件所在路徑 type-aliases-package: com.jincou.springcloud.entities # 所有Entity別名類所在包 mapper-locations: - classpath:mybatis/mapper/**/*.xml # mapper映射文件 spring: application: name: serverspringcloud-dept #這個(gè)名字很重要后期如果注入eureka就很重要 datasource: type: com.alibaba.druid.pool.DruidDataSource # 當(dāng)前數(shù)據(jù)源操作類型 driver-class-name: org.gjt.mm.mysql.Driver # mysql驅(qū)動(dòng)包 url: jdbc:mysql://localhost:3306/cloudDB01 # 數(shù)據(jù)庫名稱 username: root password: root dbcp2: min-idle: 5 # 數(shù)據(jù)庫連接池的最小維持連接數(shù) initial-size: 5 # 初始化連接數(shù) max-total: 5 # 最大連接數(shù) max-wait-millis: 200 # 等待連接獲取的最大超時(shí)時(shí)間
3、MySQL表信息
4、DAO接口信息
@Mapper public interface DeptDao { public boolean addDept(Dept dept);//添加部門 public Dept findById(Long id); //通過id找該部門數(shù)據(jù) public List<Dept> findAll(); //查看所有部門 }
5、Controller層類
@RestController public class DeptController { @Autowired private DeptService service; //添加部門接口 @RequestMapping(value = "/dept/add", method = RequestMethod.POST) public boolean add(@RequestBody Dept dept) { return service.add(dept); } //通過部門id查找部門信息 @RequestMapping(value = "/dept/get/{id}", method = RequestMethod.GET) public Dept get(@PathVariable("id") Long id) { return service.get(id); } //查找所有部門信息 @RequestMapping(value = "/dept/list", method = RequestMethod.GET) public List<Dept> list() { return service.list(); } }
6、測試
先做個(gè)小測試,看數(shù)據(jù)庫連接是否成功,調(diào)用api模塊是否成功。
說明測試成功!
四、創(chuàng)建部門微服務(wù)消費(fèi)者
主要步驟如圖
1、pom.xml文件
<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> <parent> <groupId>com.jincou.springcloudrest</groupId> <artifactId>serverspringcloud</artifactId> <version>0.0.1-SNAPSHOT</version> </parent> <artifactId>serverspringcloud-consumer-dept-80</artifactId> <description>部門微服務(wù)消費(fèi)者</description> <dependencies> <dependency><!-- 自己定義的api --> <groupId>com.jincou.springcloudrest</groupId> <artifactId>serverspringcloud-api</artifactId> <version>${project.version}</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- 修改后立即生效,熱部署 --> <dependency> <groupId>org.springframework</groupId> <artifactId>springloaded</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> </dependency> </dependencies> </project>
2、application.yml
server: port: 80
3、ConfigBean配置類
@Configuration public class ConfigBean // @Configuration配置 ConfigBean = applicationContext.xml { @Bean public RestTemplate getRestTemplate() { return new RestTemplate(); } }
4、DeptController_Consumer類
@RestController public class DeptController_Consumer { private static final String REST_URL_PREFIX = "http://localhost:8001"; /** * 使用 使用restTemplate訪問restful接口非常的簡單粗暴無腦。 (url, requestMap, * ResponseBean.class)這三個(gè)參數(shù)分別代表 REST請(qǐng)求地址、請(qǐng)求參數(shù)、HTTP響應(yīng)轉(zhuǎn)換被轉(zhuǎn)換成的對(duì)象類型。 */ @Autowired private RestTemplate restTemplate; @RequestMapping(value = "/consumer/dept/add") public boolean add(Dept dept) { return restTemplate.postForObject(REST_URL_PREFIX + "/dept/add", dept, Boolean.class); } @RequestMapping(value = "/consumer/dept/get/{id}") public Dept get(@PathVariable("id") Long id) { return restTemplate.getForObject(REST_URL_PREFIX + "/dept/get/" + id, Dept.class); } @SuppressWarnings("unchecked") @RequestMapping(value = "/consumer/dept/list") public List<Dept> list() { return restTemplate.getForObject(REST_URL_PREFIX + "/dept/list", List.class); } }
5、測試
測試成功,當(dāng)我調(diào)用消費(fèi)者接口的時(shí)候,它會(huì)再去調(diào)用提供者的接口。
五、總結(jié)
整個(gè)項(xiàng)目終于跑通,然后再來屢一下思路,其實(shí)還是蠻簡單的。
(1)通過maven構(gòu)建父子工程,一個(gè)個(gè)子模塊就是一個(gè)個(gè)獨(dú)立的進(jìn)程(因?yàn)樗麄兌丝谔?hào)都不一樣),也就是微服務(wù)。
(2)模塊之間的調(diào)用只要把你需要的模塊放到你的pom.xml中,這樣就會(huì)打成jar包,就可以供該模塊調(diào)用。
(3)接口之間的調(diào)用只要通過RestTemplate工具類就可以了。
最后本博客GitHub源碼:https://github.com/yudiandemingzi/restTemplatestudy
到此這篇關(guān)于SpringCloud基于RestTemplate微服務(wù)項(xiàng)目案例的文章就介紹到這了,更多相關(guān)SpringCloud微服務(wù)項(xiàng)目案例內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- restTemplate實(shí)現(xiàn)跨服務(wù)API調(diào)用方式
- Spring?Cloud?Alibaba?Nacos服務(wù)治理平臺(tái)服務(wù)注冊(cè)、RestTemplate實(shí)現(xiàn)微服務(wù)之間訪問負(fù)載均衡訪問的問題
- Java服務(wù)調(diào)用RestTemplate與HttpClient的使用詳解
- springcloud中Ribbon和RestTemplate實(shí)現(xiàn)服務(wù)調(diào)用與負(fù)載均衡
- 關(guān)于springboot 中使用httpclient或RestTemplate做MultipartFile文件跨服務(wù)傳輸?shù)膯栴}
- restTemplate未設(shè)置連接數(shù)導(dǎo)致服務(wù)雪崩問題以及解決
相關(guān)文章
Java手動(dòng)創(chuàng)建線程池代碼實(shí)例
這篇文章主要介紹了Java手動(dòng)創(chuàng)建線程池代碼實(shí)例,FixedThreadPool或者SingleThreadPool,允許的請(qǐng)求隊(duì)列長度為Integer.MAX_VALUE,可能會(huì)堆積大量的請(qǐng)求,從而導(dǎo)致OOM,需要的朋友可以參考下2023-12-12詳解Java的Proxy動(dòng)態(tài)代理機(jī)制
Java有兩種代理方式,一種是靜態(tài)代理,另一種是動(dòng)態(tài)代理。對(duì)于靜態(tài)代理,其實(shí)就是通過依賴注入,對(duì)對(duì)象進(jìn)行封裝,不讓外部知道實(shí)現(xiàn)的細(xì)節(jié)。很多 API 就是通過這種形式來封裝的2021-06-06Spring?Boot?詳細(xì)分析Conditional自動(dòng)化配置注解
首先我們先了解一下@Conditional注解,@Conditional是Spring4新提供的注解,它的作用是按照一定的條件進(jìn)行判斷,需要注入的Bean滿足給定條件才可以注入到Spring?IOC容器中2022-07-07mybatis plus使用redis作為二級(jí)緩存的方法
這篇文章主要介紹了mybatis plus使用redis作為二級(jí)緩存的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09Spring Boot2.0實(shí)現(xiàn)靜態(tài)資源版本控制詳解
這篇文章主要給大家介紹了關(guān)于Spring Boot2.0實(shí)現(xiàn)靜態(tài)資源版本控制的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11Spring Boot 中的任務(wù)執(zhí)行器基本概念及使用方法
務(wù)執(zhí)行器是 Spring Boot 中的一個(gè)非常實(shí)用的模塊,它可以簡化異步任務(wù)的開發(fā)和管理,在本文中,我們介紹了任務(wù)執(zhí)行器的基本概念和使用方法,以及一個(gè)完整的示例代碼,需要的朋友可以參考下2023-07-07Windows編寫jar啟動(dòng)腳本和關(guān)閉腳本的操作方法
腳本文件,通常放入/bin目錄下,編寫啟動(dòng)腳本需要保證能夠識(shí)別到對(duì)應(yīng)的jar文件,其次需要保證能夠識(shí)別到/config中的配置文件信息,這篇文章主要介紹了Windows編寫jar啟動(dòng)腳本和關(guān)閉腳本的操作方法,需要的朋友可以參考下2022-12-12關(guān)于Java中的mysql時(shí)區(qū)問題詳解
這篇文章主要給大家介紹了關(guān)于Java中mysql時(shí)區(qū)問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Java具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05