一、下載安裝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界面,查看服務列表菜單