nacos技术分享

2022年05月15日 阅读数:9
这篇文章主要向大家介绍nacos技术分享,主要内容包括基础应用、实用技巧、原理机制等方面,希望对大家有所帮助。


1、主流注册中心、配置中心对比

目前市面上用的比较多的服务发现中心有:Nacos、Eureka、Consul和Zookeeper。
在这里插入图片描述
从上面对比能够了解到,Nacos做为服务发现中心,具有更多的功能支持项,且从长远来看Nacos在之后的版本会 支持SpringCLoud+Kubernetes的组合,填补 2 者的鸿沟,在两套体系下能够采用同一套服务发现和配置管理的解 决方案,这将大大的简化使用和维护的成本。另外,Nacos 计划实现 Service Mesh,也是将来微服务发展的趋 势。java

目前市面上用的比较多的配置中心有:Spring Cloud ConfigApolloNacosDisconf等。 因为Disconf再也不维护,下面主要对比一下Spring Cloud Config、Apollo和Nacos。
在这里插入图片描述mysql

从配置中心角度来看,性能方面Nacos的读写性能最高,Apollo次之,Spring Cloud Config依赖Git场景不适合开放的大规模自动化运维API。功能方面Apollo最为完善,nacos具备Apollo大部分配置管理功能,而Spring Cloud Config不带运维管理界面,须要自行开发。git

Nacos的一大优点是整合了注册中心、配置中心功能,部署和操做相比 Apollo都要直观简单,所以它简化了架构复杂度,并减轻运维及部署工做。github

综合来看,Nacos的特色和优点仍是比较明显的,下面咱们一块儿进入Nacos的世界。web

2、nacos

一、简介

Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。spring

Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施。sql

服务(Service)是 Nacos 世界的一等公民。Nacos 支持几乎全部主流类型的“服务”的发现、配置和管理。数据库

二、特性

Nacos主要提供如下四大功能浏览器

  1. 服务发现与服务健康检查 Nacos使服务更容易注册,并经过DNS或HTTP接口发现其余服务,Nacos还提供服务的实时健康检查,以防 止向不健康的主机或服务实例发送请求。
  2. 动态配置管理 动态配置服务容许您在全部环境中以集中和动态的方式管理全部服务的配置。Nacos消除了在更新配置时从新 部署应用程序,这使配置的更改更加高效和灵活。
  3. 动态DNS服务 Nacos提供基于DNS 协议的服务发现能力,旨在支持异构语言的服务发现,支持将注册在Nacos上的服务以 域名的方式暴露端点,让三方应用方便的查阅及发现。
  4. 服务和元数据管理 Nacos 能让您从微服务平台建设的视角管理数据中心的全部服务及元数据,包括管理服务的描述、生命周 期、服务的静态依赖分析、服务的健康状态、服务的流量管理、路由及安全策略。

这里动态配置管理的特性说明了Naocs的配置管理能力。安全

三、下载&启动

下载地址:https://github.com/alibaba/nacos/releases

nacos的默认端口是8848,须要保证8848默认端口没有被其余进程占用。

进入安装程序的bin目录:
Linux/Unix/Mac启动方式:
启动命令(standalone表明着单机模式运行,非集群模式): sh startup.sh -m standalone
关闭命令sh shutdown.sh

启动成功,可经过浏览器访问 http://127.0.0.1:8848/nacos ,使用默认用户名:nacos,默认密码:nacos 登陆便可打开主页面。

发布配置curl -X POST "http://127.0.0.1:8848/nacos/v1/cs/configs? dataId=nacos.cfg.dataId&group=test&content=HelloWorld"

获取配置
向nacos发布配置成功,就能够经过客户端从nacos获取配置信息,执行下边的命令: curl -X GET "http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=nacos.cfg.dataId&group=test"

经过代码获取配置

public static void main(String[] args) throws NacosException {
   
   

        SpringApplication.run(ProducerApplication.class, args);

        //nacos 地址
        String serverAddr = "localhost:8848";
        //Data Id
        String dataId = "service-producer-dev.yaml";
        //Group
        String group = "DEV_GROUP";
        Properties properties = new Properties();
        properties.put("serverAddr", serverAddr);
        ConfigService configService = NacosFactory.createConfigService(properties);
        //获取配置,String dataId, String group, long timeoutMs
        String content = configService.getConfig(dataId, group, 5000);
        System.out.println("-----------" + content + "-----------");
}        

四、外部mysql数据库支持

单机模式时nacos默认使用嵌入式数据库实现数据的存储,若想使用外部mysql存储nacos数据,须要进行如下步骤:

  1. 安装数据库,版本要求:5.6.5+ ,mysql 8 如下
  2. 初始化mysql数据库,新建数据库nacos_config,数据库初始化文件:${nacoshome}/conf/nacos- mysql.sql
  3. 修改${nacoshome}/conf/application.properties文件,增长支持mysql数据源配置(目前只支持 mysql),添加mysql数据源的url、用户名和密码。
spring.datasource.platform=mysql db.num=1
db.url.0=jdbc:mysql://11.162.196.16:3306/nacos_config?
characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true 
db.user=nacos_devtest db.password=youdontknow

3、配置管理

一、配置管理模型

对于Nacos配置管理,经过Namespace、group、Data ID可以定位到一个配置集。

配置集(Data ID)

在系统中,一个配置文件一般就是一个配置集,一个配置集能够包含了系统的各类配置信息,例如,一个配置集可 能包含了数据源、线程池、日志级别等配置项。每一个配置集均可以定义一个有意义的名称,就是配置集的ID即Data ID。

配置项

配置集中包含的一个个配置内容就是配置项。它表明一个具体的可配置的参数与其值域,一般以 key=value 的形 式存在。例如咱们常配置系统的日志输出级别(logLevel=INFO|WARN|ERROR) 就是一个配置项。

配置分组(Group)

配置分组是对配置集进行分组,经过一个有意义的字符串(如 Buy 或 Trade )来表示,不一样的配置分组下能够有 相同的配置集(Data ID)。当您在 Nacos 上建立一个配置时,若是未填写配置分组的名称,则配置分组的名称默 认采用 DEFAULT_GROUP 。配置分组的常见场景:可用于区分不一样的项目或应用,例如:学生管理系统的配置集 能够定义一个group为:STUDENT_GROUP。

命名空间(Namespace)

命名空间(namespace)可用于进行不一样环境的配置隔离。例如能够隔离开发环境、测试环境和生产环境,由于 它们的配置可能各不相同,或者是隔离不一样的用户,不一样的开发人员使用同一个nacos管理各自的配置,可经过 namespace隔离。不一样的命名空间下,能够存在相同名称的配置分组(Group) 或 配置集。

最佳实践

Nacos抽象定义了Namespace、Group、Data ID的概念,具体这几个概念表明什么,取决于咱们把它们当作什 么,这里推荐给你们一种用法:

Namespace:表明不一样环境,如开发、测试、生产环境。

Group:表明某项目,如XX医疗项目、XX电商项目

DataId:每一个项目下每每有若干个工程,每一个配置集(DataId)是一个工程的主配置文件

获取某配置集的代码:
须要指定:

一、nacos服务地址,必须指定
二、namespace,如不指定默认public
三、group,如不指定默认DEFAULT_GROUP
四、dataId,必须指定

二、命名空间管理

namespace 隔离设计

namespace 的设计是 nacos 基于此作多环境以及多租户(多个用户共同使用nacos)数据(配置和服务)隔离的。

命名空间管理

运行下边的程序测试新建的命名空间:

// 初始化配置服务, 
String serverAddr = "127.0.0.1:8848"; 
String namespace = "ee247dde‐d838‐425c‐b371‐029dab26232f"; 
//开发环境 
String group = "DEFAULT_GROUP"; 
//默认组 
String dataId = "nacos‐simple‐demo.yaml"; 
Properties properties = new Properties(); 
properties.put("serverAddr", serverAddr); 
properties.put("namespace", namespace); 
ConfigService configService = NacosFactory.createConfigService(properties); 
//获取配置,并输出控制台 
String content = configService.getConfig(dataId, group, 5000); System.out.println(content);

三、配置管理

Nacos支持基于Namespace和Group的配置分组管理,以便用户更灵活的根据本身的须要按照环境或者应用、模 块等分组管理微服务的大量配置,在配置管理中主要提供了配置历史版本、回滚、订阅者查询等核心管理能力。

一、配置列表

多配置格式编辑器

编辑DIFF

配置集导出

配置集导入

配置集克隆

二、历史版本

Nacos经过提供配置版本管理及其一键回滚能力,帮助用户改错配置的时候可以快速恢复,下降微服务系统在配置 管理上的可用性风险。

三、监听查询

Nacos提供配置订阅者即监听者查询能力,同时提供客户端当前配置的MD5校验值,以便帮助用户更好的检查配 置变动是否推送到 Client 端。

四、 登陆管理

修改默认用户名/密码方法
关闭登陆功能

4、注册中心

服务流量权重支持及流量保护
Nacos 为用户提供了流量权重控制的能力,同时开放了服务流量的阈值保护,以帮助用户更好的保护服务服务提 供者集群不被意外打垮。以下图因此,能够点击实例的编辑按钮,修改实例的权重。若是想增长实例的流量,能够 将权重调大,若是不想实例接收流量,则能够将权重设为0。

服务元数据管理
Nacos提供多个维度的服务元数据的暴露,帮助用户存储自定义的信息。这些信息都是以K-V的数据结构存储,在 控制台上,会以k1=v1,k2=v2这样的格式展现。相似的,编辑元数据能够经过相同的格式进行。例如服务的元数据 编辑,首先点击服务详情页右上角的“编辑服务”按钮,而后在元数据输入框输入:version=1.0。

服务优雅上下线
Nacos还提供服务实例的上下线操做,在服务详情页面,能够点击实例的“上线”或者“下线”按钮,被下线的实例, 将不会包含在健康的实例列表里。