阿里巴巴NACOS(2)- 为Spring Cloud提供服务注册发现及配置

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 上一篇文章我们提到了什么是Nacos以及Nacos的简单部署和使用方法,同时也介绍了阿里云的微服务引擎 MSE,这篇文章打算介绍一下如何在Spring Cloud中集成Nacos,并分别用本地自己搭建的Nacos和用阿里云MSE创建的Nacos实例来提供服务注册和发现功能。

作者:阿里云 MVP郦强

1、使用Nacos提供服务发现功能

1)首先我们要做的是写一个微服务,公司打车🚖项目有一块需求是关于用户的相关功能,例如:用户注册、登录、获取用户信息等,这样我们就需要创建一个用户微服务项目。
郦强1.png

创建用户微服务 MemberServer

2)在配置文件中,我们要指定Nacos server的地址。

郦强2.png

指定 Nacos Server 地址

3)在代码中,通过 Spring Cloud 原生注解 @EnableDiscoveryClient 开启服务注册发现功能。

郦强3.png

开启 EnableDiscoveryClient 注解

通过上面3个步骤,我们就把用户的微服务写好了,接着,我们还是重复上面的步骤创建一个订单微服务,提供打车项目中提交订单、订单结算、查询、状态转换等服务。
郦强4.png

创建订单微服务


同样,我们在配置文件中,指定Nacos server的地址,同时使用注解@EnableDiscoveryClient 开启服务注册发现功能。 郦强5.png

配置 Nacos Server 地址


郦强6.png

开启 EnableDiscoveryClient 注解

然后我们启动两个服务,就可以看到在Nacos控制台中的显示了。
郦强7.png

运行的微服务在服务列表中可以查看到

同样我们也可以把上面两个服务的Nacos server地址改成 阿里云微服务引擎的MSE地址,再重新启动两个服务,服务就展示在MSE上了。

2、使用Nacos作为服务配置中心

我们在开发项目,到测试到最终发布一版要经历3个环境,每个环境的配置都是不一样的,这样我们可以把配置文件用Nacos来进行管理,动态更新。之前公司都是用Spring Cloud的Config配置中心来完成的,这次可以用Nacos了😊

郦强8.png

Nacos配置列表

郦强9.png

配置文件

不过遗憾的是,在写本文的时候,阿里云MSE暂时只支持Nacos的服务注册和发现,配置中心暂时还没有,需要加载项目中的配置还需要开通使用阿里云的ACM(应用配置管理),所以目前来看 Nacos = MSE + ACM ,希望阿里云早日在MSE的Nacos中集成配置中心。
郦强10.png

阿里云应用配置管理首页

郦强11.png

应用配置管理开通页面

郦强12.png

开通成功

郦强13.png

新建配置页

郦强14.png

配置管理首页

郦强15.png

支持批量导入配置文件

3、总结

通过上面的介绍相信你对Spring Cloud中如何使用Nacos应该很清楚了,而且如果您之前项目用的是Eureka或者是Consul,替换成Nacos是很方便的,只要在配置文件的server地址改一下相应的参数即可。下一篇文章将介绍 部署Nacos的生产集群环境。

首发于简书。

相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
相关文章
|
1天前
|
监控 安全 Java
Spring cloud原理详解
Spring cloud原理详解
10 0
|
1天前
|
安全 Java 开发者
深入理解Spring Boot配置绑定及其实战应用
【4月更文挑战第10天】本文详细探讨了Spring Boot中配置绑定的核心概念,并结合实战示例,展示了如何在项目中有效地使用这些技术来管理和绑定配置属性。
9 1
|
3天前
|
Java Spring
Spring文件配置以及获取
Spring文件配置以及获取
10 0
|
5天前
|
消息中间件 负载均衡 Java
【Spring Cloud 初探幽】
【Spring Cloud 初探幽】
13 1
|
7天前
|
Java 开发者 微服务
Spring Cloud原理详解
【5月更文挑战第4天】Spring Cloud是Spring生态系统中的微服务框架,包含配置管理、服务发现、断路器、API网关等工具,简化分布式系统开发。核心组件如Eureka(服务发现)、Config Server(配置中心)、Ribbon(负载均衡)、Hystrix(断路器)、Zuul(API网关)等。本文讨论了Spring Cloud的基本概念、核心组件、常见问题及解决策略,并提供代码示例,帮助开发者更好地理解和实践微服务架构。此外,还涵盖了服务通信方式、安全性、性能优化、自动化部署、服务网格和无服务器架构的融合等话题,揭示了微服务架构的未来趋势。
31 6
|
9天前
|
Java 微服务 Spring
Spring Boot中获取配置参数的几种方法
Spring Boot中获取配置参数的几种方法
20 2
|
11天前
|
JSON Java Apache
Spring Cloud Feign 使用Apache的HTTP Client替换Feign原生httpclient
Spring Cloud Feign 使用Apache的HTTP Client替换Feign原生httpclient
|
11天前
|
消息中间件 安全 Java
在Spring Bean中,如何通过Java配置类定义Bean?
【4月更文挑战第30天】在Spring Bean中,如何通过Java配置类定义Bean?
20 1
|
11天前
|
Nacos
nacos 配置页面的模糊查询
nacos 配置页面的模糊查询