SpringCloudAlibaba--Nacos作为服务注册中心、各种注册中心对比、Nacos的AP和CP模式切换

亦凉 2021-08-27 17:42 641阅读 0赞

基于Nacos的服务提供者

创建cloudalibaba-provider-payment9001模拟支付模块:
依赖:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <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">
  3. <parent>
  4. <artifactId>cloud2020</artifactId>
  5. <groupId>pers.zhang.springcloud</groupId>
  6. <version>1.0-SNAPSHOT</version>
  7. </parent>
  8. <modelVersion>4.0.0</modelVersion>
  9. <artifactId>cloudalibaba-provider-payment9001</artifactId>
  10. <dependencies>
  11. <!--SpringCloud ailibaba nacos -->
  12. <dependency>
  13. <groupId>com.alibaba.cloud</groupId>
  14. <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
  15. </dependency>
  16. <!-- SpringBoot整合Web组件 -->
  17. <dependency>
  18. <groupId>org.springframework.boot</groupId>
  19. <artifactId>spring-boot-starter-web</artifactId>
  20. </dependency>
  21. <dependency>
  22. <groupId>org.springframework.boot</groupId>
  23. <artifactId>spring-boot-starter-actuator</artifactId>
  24. </dependency>
  25. <!--日常通用jar包配置-->
  26. <dependency>
  27. <groupId>org.springframework.boot</groupId>
  28. <artifactId>spring-boot-devtools</artifactId>
  29. <scope>runtime</scope>
  30. <optional>true</optional>
  31. </dependency>
  32. <dependency>
  33. <groupId>org.projectlombok</groupId>
  34. <artifactId>lombok</artifactId>
  35. <optional>true</optional>
  36. </dependency>
  37. <dependency>
  38. <groupId>org.springframework.boot</groupId>
  39. <artifactId>spring-boot-starter-test</artifactId>
  40. <scope>test</scope>
  41. </dependency>
  42. </dependencies>
  43. </project>

配置:application.yml

  1. server:
  2. port: 9001
  3. spring:
  4. application:
  5. name: nacos-payment-provider
  6. cloud:
  7. nacos:
  8. discovery:
  9. server-addr: localhost:8848 #配置Nacos地址
  10. management:
  11. endpoints:
  12. web:
  13. exposure:
  14. include: '*'

Controller:

  1. @RestController
  2. public class PaymentController {
  3. @Value("${server.port}")
  4. String serverPort;
  5. @GetMapping("/payment/nacos/{id}")
  6. public String getPayment(@PathVariable("id") Long id){
  7. return "nacos registry, serverPort:" + serverPort + "\t id" + id;
  8. }
  9. }

启动类:

  1. @SpringBootApplication
  2. @EnableDiscoveryClient
  3. public class PaymentMain9001 {
  4. public static void main(String[] args) {
  5. SpringApplication.run(PaymentMain9001.class, args);
  6. }
  7. }

测试:启动Nacos,启动9001微服务:
在这里插入图片描述
在这里插入图片描述

基于Nacos的服务消费者

首先,根据上文的9001微服务再创建一个9002微服务。

新建cloudalibaba-consumer-nacos-order83模拟订单模块

依赖:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <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">
  3. <parent>
  4. <artifactId>cloud2020</artifactId>
  5. <groupId>pers.zhang.springcloud</groupId>
  6. <version>1.0-SNAPSHOT</version>
  7. </parent>
  8. <modelVersion>4.0.0</modelVersion>
  9. <artifactId>cloudalibaba-consumer-nacos-order83</artifactId>
  10. <dependencies>
  11. <!--SpringCloud ailibaba nacos -->
  12. <dependency>
  13. <groupId>com.alibaba.cloud</groupId>
  14. <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
  15. </dependency>
  16. <!-- 引入自己定义的api通用包,可以使用Payment支付Entity -->
  17. <dependency>
  18. <groupId>pers.zhang.springcloud</groupId>
  19. <artifactId>cloud-api-commons</artifactId>
  20. <version>${project.version}</version>
  21. </dependency>
  22. <!-- SpringBoot整合Web组件 -->
  23. <dependency>
  24. <groupId>org.springframework.boot</groupId>
  25. <artifactId>spring-boot-starter-web</artifactId>
  26. </dependency>
  27. <dependency>
  28. <groupId>org.springframework.boot</groupId>
  29. <artifactId>spring-boot-starter-actuator</artifactId>
  30. </dependency>
  31. <!--日常通用jar包配置-->
  32. <dependency>
  33. <groupId>org.springframework.boot</groupId>
  34. <artifactId>spring-boot-devtools</artifactId>
  35. <scope>runtime</scope>
  36. <optional>true</optional>
  37. </dependency>
  38. <dependency>
  39. <groupId>org.projectlombok</groupId>
  40. <artifactId>lombok</artifactId>
  41. <optional>true</optional>
  42. </dependency>
  43. <dependency>
  44. <groupId>org.springframework.boot</groupId>
  45. <artifactId>spring-boot-starter-test</artifactId>
  46. <scope>test</scope>
  47. </dependency>
  48. </dependencies>
  49. </project>

配置:application.yml

  1. server:
  2. port: 83
  3. spring:
  4. application:
  5. name: nacos-order-consumer
  6. cloud:
  7. nacos:
  8. discovery:
  9. server-addr: localhost:8848
  10. #消费者将要去访问的微服务名称(注册成功进nacos的微服务提供者)
  11. service-url:
  12. nacos-user-service: http://nacos-payment-provider
  13. @Configuration
  14. public class ApplicationContextConfig {
  15. @Bean
  16. @LoadBalanced
  17. public RestTemplate getRestTemplate() {
  18. return new RestTemplate();
  19. }
  20. }

Controller:

  1. @RestController
  2. @Slf4j
  3. public class OrderNacosController {
  4. @Resource
  5. RestTemplate restTemplate;
  6. @Value("${service-url.nacos-user-service}")
  7. String serverURL;
  8. @GetMapping("/consumer/payment/nacos/{id}")
  9. public String paymentInfo(@PathVariable("id") Long id) {
  10. String result = restTemplate.getForObject(serverURL + "/payment/nacos/" + id, String.class);
  11. return result;
  12. }
  13. }

启动类:

  1. @SpringBootApplication
  2. @EnableDiscoveryClient
  3. public class OrderNacosMain83 {
  4. public static void main(String[] args) {
  5. SpringApplication.run(OrderNacosMain83.class, args);
  6. }
  7. }

测试

启动Nacos,启动9001和9002,以及83端口微服务:

查看8848控制台,注册成功。
在这里插入图片描述
访问:localhost:83/consumer/payment/nacos/222,轮询负载OK。
在这里插入图片描述
在这里插入图片描述
Nacos集成了Ribbon,自带负载均衡。

各种注册中心对比

Nacos全景图:
在这里插入图片描述

Nacos与CAP:

在这里插入图片描述
在这里插入图片描述

Nacos的AP和CP模式切换

  • C是所有节点在同一时间看到的数据是一致的;
  • A的定义是所有请求都会收到响应。

何时选用哪种模式?

一般来说,如果不需要存储服务级别的信息且服务实例是通过nacos-client注册,并能够保持心跳上报,那么就可以选择AP模式。当前主流的服务如Spring Cloud 和 Dubbo服务,都适用于AP模式,AP模式为了服务的可能性而减弱了一致性,因此AP模式下只支持注册临时实例。

如果需要在服务级别编辑或者存储配置信息,那么CP是必须的,K8S服务和DNS服务则适用于CP模式。CP模式下支持注册持久化实例,此时则是以Raft协议为集群运行模式,该模式下注册实例之前必须先注册服务,如果服务不存在,则会返回错误。

  1. curl -X PUT `$NACOS_SERVER:8848/nacos/v1/ns/operator/switches?entry=serverMode&value=CP'

发表评论

表情:
评论列表 (有 0 条评论,641人围观)

还没有评论,来说两句吧...

相关阅读