Nacos

SpringCloud Alibaba Nacos是一个狗抑郁构建云原生应用的动态服务发现、配置管理和服务管理平台。

Nacos:Dynamic Naming and Configuration Service

Nacos是注册中心+配置中心=Eureka+Bus+Config

Nacos安装并运行

本地环境必须有Java8以上版本和maven环境,先从官网上下载Nacos,然后解压安装包,直接在bin目录下的startup.cmd,运行成功后直接访问http://localhost:8848/nacos。用户名密码都是nacos,然后登陆到控制台。

服务注册与发现

如果要在您的项目中使用 Nacos 来实现服务注册/发现,使用 group ID 为 com.alibaba.cloud 和 artifact ID 为 spring-cloud-starter-alibaba-nacos-discovery的 starter。


<dependencies>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</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>
</dependencies>

如果不想使用 Nacos 作为您的服务注册与发现,可以将 spring.cloud.nacos.discovery 设置为 false。一般使用时设置成true。
application.yml

server:
port: 9001
spring:
application:
name: nacos-payment-provider
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848 management:
endpoints:
web:
exposure:
include: '*'

之后输入localhost:8848/nacos进入web端nacos管理平台,然后可以在服务列表中看到注册成功的实例名称。

注册到Nacos中有服务提供者和服务消费者。消费者调用提供者的方式要稍微复杂一些。
因为Nacos的依赖中默认引入了Ribbon服务调用和负载均衡工具,因为在 Consumer 端需要去调用 Provider 端提供的REST 服务。例子中我们使用最原始的一种方式, 即显示的使用 LoadBalanceClient 和 RestTemplate 结合的方式来访问。

服务提供方Controller

@RestController
public class PayController { @GetMapping(value = "/echo/{string}")
public String echo(@PathVariable String string) {
return "9001 nacos payment" + string;
}
}

服务提供方配置

server:
port: 9002
spring:
application:
name: nacos-payment-provider
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848 management:
endpoints:
web:
exposure:
include: '*'

消费方的pomxml和提供者的一样,这里不再显示。
消费者的配置文件

server:
port: 83
spring:
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
application:
name: nacos-order83-consumer management:
endpoints:
web:
exposure:
include: '*'
# 消费者将要访问的微服务名称(服务提供者)
service-url:
nacos-user-service: http://nacos-payment-provider

消费方的配置类

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

消费者的controller

@RestController
public class OrderController {
@Resource
private RestTemplate restTemplate;
@Value("{service-url.nacos-user-service}")
private String SERVICE_URL; @GetMapping(value = "/consumer/echo/{string}")
public String echo(@PathVariable String string) {
return restTemplate.getForObject("http://nacos-payment-provider/echo/" + string,String.class);
} }

启动两个服务,然后访问消费者的localhost:83/consumer/echo/参数
输出“9002 nacos payment,参数”

服务注册中心对比

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

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

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

Nacos引入中,默认包含有Ribbon相关依赖,因此负载均衡算法包含轮询,随机,加权等。

Nacos Config

使用Spring Cloud Alibaba Nacos Config,可基于SpringCloud的编程模式快速接入Nacos配置管理功能。

Nacos同SpringCloud-Config一样,在项目初始化时,要保证先从配置中心进行配置拉取,拉取配置后,才能保证项目的正常启动。

SpringBoot中配置文件是存在优先级顺序的,bootstrap优先级高于application。

引入相关依赖

<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>

配置文件

application.yml

spring:
profiles:
active: dev # 表示开发环境
#active: test # 表示测试环境
#active: info

bootstrap.yml

# nacos配置
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格式的配置

动态获取配置

在自定义的属性值所在的类上添加@RefreshScope:动态获取并刷新配置

@Value("${配置项的名}"):获取配置文件中指定配置项的值
controller

@RestController
@RefreshScope //动态刷新
public class ConfigClientController {
@Value("${config.info}")
private String configInfo; @GetMapping("config/info")
public String getConfigInfo(){
//将nacos控制平台上的配置信息返回
return configInfo;
}
}

启动nacos,主启动类启动。

进入localhost:8848/nacos/,登录nacos后,点击配置列表,选择添加配置。

这里需要注意的是,配置文件名的命名规范。

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

将这三个属性值合并起来就是配置中心新建的配置文件的DataIdnacos-config-client-dev.yaml。只有这样动态刷新配置时才能识别。

这时配置好config.info的值后,访问controller指定路径。结果如下。

将配置文件中的版本改成2后重新访问。


如果配置中心和当前应用的配置文件中配置了相同的项,优先使用配置中心的配置。

{"msg":"success","empname":"zhangsan","code":0,"age":24}

Nacos的名称空间

类似于Java里面的包名和类名,最外层的namespace是可以用于区分部署环境的,GroupID和DataID用于区分不同的对象。

Nacos默认名称空间是public,Namespace主要用来实现隔离。

比如说现在有三个环境:开发,测试和生产环境,我们可以创建三个NameSpace,不同的Namespace之间是相互隔离的。

Service是微服务,一个Service可以包含多个集群,Nacos默认几圈是DEFAULT,集群Cluster是对指定微服务的一个虚拟划分。

将Service微服务分别部署在杭州机房和北京机房。

最后是Instance是微服务的实例。

指定spring.profile.active和配置文件的DataID 来使不同的环境下读取不同的配置

默认空间+默认分组+新建dev+test两个DataID。

通过`spring.profile.active属性就能进行火哥环境下配置文件的读取。

SpringCloud Alibaba Nacos服务注册与配置管理的更多相关文章

  1. SpringCloud Alibaba Nacos 服务注册

    业务服务接入Nacos服务治理中心 启动Nacos访问地址为:http://101.200.201.195:8848/nacos/ 创建bom工程用于管理依赖(下方附加源码地址) 准备工作完成后开始接 ...

  2. Spring Cloud Alibaba | Nacos服务注册与发现

    目录 Spring Cloud Alibaba | Nacos服务注册与发现 1. 服务提供者 1.1 pom.xml项目依赖 1.2 配置文件application.yml 1.3 启动类Produ ...

  3. Spring Cloud Alibaba Nacos 服务注册与发现功能实现!

    Nacos 是 Spring Cloud Alibaba 中一个重要的组成部分,它提供了两个重要的功能:服务注册与发现和统一的配置中心功能. 服务注册与发现功能解决了微服务集群中,调用者和服务提供者连 ...

  4. SpringCloud Alibaba Nacos 服务治理中心

    目录 一.什么是Nacos? 二.Nacos能干吗? 三.Nacos关键特性 四.Nacos中的基本概念 五.如何安装部署Nacos? 六.Nacos数据持久化 一.什么是Nacos? 英文全称Dyn ...

  5. SpringCloud之Nacos服务注册(十八)

    一 服务提供配置 pom.xml <dependency> <groupId>org.springframework.boot</groupId> <arti ...

  6. springcloudalibaba与nacos服务注册流程图

    springboot + springcloud + springcloudalibaba + nacos 服务注册流程图: springboot ①WebApplicationContext ②st ...

  7. Nacos笔记01——使用Nacos作为SpringCloud项目的服务注册中心

    前言 刚学SpringCloud时使用eureka作为服务注册中心,随着网飞公司eureka2.x不再更新,以及最近在公司实习接触到的SpringCloud项目是使用Nacos来做服务注册中心的,所以 ...

  8. Spring Cloud Alibaba(一) 如何使用nacos服务注册和发现

    Nacos介绍 Nacos 致力于帮助您发现.配置和管理微服务.Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现.服务配置.服务元数据及流量管理. Nacos 帮助您更敏捷和容易地构 ...

  9. Alibaba Nacos 学习(三):Spring Cloud Nacos Discovery - FeignClient,Nacos 服务注册与发现

    Alibaba Nacos 学习(一):Nacos介绍与安装 Alibaba Nacos 学习(二):Spring Cloud Nacos Config Alibaba Nacos 学习(三):Spr ...

随机推荐

  1. elastic-job分布式调度与zookeeper的简单应用

    一.对分布式调度的理解 调度->定时任务,分布式调度->在分布式集群环境下定时任务这件事 Elastic-job(当当⽹开源的分布式调度框架) 1 定时任务的场景 定时任务形式:每隔⼀定时 ...

  2. JS复习之深浅拷贝

    一.复习导论(数据类型相关) 想掌握JS的深浅拷贝,首先来回顾一下JS的数据类型,JS中数据类型分为基本数据类型和引用数据类型. 基本数据类型是指存放在栈中的简单数据段,数据大小确定,内存空间大小可以 ...

  3. Tensorflow学习笔记No.11

    图像定位 图像定位是指在图像中将我们需要识别的部分使用定位框进行定位标记,本次主要讲述如何使用tensorflow2.0实现简单的图像定位任务. 我所使用的定位方法是训练神经网络使它输出定位框的四个顶 ...

  4. 九、TestNG超时测试

    "超时"表示如果单元测试花费的时间超过指定的毫秒数,那么TestNG将会中止它并将其标记为失败. 使用属性 timeOut = 参数(1s*1000) package com.lc ...

  5. mysql 8.0 主从复制配置

    背景: 主库: 192.168.211.128 从库: 192.168.211.129 一.关闭防火墙 [root@node01 ~]# systemctl disable firewalld [ro ...

  6. AOP基本概念

    连接点joinpoint(类中所有方法) 切入点pointcut(缺少共性代码的方法) 通知advice(被抽取的共性功能的代码逻辑,通知有位置区分,也就是从切入点方法中被抽取代码的前面还是后面抽象出 ...

  7. LLVM程序分析日记之插桩BranchInst

    1. splitblockandinsertifthenelse() 一个代码例子:StackOverflow 2. SplitBlockAndInsertIfThen() 或者仅仅想插桩if the ...

  8. 使用 vue 仿写的一个购物商城

    在学习了 vue 之后,决定做一个小练习,仿写了一个有关购物商城的小项目.下面就对项目做一个简单的介绍. 项目源码: github 项目的目录结构 -assets 与项目有关的静态资源,包括 css, ...

  9. App性能测试揭秘(Android篇)

    阿里云 云原生应用研发平台EMAS 李嘉华(千瞬) 简介: 性能测试在移动测试领域一直是一个大难题,它最直观的表现是用户在前台使用 App 时的主观体验,然而决定体验优劣的背后,涉及到了许许多多的技术 ...

  10. python pip命令的安装与实验安装scrapy

    大家在使用python时候,很多时候导入模块都会发现该模块不存在,那么我们就需要下载安装,可是有时候安装会出现各种问题,大家回去请教别人,大部分程序员会回答你:pip install 什么等,可是你p ...