0


SpringCloud Aliba-Nacos-从入门到学废【1】

🥚今日鸡汤🥚

** 当你最倒霉地时候一定要扛住。**

** 因为,那正是你运气该上升的时候。**

** ——《一人之下》**

1.Nacos介绍

  • Nacos是阿里巴巴开源的一个动态服务发现、配置管理和服务管理平台。
  • 实现微服务架构中的服务注册与发现、动态配置管理、服务健康监测等功能。
  • Nacos就是注册中心+配置中心的组合
  • 替代Eureka做服务注册中心
  • 替代Config做服务配置中心

2.Nacos服务提供者注册

2.1.建工程

  • 1.在父工程下创建cloudalibaba-provider-payment9001
  • 2.注意jdk和maven版本号
  • 另外创建cloudalibaba-provider-payment9002

2.2.加pom

父工程添加pom:

  1. <!--spring cloud alibaba 2.1.0.RELEASE-->
  2. <dependency>
  3. <groupId>com.alibaba.cloud</groupId>
  4. <artifactId>spring-cloud-alibaba-dependencies</artifactId>
  5. <version>2.2.0.RELEASE</version>
  6. <type>pom</type>
  7. <scope>import</scope>
  8. </dependency>

** 子工程pom: **

  1. <dependencies>
  2. <dependency>
  3. <groupId>org.springframework.boot</groupId>
  4. <artifactId>spring-boot-starter-web</artifactId>
  5. </dependency>
  6. <dependency>
  7. <groupId>org.springframework.boot</groupId>
  8. <artifactId>spring-boot-starter-actuator</artifactId>
  9. </dependency>
  10. <dependency>
  11. <groupId>org.springframework.boot</groupId>
  12. <artifactId>spring-boot-starter-test</artifactId>
  13. </dependency>
  14. <dependency>
  15. <groupId>org.projectlombok</groupId>
  16. <artifactId>lombok</artifactId>
  17. </dependency>
  18. <!--springCloud alibaba Naocs-->
  19. <dependency>
  20. <groupId>com.alibaba.cloud</groupId>
  21. <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
  22. </dependency>
  23. </dependencies>

2.3.改yml

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

2.4.主启动类

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

**2.5.测试 **

启动9001,9002,web端访问Nacos,说明访问成功

3.Nacos服务消费者

3.1.建工程

  • 1.在父工程下创建cloudalibaba-consumer-nacos-order83作为消费者
  • 2.注意jdk和maven版本号

3.2.加pom

  1. <dependencies>
  2. <dependency>
  3. <groupId>org.springframework.boot</groupId>
  4. <artifactId>spring-boot-starter-web</artifactId>
  5. </dependency>
  6. <dependency>
  7. <groupId>org.springframework.boot</groupId>
  8. <artifactId>spring-boot-starter-actuator</artifactId>
  9. </dependency>
  10. <dependency>
  11. <groupId>org.springframework.boot</groupId>
  12. <artifactId>spring-boot-starter-test</artifactId>
  13. </dependency>
  14. <dependency>
  15. <groupId>org.projectlombok</groupId>
  16. <artifactId>lombok</artifactId>
  17. </dependency>
  18. <dependency>
  19. <groupId>org.example</groupId>
  20. <artifactId>cloud-api-commons</artifactId>
  21. <version>1.0-SNAPSHOT</version>
  22. </dependency>
  23. <!--springCloud alibaba Naocs-->
  24. <dependency>
  25. <groupId>com.alibaba.cloud</groupId>
  26. <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
  27. </dependency>
  28. </dependencies>

3.3.改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

3.4.主启动类

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

3.5添加配置类

  • 1.注入RestTemplate
  • 2.添加@LoadBalanced(负载均衡)
  1. @Configuration
  2. public class MyConfig {
  3. @Bean
  4. @LoadBalanced
  5. public RestTemplate getRestTemplate() {
  6. return new RestTemplate();
  7. }
  8. }

3.6业务类

  • 1.定义常量
  • 2.引入restTemplate
  • 3.直接调用
  1. @RestController
  2. public class OrderNacosController {
  3. private static final String SERVER_URL="http://nacos-payment-provider";
  4. @Autowired
  5. private RestTemplate restTemplate;
  6. @GetMapping("/consumer/order/{id}")
  7. public String getPayment(@PathVariable("id")Integer id){
  8. return restTemplate.getForObject(SERVER_URL+"/payment/nacos/"+id,String.class);
  9. }
  10. }

3.7测试

  • 1.浏览器访问Nacos客户端,查看服务列表

  • **2.浏览器访问83消费端 **

**4.Nacos作为配置中心 **

4.1.建工程

  • 1.在父工程下创建cloudalibaba-config-nacos-client3377
  • 2.注意jdk和maven版本

4.2.加pom

  1. <dependencies>
  2. <dependency>
  3. <groupId>org.springframework.boot</groupId>
  4. <artifactId>spring-boot-starter-web</artifactId>
  5. </dependency>
  6. <dependency>
  7. <groupId>org.springframework.boot</groupId>
  8. <artifactId>spring-boot-starter-actuator</artifactId>
  9. </dependency>
  10. <dependency>
  11. <groupId>org.springframework.boot</groupId>
  12. <artifactId>spring-boot-starter-test</artifactId>
  13. </dependency>
  14. <dependency>
  15. <groupId>org.projectlombok</groupId>
  16. <artifactId>lombok</artifactId>
  17. </dependency>
  18. <dependency>
  19. <groupId>org.example</groupId>
  20. <artifactId>cloud-api-commons</artifactId>
  21. <version>1.0-SNAPSHOT</version>
  22. </dependency>
  23. <!--springCloud alibaba Naocs-->
  24. <dependency>
  25. <groupId>com.alibaba.cloud</groupId>
  26. <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
  27. </dependency>
  28. <!--nacos-config-->
  29. <dependency>
  30. <groupId>com.alibaba.cloud</groupId>
  31. <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
  32. </dependency>
  33. </dependencies>

4.3.改yml

1.要保证先从配置中心进行配置拉取,拉取配置之后,才能保证项目的正常启动。

2.springboot中配置文件的加载是存在优先级顺序的, bootstrap优先级高于application

  • **bootstrap.yml: **
  1. server:
  2. port: 3377
  3. spring:
  4. application:
  5. name: nacos-config-client
  6. cloud:
  7. nacos:
  8. discovery:
  9. server-addr: localhost:8848 #Nacos注册中心地址
  10. config:
  11. server-addr: localhost:8848 #Nacos作为配置中心地址
  12. file-extension: yml #指定yml格式的配置
  13. #${spring.application.name}-${spring.profile.active}.${spring.cloud.nacos.config.file-extension}
  14. #nacos-config-client-dev.yml
  • **application.yml **
  1. spring:
  2. profiles:
  3. active: dev #表示开发环境

**4.4Nacos新增配置 **

根据公式,配置Data ID

  1. ${spring.application.name}-${spring.profile.active}.${spring.cloud.nacos.config.file-extension}

4.5.主启动类

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

4.6业务类

  1. @RestController
  2. @RefreshScope//保持动态刷新
  3. public class ConfigClientController {
  4. @Value("${config.info}")
  5. private String configInfo;
  6. @GetMapping("/config/info")
  7. public String getConfigInfo(){
  8. return configInfo;
  9. }
  10. }

4.7测试

浏览器访问controller接口

**与Nacos配置里一样,说明成功~ **

5.命名空间+Group+Data Id

5.1三者关系

这三者的关系类似于Java里面的package名和类名,最外层的Namespace是可以用于区分部署环境的,Group和DataID逻辑上区分两个目标对象

5.2默认情况

Namespace=public,Group=DEFAULT_GROUP,默认Cluster是DEFAULT


**5.3Data Id 方案 **

  • 1.Nacos测试新增

  • **2.application.yml配置 **
  1. spring:
  2. profiles:
  3. #active: dev #表示开发环境
  4. active: test #表示测试环境
  • ** 3.测试重启**

**5.4Group方案 **

  • 1.Navos创建相同的DataID,但GROIP不同

  • **2.bootstrap添加group配置 **

  • **3.重启测试 **

**5.5Namespace方案 **

  • 1.查看命名空间

  • **2.新增命名空间 **

  • 3.切换命名空间

  • **4.bootstrap.yml配置 **
  1. server:
  2. port: 3377
  3. spring:
  4. application:
  5. name: nacos-config-client
  6. cloud:
  7. nacos:
  8. discovery:
  9. server-addr: localhost:8848 #Nacos注册中心地址
  10. config:
  11. server-addr: localhost:8848 #Nacos作为配置中心地址
  12. file-extension: yml #指定yml格式的配置
  13. group: TEST_GROUP #分组
  14. namespace: 277386e3-b431-4b12-a73e-222f61304889 #命名空间
  • 5.application.yml配置
  1. spring:
  2. profiles:
  3. active: dev #表示开发环境
  4. #active: test #表示测试环境
  5. #active: info #表示测试环境


本文转载自: https://blog.csdn.net/dfdg345/article/details/135555208
版权归原作者 会敲代码的小张 所有, 如有侵权,请联系我们删除。

“SpringCloud Aliba-Nacos-从入门到学废【1】”的评论:

还没有评论