SpringCloud Alibaba微服务实战(二) - Nacos服务注册与restTemplate消费
說在前面
基礎環境搭建,理論,請看上一篇,在這就不扯理論了,直接上代碼。
項目結構
代碼實現
第一步:在父pom的項目中引入dependencyManagement
在引入父pom之前咱們先來回顧下dependencyManagement與使用他的原因
什么是dependencyManagement:他可以統一管理項目的版本號,確保應用的各個子項目的依賴和版本一致,當需要變更版本號的時候只需要在父類容器里更新,不需要任何一個子項目的修改;如果某個子項目需要另外一個特殊的版本號時,只需要在自己的模塊dependencies中聲明一個版本號即可。子類就會使用子類聲明的版本號,不繼承于父類版本號。
為什么用dependencyManagement:首先在SpringCloudAlibaba的項目中對于版本的依賴要求很嚴格,所有需要統一來聲明管理每隔依賴的版本號。版本之間的關系參考文章:SpringCloud Alibaba 微服務架構版本說明
父類完整的pom.xml
<?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><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.3.2.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.zsy.springcloud</groupId><artifactId>cloud-alibaba</artifactId><packaging>pom</packaging><version>1.0-SNAPSHOT</version><modules><module>cloud-account</module><module>cloud-consumer</module></modules><properties><java.version>1.8</java.version><spring-cloud-alibaba.version>2.2.3.RELEASE</spring-cloud-alibaba.version><spring-cloud.version>Hoxton.SR8</spring-cloud.version></properties><dependencies><!--Spring Boot整合lombok依賴--><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency></dependencies><dependencyManagement><dependencies><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>${spring-cloud-alibaba.version}</version><type>pom</type><scope>import</scope></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>${spring-cloud.version}</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement>
</project>
第二步:構建服務提供者cloud-account進行服務注冊
- 在父項目中創建子module項目名字為cloud-account,在pom中引入nacos服務注冊依賴
<!--Spring web--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--SpringCloud Alibaba nacos--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency>
完整服務提供者cloud-account的pom.xml
<?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"><parent><artifactId>cloud-alibaba</artifactId><groupId>com.zsy.springcloud</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>cloud-account</artifactId><dependencies><!--Spring web--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--SpringCloud Alibaba nacos--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build><repositories><!--指定阿里云鏡像庫下載依賴--><repository><id>central</id><name>aliyunmaven</name><url>http://maven.aliyun.com/nexus/content/groups/public/</url></repository></repositories>
</project>
- 創建服務提供者AccountController
package com.zsy.springcloud.controller;
import lombok.extern.log4j.Log4j2;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import java.util.HashMap;
import java.util.Map;
@Log4j2
@RestController
public class AccountController {@RequestMapping(value = "/getAccount", method = RequestMethod.GET)public Map<String,Object> getAccount() {log.info("獲取客戶信息服務, 服務正常啟動");Map<String,Object> account = new HashMap<>();account.put("id","1");account.put("name","詩穎");log.info("id=="+account.get("id")+",name=="+account.get("name"));return account;}
}
- 配置application.yml或者properties文件
server:port: 8081
spring:#服務應用名字application:name: cloud-accountcloud:# 指定nacos控制臺地址,配置注冊ip:端口,注意即使是80端口也不可能省略nacos:discovery:server-addr: 127.0.0.1:8848
- 配置啟動服務的啟動類
package com.zsy.springcloud;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
@SpringBootApplication
@EnableDiscoveryClient //開啟服務注冊
public class AccountApplication {public static void main(String [] args) {SpringApplication.run(AccountApplication.class, args);}
}
- 啟動cloud-account服務項目,啟動成功,如下圖
- 驗證服務,瀏覽器訪問http://127.0.0.1:8848/nacos/,登錄,點擊服務管理,查看服務列表,如下圖,服務注冊成功。
第三步,構建服務消費者cloud-consumer進行服務調用
1.在父項目中創建子module項目名字為cloud-account,在pom中引入nacos服務注冊依賴(同服務者)
<!--Spring web--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--SpringCloud Alibaba nacos--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency>
完整消費者cloud-consumer的pom.xml
<?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"><parent><artifactId>cloud-alibaba</artifactId><groupId>com.zsy.springcloud</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>cloud-consumer</artifactId><dependencies><!--Spring web--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--SpringCloud Alibaba nacos--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build><repositories><!--指定阿里云鏡像庫下載依賴--><repository><id>central</id><name>aliyunmaven</name><url>http://maven.aliyun.com/nexus/content/groups/public/</url></repository></repositories>
</project>
- 創建消費者AccountConsumerController
package com.zsy.springcloud.controller;
import lombok.extern.log4j.Log4j2;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;
import java.util.HashMap;
import java.util.Map;
@Log4j2
@RestController
public class AccountConsumerController {@Autowiredprivate RestTemplate restTemplate;@RequestMapping(value = "/getConsumerAccount", method = RequestMethod.GET)public Map<String,Object> getAccount() {Map<String,Object> account = new HashMap<>();log.info("---------消費者開始------------");//調用服務account = restTemplate.getForObject("http://cloud-account/getAccount", HashMap.class);log.info("---------消費者結束--------account{}----", account);return account;}
}
- 配置application.yml或者properties文件
server:port: 8082
spring:#服務應用名字application:name: cloud-consumercloud:# 指定nacos控制臺地址,配置注冊ip:端口,注意即使是80端口也不可能省略nacos:discovery:server-addr: 127.0.0.1:8848
- 配置消費者啟動服務的啟動類
package com.zsy.springcloud;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;
@SpringBootApplication
@EnableDiscoveryClient //開啟服務注冊
public class ConsumerApplication {public static void main(String [] args) {SpringApplication.run(ConsumerApplication.class, args);}/*** 創建服務調用的對象* @LoadBalanced 添加此注解后,RestTemplate就具有了ribben客戶端負載均衡能力*/@Bean@LoadBalancedpublic RestTemplate restTemplate() {return new RestTemplate();}
}
- 啟動cloud-consumer服務項目,啟動成功,如下圖
6. 驗證服務,瀏覽器訪問http://localhost:8082/getConsumerAccount,返回如下圖
查看消費者cloud-consumer控制臺,如下圖
查看服務者cloud-account控制臺,如下圖
Nacos服務注冊與發現搭建完成,完整代碼地址:點擊下載
碼云地址:https://gitee.com/zlzhaoe/cloud-alibaba
總結
以上是生活随笔為你收集整理的SpringCloud Alibaba微服务实战(二) - Nacos服务注册与restTemplate消费的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: SpringCloud Alibaba微
- 下一篇: SpringCloud Alibaba微