我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Nacos框架与原理之Nacos的参数

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Nacos框架与原理之Nacos的参数

前言:

Nacos 中的参数有很多,如:命名空间、分组名、服务名、保护阈值、服务路由类型、临时实例等,那这些参数都是什么意思?又该如何设置?接下来我们一起来盘它。

1.命名空间

在 Nacos 中通过命名空间(Namespace)+ 分组(Group)+服务名(Name)可以定位到一个唯一的服务实例。 

 命名空间(Namespace):Nacos 服务中最顶层、也是包含范围最广的概念,用于强制隔离类似环境或租户等场景。Nacos 的服务也需要使用命名空间来进行隔离 命名空间在 Nacos 控制台的一级目录里可以找到,如下图所示: 

 在服务列表中也能看到命名空间的身影,如下图所示: 

1.1 命名空间用法

命名空间默认为 public,在项目开发中,如果不指定命名空间,那么会使用默认值 public。官方推荐使用运行环境来定义命名空间,如生产版本可使用 public,开发版可定义为 private。 在项目开发中,可通过配置“spring.cloud.nacos.discovery.namespace”来定义命名空间,如下图所示: 

1.2 注意事项

命名空间在使用前,必须先在控制台新建命名空间,如下图所示: 

 如果在控制台没有新建命名空间,直接在项目中使用的话,是不能将服务成功的注册到 Nacos 中的,如下在项目中配置了一个未新建的 dev 命名空间,如下图所示: 

 然后启动项目,此时会发现,在 Nacos 控制台的服务列表中一直刷新不到任何服务实例,如下图所示: 

2.分组名

分组名(Group):Nacos 中次于命名空间的⼀种隔离概念,区别于命名空间的强制隔离属性,分组属于⼀个弱隔离概念,主要用于逻辑区分⼀些服务使用场景或不同应用的同名服务,最常用的情况主要是同⼀个服务的测试分组和生产分组、或者将应用名作为分组以防止不同应用提供的服务重名。 分组名在 Nacos 控制台的服务列表中可以看到,如下图所示: 

 分组名默认为 DEFAULT_GROUP,在项目中可通过“spring.cloud.nacos.discovery.group”来设置,如下图所示: 

 此项可省略,省略时的默认值为 DEFAULT_GROUP。 分组名可以直接在项目中使用,无需像命名空间那样,在使用前还要在控制台中新建,设定了分组名之后,刷新服务列表就可以看到新的分组名称了,如下图所示: 

3.服务名

服务名(Name):该服务实际的名字,⼀般用于描述该服务提供了某种功能或能力。 通常推荐使用由运行环境作为命名空间、应用名作为分组,服务功能作为服务名的组合来确保该服务的天然唯⼀性,当然使用者可以忽略命名空间和分组,仅使用服务名作为服务唯⼀标示,这就需要使用者在定义服务名时额外增加自己的规则来确保在使用中能够唯⼀定位到该服务而不会发现到错误的服务上。 服务名在项目中可以通过“spring.application.name”来指定,如下图所示: 

4.保护阈值

健康保护阈值(ProtectThreshold):为了防止因过多实例故障,导致所有流量全部流入剩余实例,继而造成流量压力将剩余实例被压垮形成雪崩效应。应将健康保护阈值定义为⼀个 0 到 1 之间的浮点数。当域名健康实例数占总服务实例数的比例小于该值时,无论实例是否健康,都会将这个实例返回给客户端。这样做虽然损失了⼀部分流量,但是保证了集群中剩余健康实例能正常工作 简单来说,保护阈值是一个 0-1 的浮点值,保护阈值是允许集群中健康实例占比的最小值,如果实际健康实例的占比小于或等于设置的保护阈值时,就会触发阈值保护,如下图所示,设置保护阈值为 0.75: 

 停掉唯一的健康实例,集群的健康实例占比降成了 0%,小于设置的保护阈值 0.75(75%),此时就会触发阈值保护,

如下图所示: 

5.服务路由类型

服务路由类型的设置如下图所示: 

 它是用来设置服务的路由策略的,默认值为 none。如果设置此值为 label(标签)模式,需要设置相应的标签表达式来匹配实例选择器(Selector),通过实例选择器可以完成自定义负载均衡策略,比如我们可以自定义实例选择器,实现就近访问的负载均衡策略,这样消费者在调用时,会优先调用离自己比较近的 IP 节点,从而实现更高效的服务调用。

6.权重

权重(Weight):实例的级别配置。权重为浮点数,范围为 0-10000。权重越大,分配给该实例的流量越大。 它是针对服务实例进行设置的,

如下图所示: 

7.临时实例

在 Nacos 中服务实例有两种(类型):持久化实例和临时实例(也叫非持久化实例)。当控制台中“临时实例”为 true 时,表示此服务为临时实例,

如下图所示: 

7.1 临时实例 VS 持久化实例

临时实例和持久化实例的区别主要有以下两点:

  • 临时实例在非健康状态下会被自动剔除,而持久化实例不会被自动剔除。
  • 临时实例的健康状况是 Nacos 客户端以固定频率(5s一次)上报给 Nacos 服务器端的,而持久化实例是 Nacos 服务器端主动探测的。

7.2 实例类型设置

在项目开发中,可以通过设置“spring.cloud.nacos.discovery.ephemeral”来指定服务的实例类型,默认为临时实例,也就是默认“spring.cloud.nacos.discovery.ephemeral=true”。如果要设置持久化实例,需要设置“spring.cloud.nacos.discovery.ephemeral”设置为 false,

如下图所示: 

7.3 注意事项

服务的实例类型一旦确定之后,整个生命周期内不允许被修改,如果试图修改实例类型会提示如下错误: 

总结

Nacos 中通过命名空间 + 分组名 + 服务名可以定位到一个唯一实例,通常推荐使用由运行环境作为命名空间、应用名作为分组,服务功能作为服务名的组合来定义服务。保护阈值是牺牲⼀部分流量,保证集群中剩余健康实例能正常工作的一种手段。服务路由类型和权重都是用来定义 Nacos 路由规则的,而临时实例和持久化实例是 Nacos 中的两种实例类型。

到此这篇关于Nacos框架与原理之Nacos的参数的文章就介绍到这了,更多相关Nacos的参数内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Nacos框架与原理之Nacos的参数

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android Activity之间相互调用与传递参数的原理与用法分析

本文实例讲述了Android Activity之间的相互调用与传递参数。分享给大家供大家参考,具体如下: Activity之间是如何调用的 在javaWeb程序中,jsp与jsp之间的调用是通过重定向完成的,而在Android中,Activ
2022-06-06

koa框架的原理、功能,与基本使用方法概述 原创

这篇文章主要介绍了koa框架的原理、功能,与基本使用方法,结合实例形式分析了koa框架的基本功能、原理、使用方法与相关注意事项,需要的朋友可以参考下
2023-05-17

MySQL ORM框架的数据库清理与压缩

MySQL ORM框架(如Django ORM、SQLAlchemy等)通常提供了一种高级别的抽象,使得开发者能够更方便地与数据库进行交互。然而,有时我们可能需要对数据库进行清理和压缩,以释放空间、提高性能或修复数据完整性问题。以下是一些建
MySQL ORM框架的数据库清理与压缩
2024-10-05

MySQL 原理与优化之原数据锁的应用

mysql 中原数据锁是系统自动控制添加的,对于用户来说无需显示调用,当我们使用一张表的时候就会加上原数据锁。原数据锁的作用是为了保护表原数据的一致性,如果在表上有活动事务的时候,不可以对元数据进行写入操作。也就是为了避免DML 和DDL
2022-08-14

学习CSS的基本框架构建原理与实现方法

随着互联网的快速发展,网页的设计越来越受到重视。而CSS作为网页设计的重要部分之一,其制作网页基本框架的原理和实现方法也就备受关注了。本文将通过具体代码示例讲解CSS制作网页基本框架的原理与实现方法。一、HTML和CSS基本语法在了解C
学习CSS的基本框架构建原理与实现方法
2024-01-16

解密CSS框架越权访问的原理与防范措施

解密CSS框架越权访问的原理与防范措施随着互联网的迅猛发展,网页设计逐渐成为一门重要的技术。为了提高效率和统一样式,很多开发者使用CSS框架来快速构建网页。然而,一些不法分子利用CSS框架的漏洞实施越权访问,造成严重的安全风险。本文将解密
解密CSS框架越权访问的原理与防范措施
2024-01-16

Silverlight中导航框架与动态加载的原理是什么

今天就跟大家聊聊有关Silverlight中导航框架与动态加载的原理是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1. Silverlight 3 的导航框架简介Silverl
2023-06-17

Java集合框架进阶指南:揭秘框架的底层原理,打造高效的数据结构

Java集合框架是一个强大的工具,可以帮助你管理和操作数据。如果你想深入了解集合框架,本文将为你揭秘框架的底层原理,并指导你如何打造高效的数据结构。
Java集合框架进阶指南:揭秘框架的底层原理,打造高效的数据结构
2024-02-22

大数据处理领域的经典框架:MapReduce详解与应用

MapReduce是一种经典的大数据处理框架,最早由Google提出,并在后来由Apache Hadoop项目开发和推广。MapReduce的设计目标是为了方便并行处理大规模数据集。MapReduce框架分为两个主要步骤:Map和Reduc
2023-10-11

C++ 函数参数详解:传入机制的底层原理与应用场景

c++++ 函数参数传递机制:值传递:创建传递值副本,原始变量不受影响。引用传递:直接操作原始变量,允许修改。指针传递:通过地址访问变量,可修改指向变量或指向其他变量。应用场景:值传递:不修改数据的函数,如打印、计算。引用传递:修改数据的函
C++ 函数参数详解:传入机制的底层原理与应用场景
2024-04-27

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录