【微服务】Nacos

devtools/2024/11/30 14:49:16/

一、安装

1、官网地址:https://nacos.io/download/nacos-server/
2、启动:找到bin目录下的startup.cmd双击启动,或者打开一个命令窗口输入:

java">startup.cmd -m standalone

双击启动后如下:可以访问控制台地址
在这里插入图片描述

访问后的地址如下:
在这里插入图片描述
登录:默认账号和密码都是nacos
在这里插入图片描述

二、注册

1、在cloud-demo父工程中添加spring-cloud-alibaba的管理依赖

java">            <!--nacos的管理依赖--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>2.2.5.RELEASE</version><type>pom</type><scope>import</scope></dependency>

2、注释掉order-service和user-service中原有的eureka依赖
在这里插入图片描述

3、添加nacos的客户端依赖

java">        <!--nacos的客户端依赖--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency>

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
成功负载均衡
在这里插入图片描述
在这里插入图片描述

三、Nacos服务分级存储模型

在这里插入图片描述

1、修改spplication.yml,添加如下内容
在这里插入图片描述
修改成HZ后直接可以启动userApplication和userApplication2,此时这两个就在HZ集群
在这里插入图片描述
修改成SH,在启动UserApplication3,此时UserApplication3就在SH集群。
2、服务台可以看到集群变化
在这里插入图片描述
在这里插入图片描述

四、修改集群负载均衡规则NacosRule

orderService同样设置在HZ集群(8081 8082),看调用时是否优先选择本地集群。
在这里插入图片描述
但是此发送请求发现默认选择轮询,即8081,8082,8083无论集群内还是集群外,都接收到了请求。如何解决:
1、修改order-service中的application.yml,设置集群为HZ(如上)
2、在order-service中设置负载均衡的IRule为NacosRule,这个规则就会优先寻找与自己相同集群的服务

java">userservice:ribbon:NFLoadBalancerRuleclassName: com.alibaba.cloud.nacos.ribbon.NacosRule

发送五条请求,发现都在同一集群的8081 8082之下,而8083暂时没有
在这里插入图片描述
在这里插入图片描述
NacosRule先选择本地集群,在本地集群中随机访问,将8081 8082停止服务,再发送请求:
在这里插入图片描述
在这里插入图片描述
3、注意将user-service的权重都设置为1

五、根据权重负载均衡

1、Nacos控制台可以设置实例的权重值,首先选中实例后面的编辑按钮
在这里插入图片描述
在这里插入图片描述
Nacos控制台可以设置实例的权重值,O~1之间同集群内的多个实例,权重越高被访问的频率越高权重设置为0则完全不会被访问

六、环境隔离-namespace

Nacos中服务存储和数据存储的最外层都是一个名为namespace的东西,用来做最外层隔离
在这里插入图片描述
1、创建命名空间
在这里插入图片描述
在这里插入图片描述

2、修改服务的命名空间
修改order-service的application.yml,添加namespase
在这里插入图片描述
在这里插入图片描述
此时再从orerservice发送请求,8081 8082 8083均收不到,因为被命名空间隔离了
在这里插入图片描述

七、Eureka和Nacos对比

在这里插入图片描述
设置临时实例(默认是true),停止orderservice,此时在dev中直接消失
再设置为非临时实例(false),重启orderservice,再次检查状态
在这里插入图片描述
在这里插入图片描述
此时再主动停止该服务,爆红后但还是存在,不会删除,重启后仍旧存在
在这里插入图片描述
1、Nacos与eureka的共同点

  • 都支持服务注册和服务拉取
  • 都支持服务提供者心跳方式做健康检测

2、Nacos与Eureka的区别

  • Nacos支持服务端主动检测提供者状态:临时实例采 用心跳模式,非临时实例采用主动检测模式
  • 临时实例心跳不正常会被剔除,非临时实例则不会被剔除
  • Nacos支持服务列表变更的消息推送模式,服务列表更新更及时
  • Nacos集群默认采用AP方式,当集群中存在非临时实例时,采用CP模式;Eureka采用AP方式

http://www.ppmy.cn/devtools/138221.html

相关文章

计算机网络习题解答--个人笔记(未完)

本篇文章为关于《计算机网络-自顶向下方法第七版》的阅读总结和课后习题解答(未完待续) 第二章&#xff1a; cookie&#xff1a;&#xff08;这里是比较老版本的HTTP&#xff0c;具体HTTPs是怎么实现的不是很清楚&#xff09;cookie的原理其实很简单。就是在HTTP消息头上又多…

去中心化物理基础设施网络(DePIN):重塑未来的基石

一、引言&#xff1a;DePIN的定义与背景 什么是DePIN&#xff1f; 去中心化物理基础设施网络&#xff08;DePIN&#xff0c;Decentralized Physical Infrastructure Networks&#xff09;是利用区块链和去中心化技术管理、优化和激励物理资源分配的一种新兴模式。与传统集中式…

Python入门(14)--数据分析基础

Python数据分析基础 &#x1f4ca; 1. NumPy基础操作 &#x1f522; 1.1 NumPy数组创建与操作 NumPy是Python中科学计算的基础库&#xff0c;提供了高效的多维数组对象和处理工具&#xff1a; import numpy as np# 创建数组 arr1 np.array([1, 2, 3, 4, 5]) arr2 np.zero…

做异端中的异端 -- Emacs裸奔之路3: 上古神键Hyper

谈一下快捷捷冲突的问题。 Emacs几乎穷尽所有组合键 我用下面命令&#xff0c;在Fundamental模式下&#xff0c;枚举所有绑定。 (defun keymap-lookup-test-fn(); printable keys(setq printable-chars (number-sequence 33 126))(setq i 0)(while (< i (length printable…

Qt 窗口操作函数(置顶、全屏,最大化最小化按钮设置等)

一、窗口置顶 与 取消置顶 void MainWindow::on_windowTopButton_clicked() {if (m_flags NULL){m_flags windowFlags();setWindowFlags(m_flags | Qt::WindowStaysOnTopHint);this->show();}else{m_flags NULL;setWindowFlags(m_flags);this->show();} }二、全屏显示…

RabbitMQ高级特性:TTL、死信队列与延迟队列

RabbitMQ高级特性&#xff1a;TTL、死信队列与延迟队列 RabbitMQ作为一款开源的消息代理软件&#xff0c;广泛应用于分布式系统中&#xff0c;用于实现消息的异步传递和系统的解耦。其强大的高级特性&#xff0c;包括TTL&#xff08;Time-To-Live&#xff09;、死信队列&#…

实现实时CPS安全的动态目标防御

论文标题&#xff1a;Enabling Moving Target Defense for Real-Time CPS Security&#xff08;实现实时CPS安全的动态目标防御&#xff09; 作者信息&#xff1a; Rajarshi Mukherjee&#xff0c;弗吉尼亚理工大学&#xff0c;电气与计算机工程系&#xff0c;阿灵顿&#xf…

数据库和缓存的数据一致性 -20241124

问题描述 一致性 缓存中有数据&#xff0c;缓存的数据值数据库中的值缓存中本没有数据&#xff0c;数据库中的值最新值&#xff08;有请求查询数据库时&#xff0c;会将数据写入缓存&#xff0c;则变为上面的“一致”状态&#xff09; “数据不一致”&#xff1a; 缓存的数据值…