【Nacos系列第二篇】-Nacos之Spring Boot Discovery

简介: 作者:毕来生 【Nacos系列第二篇】-Nacos之Spring Boot Discovery

作者:毕来生

前言

​ 个人比较看好Spring Cloud Alibaba家族。此系列以Nacos为主题,从Spring、Spring boot、Spring Cloud多个方面逐步进行演示,源码解读。目前来看官方文档还有待完善。网络上除了官网外缺少Nacos系列文章。都是零零散散的知识点。如此系列文章哪里写的有不周全,错误之处。欢迎大家指正。谢谢。

​ 因公众号排版问题,可能会有代码显示不完整,请使用电脑版微信内置浏览器/复制链接到浏览器中。

​ 上一篇已经描述了Nacos中Spring Discovery 以及Config演示。 因大家在工作中逐步以Spring boot、Spring Cloud为主进行开发。我们接下来会以这两个为核心演示详解。


Nacos架构图

在这里插入图片描述

工程结构

上面说了那么多,现在先来看一下我们的Spring boot Nacos Discovery工程结构(Windows下演示)

Spring Boot版本:2.1.2.RELEASE

在这里插入图片描述

附上与普通创建的Spring boot工程不同点

NacosDiscoveryController(新增)

package org.nacos.springboot.controller;

import com.alibaba.nacos.api.annotation.NacosInjected;
import com.alibaba.nacos.api.exception.NacosException;
import com.alibaba.nacos.api.naming.NamingService;
import com.alibaba.nacos.api.naming.pojo.Instance;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;

import java.util.List;

@Controller
@RequestMapping("nacos")
public class NacosDiscoveryController {

    @NacosInjected
    private NamingService namingService;

    @RequestMapping("/instance")
    @ResponseBody
    public List<Instance> getAllInstance(@RequestParam String servicename) throws NacosException {
        return namingService.getAllInstances(servicename);
    }

}

application.properties

nacos.discovery.server-addr=127.0.0.1:8848

pom.xml

<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba.boot</groupId>
            <artifactId>nacos-discovery-spring-boot-starter</artifactId>
            <version>0.2.1</version>
        </dependency>
    </dependencies>

上述内容就是我们在创建好Spring Boot工程结构后增加/调整内容。

演示步骤

1、启动好我们的Nacos

2、启动 BilaishengNacosSpringbootApplication

3、调用 curl http://localhost:8080/nacos/instance?serviceName=nacos-spring,此时返回为空 JSON 数组[]

4、官方告诉你说执行下方命令。模拟请求(别看就这一句话。很坑)

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

#### 踩坑之旅

环境:Windows7 (想着演示用,偷偷懒。结果把自己坑了。)我们来说一下有多坑。

  • 直接cmd。提示curl 不是内部或外部命令,也不是可运行的程序 。
  • 好吧我们下载一个。官网地址:https://curl.haxx.se/。根据系统选择不同的版本。我下载的windows64. 解压。
  • 解压下载好的文件,拷贝curl.exe文件到C:WindowsSystem32
  • 然后就可以在DOS窗口中任意位置,使用curl命令了。但是你以为这就结束了?告诉你,不可能!!!

在这里插入图片描述

​ 纠结了很久,不知道为什么。百度说的一大堆都是废话。没有一个有用的。但是这点困难怎么会难住我们呢? 我们一条路走不通我们就换一条路嘛。给大家几个解决方案。

1、通过jdk里面自带的jconsole模拟请求(没玩过的同学可以百度一下)

2、PostMan

3、百度了一个模拟请求工具。附下图。

在这里插入图片描述

上面搞定了后。我们继续向下玩耍。

我们来访问一下如下地址。http://localhost:8080/nacos/instance?servicename=nacos-spring

在这里插入图片描述

以上就是我们Spring Boot Discovery的一个Demo例子。参考官网Demo。


喜欢就关注我吧

在这里插入图片描述

目录
相关文章
|
3月前
|
Cloud Native Java Nacos
微服务时代的新宠儿!Spring Cloud Nacos实战指南,带你玩转服务发现与配置管理,拥抱云原生潮流!
【8月更文挑战第29天】Spring Cloud Nacos作为微服务架构中的新兴之星,凭借其轻量、高效的特点,迅速成为服务发现、配置管理和治理的首选方案。Nacos(命名和配置服务)由阿里巴巴开源,为云原生应用提供了动态服务发现及配置管理等功能,简化了服务间的调用与依赖管理。本文将指导你通过五个步骤在Spring Boot项目中集成Nacos,实现服务注册、发现及配置动态管理,从而轻松搭建出高效的微服务环境。
217 0
|
19天前
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
34 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
1月前
|
缓存 NoSQL Java
Springboot自定义注解+aop实现redis自动清除缓存功能
通过上述步骤,我们不仅实现了一个高度灵活的缓存管理机制,还保证了代码的整洁与可维护性。自定义注解与AOP的结合,让缓存清除逻辑与业务逻辑分离,便于未来的扩展和修改。这种设计模式非常适合需要频繁更新缓存的应用场景,大大提高了开发效率和系统的响应速度。
44 2
|
3月前
|
Cloud Native Java Nacos
Spring Cloud Config、Apollo、Nacos和Archaius对比
这篇文章对比了Spring Cloud Config、Apollo、Nacos和Archaius这四种配置中心的适应场景、优缺点。文中讨论了它们的功能特点,例如Spring Cloud Config的集中化配置管理和动态刷新能力,Apollo的实时配置推送和权限治理,Nacos的服务发现和管理功能,以及Archaius的动态配置更新能力。文章指出选择配置中心应根据项目需求和架构来决定,并提供了一个对比图来帮助读者更直观地理解这些工具的差异。
64 1
Spring Cloud Config、Apollo、Nacos和Archaius对比
|
3月前
|
运维 Java Nacos
Spring Cloud应用框架:Nacos作为服务注册中心和配置中心
Spring Cloud应用框架:Nacos作为服务注册中心和配置中心
|
3月前
|
Dubbo Java Nacos
【实战攻略】破解Dubbo+Nacos+Spring Boot 3 Native打包后运行异常的终极秘籍——从零开始彻底攻克那些让你头疼不已的技术难题!
【8月更文挑战第15天】Nacos作为微服务注册与配置中心受到欢迎,但使用Dubbo+Nacos+Spring Boot 3进行GraalVM native打包后常遇运行异常。本文剖析此问题及其解决策略:确认GraalVM版本兼容性;配置反射列表以支持必要类和方法;采用静态代理替代动态代理;检查并调整配置文件;禁用不支持的功能;利用日志和GraalVM诊断工具定位问题;根据诊断结果调整GraalVM配置。通过系统排查方法,能有效解决此类问题,确保服务稳定运行。
87 0
|
4月前
|
消息中间件 Java 数据库连接
理解java的springboot+mybatisplus+dubbo+nacos+kafka这一套技术栈
理解java的springboot+mybatisplus+dubbo+nacos+kafka这一套技术栈
85 0
|
5月前
|
Java Nacos 微服务
Spring Cloud微服务在Windows本地开发时禁用Nacos注册中心注册
Spring Cloud微服务在Windows本地开发时禁用Nacos注册中心注册
|
5月前
springboot2.4.5使用pagehelper分页插件
springboot2.4.5使用pagehelper分页插件
137 0
|
Java Nacos
SpringBoot 整合 Nacos
上一篇笔者已经介绍怎么安装 Nacos 了,这篇就开始重头戏。 搭建SpringBoot项目。
2533 1