AlibabaNacos服務注冊和配置中心


  Springcloud Netflix提供的服務進入維護模式,也就是一段時間內SpringcloudNetflix提供的服務和功能就這么多了,不在開發新的組件和功能。

  SpringcloudAlibaba致力於提供微服務開發的一站式解決方案。方便開發者通過springcloud編程模型輕松使用這些組件開發分布式應用服務。依托於coud alibaba,只需要添加一些注解和少量配置,就可以將Spring cloud應用接入阿里微服務解決方案。其主要組件包括Sentinel、Nacos、RocketMQ、Dubbo、Seata、Alibaba Cloud OSS、Alibaba Cloud Scheduler、Alibaba Cloud SMS等。

  阿里cloud項目官網:https://github.com/alibaba/spring-cloud-alibaba

1.Nacos簡介和安裝

1.簡介

一個更易於構建雲原生應用的動態服務發現、配置管理和服務管理平台。

Dynamic Naming And Configuration Service,實際上相當於注冊中心+配置中心的組合。相當Springcloud中Eureka + Config + Bus的組合。

nacos官網:https://nacos.io/zh-cn/

git官網:https://github.com/alibaba/nacos

2.安裝(我下載的版本是1.3.1)

(1)到https://github.com/alibaba/nacos/releases下載安裝包。如下:

nacos-server-1.3.1.zip

(2)解壓后啟動

 直接運行bin/startup.cmd

(3)訪問測試,默認的端口是8848,可以在application.properties中進行修改

默認的賬號密碼都是:nacos

登錄之后如下:

 2.支付訂單模塊使用nacos做注冊中心

0.父pom文件確定pom有下面坐標

            <!--spring cloud alibaba 2.1.0.RELEASE-->
            <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>

1.支付模塊

1.新建moudle

 2.修改pom

<?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</artifactId>
        <groupId>cn.qz.cloud</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>cloudalibaba-provider-nacos-payment9001</artifactId>

    <dependencies>
        <!--引入自己抽取的工具包-->
        <dependency>
            <groupId>cn.qz.cloud</groupId>
            <artifactId>cloud-api-commons</artifactId>
            <version>${project.version}</version>
        </dependency>
        <!--SpringCloud ailibaba nacos -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <!-- SpringBoot整合Web組件 -->
        <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>
        <!--日常通用jar包配置-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
</project>

3.修改yml

server:
  port: 9001

spring:
  application:
    name: nacos-payment-provider
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 #配置Nacos地址

management:
  endpoints:
    web:
      exposure:
        include: '*'

4.主啟動類

package cn.qz.cloud.alibaba;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

/**
 * @Author: qlq
 * @Description
 * @Date: 21:51 2020/10/26
 */
@EnableDiscoveryClient
@SpringBootApplication
public class PaymentMain9001 {
    public static void main(String[] args) {
        SpringApplication.run(PaymentMain9001.class, args);
    }
}

5.業務類:

package cn.qz.cloud.alibaba.controller;

import cn.qz.cloud.utils.JSONResultUtil;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * @Author: qlq
 * @Description
 * @Date: 21:52 2020/10/26
 */
@RestController
@RequestMapping("/nacos/payment")
public class PaymentController {

    @Value("${server.port}")
    private String serverPort;

    @GetMapping(value = "/getServerPort")
    public JSONResultUtil<String> getServerPort() {
        return JSONResultUtil.successWithData(serverPort);
    }
}

6.啟動后查看nacos服務列表

 2.創建模塊cloudalibaba-provider-nacos-payment9002和上面構成集群

啟動后查看nacos服務列表:

 3.創建訂單服務調用上面支付服務

1.新建訂單模塊cloudalibaba-consumer-nacos-order83

 2.修改pom

<?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</artifactId>
        <groupId>cn.qz.cloud</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>cloudalibaba-consumer-nacos-order83</artifactId>

    <dependencies>
        <!--SpringCloud ailibaba nacos -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <!--引入自己抽取的工具包-->
        <dependency>
            <groupId>cn.qz.cloud</groupId>
            <artifactId>cloud-api-commons</artifactId>
            <version>${project.version}</version>
        </dependency>
        <!-- SpringBoot整合Web組件 -->
        <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>
        <!--日常通用jar包配置-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
</project>

3.修改yml

server:
  port: 83

spring:
  application:
    name: nacos-order-consumer
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848

#消費者將要去訪問的微服務名稱(注冊成功進nacos的微服務提供者)
service-url:
  nacos-payment-provider: http://nacos-payment-provider

4.主啟動類:

package cn.qz.cloud.alibaba;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

/**
 * @Author: qlq
 * @Description
 * @Date: 22:27 2020/10/26
 */
@EnableDiscoveryClient
@SpringBootApplication
public class OrderNacosMain83 {
    public static void main(String[] args) {
        SpringApplication.run(OrderNacosMain83.class, args);
    }
}

5.業務類:

(1)配置類

package cn.qz.cloud.alibaba.config;

import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.client.RestTemplate;

@Configuration
public class ApplicationContextConfig {
    @Bean
    @LoadBalanced
    public RestTemplate getRestTemplate() {
        return new RestTemplate();
    }
}

(2)Controller

package cn.qz.cloud.alibaba.controller;

import cn.qz.cloud.utils.JSONResultUtil;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;

import javax.annotation.Resource;

@RestController
@Slf4j
@RequestMapping("/nacos/consumer/")
public class OrderNacosController {
    @Resource
    private RestTemplate restTemplate;

    @Value("${service-url.nacos-payment-provider}")
    private String serverURL;

    @GetMapping(value = "/getServerPort")
    public JSONResultUtil<String> getServerPort() {
        return restTemplate.getForObject(serverURL + "/nacos/payment/getServerPort", JSONResultUtil.class);
    }
}

6.啟動后測試

liqiang@root MINGW64 ~/Desktop
$ curl http://localhost:83/nacos/consumer/getServerPort
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:  0     0    0     0    0     0      0      0 --:--:--  0:00:01 --:100    52    0    52    0     0     35      0 --:--:--  0:00:01 --:--:--    35{"success":true,"code":"200","msg":"","data":"9002"}

liqiang@root MINGW64 ~/Desktop
$ curl http://localhost:83/nacos/consumer/getServerPort
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:100    52    0    52    0     0    666      0 --:--:-- --:--:-- --:--:--  1106{"success":true,"code":"200","msg":"","data":"9001"}

   當然訂單模塊也可以用feign來進行服務調用。

補充:各注冊中心的異同點 

   另外Nacos可以支持AP與CP模式。C是所有節點在同一時間看到的數據是一致的;而A的定義是所有的請求都會得到響應。nacos默認是AP,如果需要切換CP如下:

$ curl -X PUT "http://localhost:8848/nacos/v1/ns/operator/switches?entry=serverMode&value=CP"
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100     2  100     2    0     0     14      0 --:--:-- --:--:-- --:--:--    16ok

3.nacos做配置中心 

1.基本的使用

 1.新建項目cloudalibaba-config-nacos-client3377

 2.修改pom

<?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</artifactId>
        <groupId>cn.qz.cloud</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>cloudalibaba-config-nacos-client3377</artifactId>

    <dependencies>
        <!-- nacos config-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>
        <!-- SpringCloud ailibaba nacos-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <!--引入自己抽取的工具包-->
        <dependency>
            <groupId>cn.qz.cloud</groupId>
            <artifactId>cloud-api-commons</artifactId>
            <version>${project.version}</version>
        </dependency>
        <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.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
</project>

3.建立bootstrap.yml

server:
  port: 3377

spring:
  application:
    name: nacos-config-client
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 #Nacos服務注冊中心地址
      config:
        server-addr: localhost:8848 #Nacos作為配置中心地址
        file-extension: yaml #指定yaml格式配置

#${prefix}-${spring.profile.active}.${file-extension}
# ${spring.application.name}-${spring.profile.active}.${file-extension}
# nacos-config-client-dev.yml

4.建立application.yml

spring:
  profiles:
#    active: prod
    active: dev #表示開發環境

5.建立主啟動類:

package cn.qz.cloud.alibaba;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

@EnableDiscoveryClient
@SpringBootApplication
public class NacosConfigClientMain3377 {

    public static void main(String[] args) {
        SpringApplication.run(NacosConfigClientMain3377.class, args);
    }
}

6.建立controller測試

package cn.qz.cloud.alibaba.controller;

import cn.qz.cloud.utils.JSONResultUtil;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RefreshScope // 支持Nacos的動態刷新功能
@RequestMapping("/nacos/config/")
public class ConfigClientController {

    @Value("${config.info}")
    private String configInfo;

    @GetMapping("/configInfo")
    public JSONResultUtil<String> configInfo() {
        return JSONResultUtil.successWithData(configInfo);
    }
}

7.nacos建立配置文件:

(1)點擊如下按鈕:

 

 (2)新建dataId為nacos-config-client-dev.ymal。  實際dataId的值為: ${prefix}-${spring.profile.active}.${file-extension},默認prefix是${spring.application.name},例如上面的對應nacos-config-client-dev.yaml

 

啟動后訪問測試:

$ curl http://localhost:3377/nacos/config/configInfo
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100   101    0   101    0     0    404      0 --:--:-- --:--:-- --:--:--   404{"success":true,"code":"200","msg":"","data":"nacos-config-client-dev文件,ymal類型。version=2!"}

(3)nacos新建dataId為nacos-config-client-prod.yaml的配置,內容如下:

 修改applicaiton.yml中激活的版本,如下:

spring:
  profiles:
    active: prod
#    active: dev #表示開發環境

測試:

$ curl http://localhost:3377/nacos/config/configInfo
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100   102    0   102    0     0    502      0 --:--:-- --:--:-- --:--:--   502{"success":true,"code":"200","msg":"","data":"nacos-config-client-prod文件,ymal類型。version=1!"}

2.nacos按組group分組方案

   nacos允許通過group區分不同的配置文件。默認是組DEFAULT_GROUP。

1.新建配置文件並且指定組

2.bootstrap.yml指定組和application.yml指定激活的開發環境

server:
  port: 3377

spring:
  application:
    name: nacos-config-client
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 #Nacos服務注冊中心地址
      config:
        server-addr: localhost:8848 #Nacos作為配置中心地址
        file-extension: yaml #指定yaml格式配置
        group: group1

 

spring:
  profiles:
#    active: prod
    active: dev #表示開發環境

3.啟動測試:

$ curl http://localhost:3377/nacos/config/configInfo
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100   108    0   108    0     0    532      0 --:--:-- --:--:-- --:--:--   532{"success":true,"code":"200","msg":"","data":"nacos-config-client-dev文件,ymal類型。version=1!group1!"}

3.按namespace分組

  nacos還支持按namespace分組,namespace包含group,group包含dataId。 類似於java的package。

1.新建一個namespace

 2.該namespace下面新建配置文件,dataId為 nacos-config-client-dev.yaml

 新建的配置如下:

 3.修改bootstrap.yaml,指定group和namespace

server:
  port: 3377

spring:
  application:
    name: nacos-config-client
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 #Nacos服務注冊中心地址
      config:
        server-addr: localhost:8848 #Nacos作為配置中心地址
        file-extension: yaml #指定yaml格式配置
        group: group1
        namespace: namespace-dev

4.重啟后測試

$ curl http://localhost:3377/nacos/config/configInfo
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100   139    0   139    0     0    684      0 --:--:-- --:--:-- --:--:--   684{"success":true,"code":"200","msg":"","data":"nacos-config-client-dev文件,ymal類型。version=1!group1!namespace為【namespace-dev】"}

 5.修改配置內容的版本為2:

config: 
    info:  nacos-config-client-dev文件,ymal類型。version=2!group1!namespace為【namespace-dev】

6.保存后測試:(說明自動更新為nacos配置文件中的內容)

$ curl http://localhost:3377/nacos/config/configInfo
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100   139    0   139    0     0    139      0 --:--:-- --:--:-- --:--:--  135k{"success":true,"code":"200","msg":"","data":"nacos-config-client-dev文件,ymal類型。version=2!group1!namespace為【namespace-dev】"}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM