微服务服务发现、配置和管理之-SpringBoot整合Nacos实现服务发现

本文详细介绍了如何一步步配置和使用Nacos进行服务发现与注册。首先,下载并启动Nacos服务器,然后在Spring Boot应用中引入Nacos Discovery依赖,并配置Nacos服务器地址。接着,通过注解注入NamingService,实现服务查询。启动应用并调用API获取服务实例,初始为空。最后,通过Nacos OpenAPI注册服务,再次查询时即可得到服务实例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

完整示例代码参考:

一、下载 Nacos 并启动 Nacos server。参考 Nacos快速开始

二、添加坐标 可参考 mvnrepository

<dependency>
    <groupId>com.alibaba.boot</groupId>
    <artifactId>nacos-discovery-spring-boot-starter</artifactId>
    <version>${latest.version}</version>
</dependency>

三、在 application.properties 中配置 Nacos server 的地址:

nacos.config.server-addr=127.0.0.1:8848

四、使用 @NacosInjected 注入 Nacos 的 NamingService 实例:

@Controller

@RequestMapping("discovery")

public class DiscoveryController {

    @NacosInjected

    private NamingService namingService;

    @RequestMapping(value = "/get", method = GET)

    @ResponseBody

    public List<Instance> get(@RequestParam String serviceName) throws NacosException {

        return namingService.getAllInstances(serviceName);

    }
}

@SpringBootApplication

public class NacosDiscoveryApplication {

    public static void main(String[] args) {

        SpringApplication.run(NacosDiscoveryApplication.class, args);

    }
}

五、启动 NacosDiscoveryApplication,调用 curl http://localhost:8080/discovery/get?serviceName=example,此时返回为空 JSON 数组[]

六、通过调用 Nacos Open API 向 Nacos server 注册一个名称为 example 服务

curl -X PUT 'http://127.0.0.1:8848/nacos/v1/ns/instance?serviceName=example&ip=127.0.0.1&port=8080'

七、再次访问 curl http://localhost:8080/discovery/get?serviceName=example,此时返回内容为

[
  {
    "instanceId": "127.0.0.1-8080-DEFAULT-example",
    "ip": "127.0.0.1",
    "port": 8080,
    "weight": 1.0,
    "healthy": true,
    "cluster": {
      "serviceName": null,
      "name": "",
      "healthChecker": {
        "type": "TCP"
      },
      "defaultPort": 80,
      "defaultCheckPort": 80,
      "useIPPort4Check": true,
      "metadata": {}
    },
    "service": null,
    "metadata": {}
  }
]

 

 

Spring Boot 整合 Nacos 通常是为了实现服务发现配置管理的功能,特别是当涉及到微服务架构中的 RPC (Remote Procedure Call) 服务通信时,Nacos 的服务注册与发现功能非常有用。以下是集成的基本步骤: 1. 添加依赖:在你的 Maven 或 Gradle 项目中添加 Spring Cloud 的 Alibaba 开源组件依赖,如 ribbon、spring-cloud-alibaba-nacos-discovery 等。 ```xml <!-- Maven --> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <!-- Gradle --> implementation 'com.alibaba.cloud:spring-cloud-starter-alibaba-nacos-discovery' ``` 2. 配置 Nacos:在 application.properties 或 application.yml 文件中加入 Nacos 的地址、命名空间以及服务的注册信息。 ```properties spring.application.name=your-service-name spring.cloud.nacos.discovery.server-addr=nacos-server-url spring.cloud.nacos.discovery.namespace=your-namespace ``` 3. 使用 @EnableDiscoveryClient 注解启用服务发现:在你的主入口类上添加此注解,Spring Boot 将自动发现并注册到 Nacos 中。 ```java @SpringBootApplication @EnableDiscoveryClient public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 4. RPC 服务发现:对于RPC服务,比如Dubbo或者RSocket,需要配合其他模块如Spring Cloud AlibabA Feign、Rsocket Gateway等。例如使用Feign进行远程调用时,只需要配置一下Feign客户端指向Nacos的服务列表即可。 5. 实现服务的自动路由:当有新的实例加入或移除时,Nacos 会实时更新,你的服务调用将会自动导向可用的服务实例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值