Spring Cloud Alibaba - 05 Nacos 领域模型_NameSpac/Group/Cluster

简介: Spring Cloud Alibaba - 05 Nacos 领域模型_NameSpac/Group/Cluster

6735aa4777de402592fbe82e8b40ee3d.png


新增命名空间


5f62fed71c524cf9a7ca631818be670a.png

f32e4af52b0a453e89cb1092a8d01ae2.png

新增dev 和 prod , 记住命名空间ID


fef2478507ce4f99b86d59d50bb6bda1.png


工程改造


artisan-cloud-nacosclient-order

artisan-cloud-nacosclient-product

78e1284b19564f4cb6131be58a1403d4.png


c83749688c704b76b5f4111e86751ee5.png


Namespace资源隔离


我们来搞个例子: dev环境下的artisan-order-center 调用prod环境下的artisan-product-center


【改造点1 】

OrderInfoV2Controller 中 通过 nacos server获取 prod的 服务地址

 /**
         * 以下仅为演示,实际开发中并不会这样使用
         */
        // 从nacos server获取 product-info的地址
        List<ServiceInstance> instances = discoveryClient.getInstances("artisan-product-center");
        if (null == instances || instances.isEmpty()) {
            return "Prod微服务没有对应的实例可用";
        }
        // 从对应的服务实例中获取访问地址
        ServiceInstance serviceInstance = instances.get(0);
        String uri = serviceInstance.getUri().toString();
        log.info("从nacos server中获取的prod地址:", uri);
        // 发起远程Http调用
        ResponseEntity<ProductInfo> responseEntity = restTemplate.getForEntity(uri + "/selectProductInfoById/" + orderInfo.getProductNo(), ProductInfo.class);
        ProductInfo productInfo = responseEntity.getBody();


【改造点2 】

找到刚才的 命名空间ID 分别设置到 order 和 product

e62e0f32a17e44449e9995efe20cafc1.png

4acd91385b814e42996b11af4e3c9420.png

【测试】


c7f48a27a2cb49feb1723572bbf7ac13.pngNameSpace(默认的NameSpace是”public“ NameSpace可以进行资源隔离,比如dev环境下的NameSpace下的服务是调用不到prod的NameSpace下的微服务。 当然了,dev和prod最好不要共用一套nacos 注册中心。


Group


不同的Group之间不允许调用

我们把namepsace都切换成一样的, 设置不同的group 来测试下

ac24197f03014f8897b627d8353b160f.png


【测试】

启动服务,访问


c7f48a27a2cb49feb1723572bbf7ac13.png

Cluster


同一个Namespace下 + 同一个Group下, 不同Cluster 内的服务,可以互相访问


73f605442b7e42e496cc55567812ff62.png


启动服务,访问


b42c97a557e64ef2bfa5d796fbe301a1.png

可以发现 同一个Namespace下 + 同一个Group下, 不同Cluster 内的服务,可以互相访问。

但有个问题,如果全国多机房,虽然能通,但是网络上可能会有延迟,尽量确保同一个Cluster内的优先访问,这就需要编码实现了。


源码


https://github.com/yangshangwei/SpringCloudAlibabMaster

相关文章
|
14天前
|
SpringCloudAlibaba 负载均衡 Dubbo
【SpringCloud Alibaba系列】Dubbo高级特性篇
本章我们介绍Dubbo的常用高级特性,包括序列化、地址缓存、超时与重试机制、多版本、负载均衡。集群容错、服务降级等。
【SpringCloud Alibaba系列】Dubbo高级特性篇
|
14天前
|
存储 SpringCloudAlibaba Java
【SpringCloud Alibaba系列】一文全面解析Zookeeper安装、常用命令、JavaAPI操作、Watch事件监听、分布式锁、集群搭建、核心理论
一文全面解析Zookeeper安装、常用命令、JavaAPI操作、Watch事件监听、分布式锁、集群搭建、核心理论。
【SpringCloud Alibaba系列】一文全面解析Zookeeper安装、常用命令、JavaAPI操作、Watch事件监听、分布式锁、集群搭建、核心理论
|
15天前
|
SpringCloudAlibaba JavaScript Dubbo
【SpringCloud Alibaba系列】Dubbo dubbo-admin安装教程篇
本文介绍了 Dubbo-Admin 的安装和使用步骤。Dubbo-Admin 是一个前后端分离的项目,前端基于 Vue,后端基于 Spring Boot。安装前需确保开发环境(Windows 10)已安装 JDK、Maven 和 Node.js,并在 Linux CentOS 7 上部署 Zookeeper 作为注册中心。
【SpringCloud Alibaba系列】Dubbo dubbo-admin安装教程篇
|
15天前
|
SpringCloudAlibaba Dubbo Java
【SpringCloud Alibaba系列】Dubbo基础入门篇
Dubbo是一款高性能、轻量级的开源Java RPC框架,提供面向接口代理的高性能RPC调用、智能负载均衡、服务自动注册和发现、运行期流量调度、可视化服务治理和运维等功能。
【SpringCloud Alibaba系列】Dubbo基础入门篇
|
15天前
|
人工智能 前端开发 Java
Spring AI Alibaba + 通义千问,开发AI应用如此简单!!!
本文介绍了如何使用Spring AI Alibaba开发一个简单的AI对话应用。通过引入`spring-ai-alibaba-starter`依赖和配置API密钥,结合Spring Boot项目,只需几行代码即可实现与AI模型的交互。具体步骤包括创建Spring Boot项目、编写Controller处理对话请求以及前端页面展示对话内容。此外,文章还介绍了如何通过添加对话记忆功能,使AI能够理解上下文并进行连贯对话。最后,总结了Spring AI为Java开发者带来的便利,简化了AI应用的开发流程。
230 0
|
2天前
|
人工智能 自然语言处理 Java
Spring Cloud Alibaba AI 入门与实践
本文将介绍 Spring Cloud Alibaba AI 的基本概念、主要特性和功能,并演示如何完成一个在线聊天和在线画图的 AI 应用。
66 7
|
30天前
|
Java Nacos Sentinel
Spring Cloud Alibaba:一站式微服务解决方案
Spring Cloud Alibaba(简称SCA) 是一个基于 Spring Cloud 构建的开源微服务框架,专为解决分布式系统中的服务治理、配置管理、服务发现、消息总线等问题而设计。
236 13
Spring Cloud Alibaba:一站式微服务解决方案
|
2月前
|
存储 人工智能 Java
Spring AI Alibaba 配置管理,用 Nacos 就够了
本文通过一些实操案例展示了 Spring AI Alibaba + Nacos 在解决 AI 应用中一系列复杂配置管理挑战的方案,从动态 Prompt 模板的灵活调整、模型参数的即时优化,到敏感信息的安全加密存储。Spring AI Alibaba 简化了对接阿里云通义大模型的流程,内置 Nacos 集成也为开发者提供了无缝衔接云端配置托管的捷径,整体上极大提升了 AI 应用开发的灵活性和响应速度。
274 14
|
11天前
|
存储 网络协议 Nacos
高效搭建Nacos:实现微服务的服务注册与配置中心
Nacos(Dynamic Naming and Configuration Service)是阿里巴巴开源的一款动态服务发现、配置管理和服务管理平台。它旨在帮助开发者更轻松地构建、部署和管理分布式系统,特别是在微服务架构中。
182 81
高效搭建Nacos:实现微服务的服务注册与配置中心
|
28天前
|
JSON Java Nacos
SpringCloud 应用 Nacos 配置中心注解
在 Spring Cloud 应用中可以非常低成本地集成 Nacos 实现配置动态刷新,在应用程序代码中通过 Spring 官方的注解 @Value 和 @ConfigurationProperties,引用 Spring enviroment 上下文中的属性值,这种用法的最大优点是无代码层面侵入性,但也存在诸多限制,为了解决问题,提升应用接入 Nacos 配置中心的易用性,Spring Cloud Alibaba 发布一套全新的 Nacos 配置中心的注解。
159 11