一、下載安裝nacos
略。
二、搭建服務提供者
1、新建一個工程(test-springcloud),導入Spring Cloud Alibaba依賴
<?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>com.sdkj</groupId> <artifactId>cloud-alibaba-parent</artifactId> <version>1.0-SNAPSHOT</version> <modules> <module>cloud-provider-alibaba-payment9001</module> <module>cloud-consumer-alibaba-order7001</module> <module>cloud-provider-alibaba-payment9002</module> <module>cloud-config-nacos-client8901</module> </modules> <packaging>pom</packaging> <properties> <maven.compiler.source>8</maven.compiler.source> <maven.compiler.target>8</maven.compiler.target> </properties> <!--boot父版本依賴--> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.5.RELEASE</version> </parent> <!--cloud管理依賴--> <dependencyManagement> <dependencies> <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-dependencies --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Hoxton.RELEASE</version> <type>pom</type> <scope>import</scope> </dependency> <!--alibaba--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-alibaba-dependencies</artifactId> <version>2.1.0.RELEASE</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <dependencies> <!-- spring boot依賴 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!--優雅停服依賴包--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <scope>runtime</scope> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> </project>
2、新建一個模塊服務提供者(springcloud-provider-alibaba-payment9001),引入Nacos依賴
<dependencies> <!--nacos--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> </dependencies>
3、新建一個配置文件appliction.yml
# 端口
server:
port: 9001
spring:
application:
name: nacos-payment-provider
cloud:
nacos:
discovery:
server-addr: 192.168.186.128:8848
4、新建啟動類
1 @EnableDiscoveryClient
2 @SpringBootApplication
3 public class PaymentMain9001 {
4 public static void main(String[] args) {
5 SpringApplication.run(PaymentMain9001.class, args);
6 }
7 }
5、新建一個Controller,如下:
1 @RestController
2 public class PaymentController {
3
4 @Value("${server.port}")
5 private String serverPort;
6
7 @GetMapping(value = "/payment/nacos/{id}")
8 public String getPayment(@PathVariable("id") Integer id) {
9 return "nacos registry, serverPort: " + serverPort + "\t id: " + id;
10 }
11 }
6、測試
1)啟動Nacos服務,啟動服務提供者模塊
2)訪問地址:http://localhost:9001/payment/nacos/11,正常獲取內容

3)訪問Nacos的Web界面,查看服務列表菜單

可以看到服務列表中,有nacos-payment-provider服務
三、搭建服務消費者
1、在父工程(test-springcloud)中,新建服務消費者模塊(springcloud-consumer-alibaba-order7001)
2、引入nacos依賴,同上
<dependencies> <!--nacos--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> </dependencies>
3、編寫配置文件,如下:
# 端口
server:
port: 7001
spring:
application:
name: nacos-order-consumer
cloud:
nacos:
discovery:
server-addr: 192.168.186.128:8848
4、編寫啟動類,如下:
1 @EnableDiscoveryClient
2 @SpringBootApplication
3 public class OrderMain7001 {
4 public static void main(String[] args) {
5 SpringApplication.run(OrderMain7001.class, args);
6 }
7 }
5、編輯配置類,代碼如下,注入RestTemplate
1 @Configuration
2 public class AppConfig {
3
4 @Bean
5 @LoadBalanced
6 public RestTemplate restTemplate(){
7 return new RestTemplate();
8 }
9
10 }
6、編寫一個Controller用于訪問
@RestController
public class OrderController {
@Autowired
private RestTemplate restTemplate;
@GetMapping(value = "/consumer/payment/nacos/{id}")
public String paymentInfo(@PathVariable("id") Integer id) {
return restTemplate.getForObject("http://nacos-payment-provider" + "/payment/nacos/" + id, String.class);
}
}
7、測試
1)啟動Nacos服務,啟動服務提供者模塊,啟動服務消費者模塊
2)訪問地址:http://localhost:9001/payment/nacos/11,正常獲取內容
訪問地址:http://localhost:7001/consumer/payment/nacos/11,正常獲取內容

3)訪問Nacos的Web界面,查看服務列表菜單,分別可以看到一個nacos-payment-provider服務,一個nacos-order-consumer服務
4)在搭建一個(springcloud-provider-alibaba-payment9002)服務提供者模塊,與9001模塊內容相同,只有端口的區別
5)啟動9002模塊,使用地址:http://localhost:7001/consumer/payment/nacos/11,訪問獲取內容
獲取的內容,是輪流從9001與9002這兩個節點上獲取
6)訪問Nacos的Web界面,查看服務列表菜單

本文來自博客園,作者:榮慕平,轉載請注明原文鏈接:http://www.rzrgm.cn/rongmuping/articles/16320149.html

浙公網安備 33010602011771號