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

这篇具有很好参考价值的文章主要介绍了SpringCloud Aliba-Nacos-从入门到学废【1】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

🥚今日鸡汤🥚

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

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

                                                                                                 ——《一人之下》

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos

目录

🧈1.Nacos介绍

🧂2.Nacos服务提供者注册

🥓3.Nacos服务消费者

🌭4.Nacos作为配置中心 

🍿5.命名空间+Group+Data  Id


1.Nacos介绍

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

2.Nacos服务提供者注册

2.1.建工程

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

2.2.加pom

父工程添加pom:

            <!--spring cloud alibaba 2.1.0.RELEASE-->
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>2.2.0.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>

 子工程pom: 

     <dependencies>
        <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-starter-test</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
        <!--springCloud alibaba Naocs-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
     </dependencies>

2.3.改yml

server:
  port: 9002

spring:
  application:
    name: ncaos-payment-provider
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848

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

2.4.主启动类

@SpringBootApplication
@EnableDiscoveryClient
public class PaymentMain9002 {
    public static void main(String[] args) {
        SpringApplication.run(PaymentMain9002.class);
    }
}

2.5.测试 

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

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos

3.Nacos服务消费者

3.1.建工程

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

3.2.加pom

 
    <dependencies>
        <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-starter-test</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
        <dependency>
            <groupId>org.example</groupId>
            <artifactId>cloud-api-commons</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
        <!--springCloud alibaba Naocs-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
    </dependencies>

3.3.改yml

server:
  port: 83

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

3.4.主启动类

@SpringBootApplication
@EnableDiscoveryClient
public class OrderNacosMain83 {
    public static void main(String[] args) {
        SpringApplication.run(OrderNacosMain83.class);
    }
}

3.5添加配置类

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

3.6业务类

  • 1.定义常量
  • 2.引入restTemplate
  • 3.直接调用
@RestController
public class OrderNacosController {

    private static final String SERVER_URL="http://nacos-payment-provider";

    @Autowired
    private RestTemplate restTemplate;


    @GetMapping("/consumer/order/{id}")
    public String getPayment(@PathVariable("id")Integer id){
        return restTemplate.getForObject(SERVER_URL+"/payment/nacos/"+id,String.class);
    }
}

3.7测试

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

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos

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

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos

4.Nacos作为配置中心 

4.1.建工程

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

4.2.加pom

     <dependencies>
        <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-starter-test</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
        <dependency>
            <groupId>org.example</groupId>
            <artifactId>cloud-api-commons</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
        <!--springCloud alibaba Naocs-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <!--nacos-config-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>
    </dependencies>

4.3.改yml

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

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

  • 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: yml   #指定yml格式的配置

#${spring.application.name}-${spring.profile.active}.${spring.cloud.nacos.config.file-extension}
#nacos-config-client-dev.yml
  • application.yml 
spring:
  profiles:
    active: dev #表示开发环境

4.4Nacos新增配置 

根据公式,配置Data ID

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

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos

4.5.主启动类

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

4.6业务类

@RestController
@RefreshScope//保持动态刷新
public class ConfigClientController {

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

    @GetMapping("/config/info")
    public String getConfigInfo(){
        return configInfo;
    }
}

4.7测试

浏览器访问controller接口

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos

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

5.命名空间+Group+Data  Id

5.1三者关系

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

5.2默认情况

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

 

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos

5.3Data Id 方案 

  • 1.Nacos测试新增

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos

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

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos

5.4Group方案 

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

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos

  • 2.bootstrap添加group配置 

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos

  • 3.重启测试 

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos

5.5Namespace方案 

  • 1.查看命名空间

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos

  • 2.新增命名空间 

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos

  • 3.切换命名空间

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos

  • 4.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: yml   #指定yml格式的配置
        group: TEST_GROUP  #分组
        namespace: 277386e3-b431-4b12-a73e-222f61304889 #命名空间
  • 5.application.yml配置
spring:
  profiles:
    active: dev #表示开发环境
    #active: test #表示测试环境
    #active: info #表示测试环境

SpringCloud Aliba-Nacos-从入门到学废【1】,springCloudAlibaba【大道秘籍】,spring cloud,spring,后端,中间件,架构,分布式,nacos文章来源地址https://www.toymoban.com/news/detail-812083.html

到了这里,关于SpringCloud Aliba-Nacos-从入门到学废【1】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • SpringCloud 注册中心(Nacos)快速入门

    作者:大三的土狗 专栏:SpringCloud   Nacos一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台,目前来看还是大多数公司使用Nacos多于Eureka。   Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发

    2024年02月03日
    浏览(66)
  • 【SpringCloud入门】-- Nacos快速入门之搭建服务与注册中心

    目录 前言:  1.Nacos的下载与安装 2. 去MySQL建立一个名为nacos的数据库 3.介绍配置文件,conf目录下的 application.properties 4.nacos启动 5. nacos作为注册中心的作用 6.建立一个项目,实现向命名空间注册 前言: 上文我们已经简单介绍了一下Nacos,现在我们一起来动手搭建一个Nacos的注

    2024年02月09日
    浏览(29)
  • SpringCloudAlibaba-整合nacos(二)

    目录地址: SpringCloudAlibaba整合-CSDN博客 一、nacos服务部分 1.下载nacos,并执行数据库脚本:nacos-mysql.sql 2.修改配置文件,配置mysql 3.启动nacos  4.访问:http://127.0.0.1:8848/nacos 用户名密码都是:nacos 5.创建3个配置文件,给3个微服务使用,展示 一下user的配置: 二、代码部分 用u

    2024年04月16日
    浏览(28)
  • Nacos使用SpringCloudAlibaba+Dubbo实现

    Nacos是阿里的一个开源产品,它是针对微服务架构中的服务发现、服务治理、配置管理的综合型解决方案。 官方介绍是这样的: Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您实现动态服务发现、服务配置管理、服务及流量管理。 N

    2024年02月13日
    浏览(30)
  • springcloudalibaba和nacos版本对应关系

    因为公司项目需要升级springcloud的版本,升级后服务启动时连接不上nacos(如下图) 历程一 一开始直接百度“Client not connected, current status:STARTING”这个错误,说可能是因为版本问题,然后到官网找对个版本对应的关系图 我项目所用的版本是2021.0.5.0的,那么对应的nacos版本应该

    2024年01月25日
    浏览(35)
  • SpringCloudAlibaba-微服务-Nacos服务配置

    Nacos 安装与部署:https://blog.csdn.net/Cey_Tao/article/details/127611559 Nacos 的服务发现有三个主要区域,从大到小分别是:命名空间(namespace),分组(group),集群(cluster) 默认分别为 public 命名空间,DEFAULT_GROUP 分组,DEFAULT 集群 不同集群之间的服务可以相互访问,但不同分组或命

    2024年02月07日
    浏览(54)
  • SpringCloudAlibaba微服务 【实用篇】| Nacos配置管理

    目录 一:Nacos配置管理 1. 统一配置管理 2. 配置热更新 3. 配置共享 4. 搭建Nacos集群 tips :前些天突然发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家,感兴趣的同学可以进行学习人工智能学习网站 Nacos除了可以做注册中心(前面已经讲了)

    2024年02月05日
    浏览(35)
  • 【微服务 SpringCloudAlibaba】实用篇 · Nacos注册中心

    微服务(5) 国内公司一般都推崇阿里巴巴的技术,比如注册中心,SpringCloudAlibaba也推出了一个名为Nacos的注册中心。 而我们现在差不多在学习SpringCloudAlibaba了,它与SpringCloud的关系就有点像SpringBoot与SpringMVC,SpringBoot引入SpringWeb框架就可以说是SpringMVC项目了,也可以说还是

    2024年02月08日
    浏览(28)
  • SpringCloudAlibaba微服务 【实用篇】| Nacos注册中心

    目录 一:Nacos注册中心 1. 认识和安装Nacos 2. Nacos快速入门 3. Nacos服务分级存储模型 ①Nacos服务分级存储模型 ②NacosRule负载均衡  ③根据权重负载均衡 4. Nacos环境隔离 二:Nacos和Eureka的对比 tips :前些天突然发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住

    2024年02月05日
    浏览(34)
  • 微服务框架SpringcloudAlibaba+Nacos集成RabbiMQ

    目前公司使用jeepluscloud版本,这个版本没有集成消息队列,这里记录一下,集成的过程;这个框架跟ruoyi的那个微服务版本结构一模一样,所以也可以快速上手。 配置类的东西做成一个公共的模块 rabbitmq模块: 哪一个服务模块需要消息队列,就在对应的yml文件中配置 rabbit链接

    2024年02月07日
    浏览(29)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包