Nacos源码学习-本地环境搭建

本文主要记录如何在本地搭建Nacos调试环境来进一步学习其源码,如果你也刚好刷到这篇文章,希望对你有所帮助。

1、本地环境准备

Maven: 3.5.4

Java: 1.8

开发工具:idea

版本控制工具: git

2、下载源码

官方仓库地址 :https://github.com/alibaba/nacos

bash 复制代码
#下载源码
git clone https://github.com/alibaba/nacos.git

# 选择2.4.3 分支
cd nacos 
git checkout 2.4.3

接下来将项目导入idea中,选择maven compile一下

3、启动server端

入口在console模块 com.alibaba.nacos.Nacos, 启动前先编辑一下,设置成单机模式启动

bash 复制代码
-Dnacos.standalone=true

启动后观察控制台日志,显示成功启动

bash 复制代码
2024-12-06 11:14:03.709  INFO 18384 --- [           main] s.a.ScheduledAnnotationBeanPostProcessor : No TaskScheduler/ScheduledExecutorService bean found for scheduled processing
2024-12-06 11:14:03.729  INFO 18384 --- [           main] c.a.n.c.l.StartingApplicationListener    : Nacos started successfully in stand alone mode. use embedded storage
2024-12-06 11:14:04.095  INFO 18384 --- [7)-192.168.22.3] o.s.web.servlet.DispatcherServlet        : Initializing Servlet 'dispatcherServlet'
2024-12-06 11:14:04.096  INFO 18384 --- [7)-192.168.22.3] o.s.web.servlet.DispatcherServlet        : Completed initialization in 1 ms

在浏览器里输入http://localhost:8848/nacos/index.html

至此已经启动成功了

4、写个demo尝试注册一下

这个我是在client模块下的test包中添加了一个类com.alibaba.nacos.client.naming.MyTest

通过Nacos 工厂类获取了一个NamingService 对象,然后假设存在一个testService的服务,通过调用registerInstance方法,将其注册到Nacos。

java 复制代码
/**
 * @description:
 * @date: 2024/12/5
 **/
public class MyTest {
    public static void main(String[] args) throws NacosException {
        Properties properties = new Properties();
        properties.setProperty("serverAddr", "localhost");
        properties.put(PropertyKeyConst.NAMESPACE, "public");
        //超时时间可以设置长点这样方便后面debug调试观察
        properties.put(CommonParams.NAMING_REQUEST_TIMEOUT, "10000");
        NamingService namingService = NacosFactory.createNamingService(properties);
        namingService.registerInstance("testService", "127.0.0.1", 8080);
        System.out.println("服务注册成功!");
    }
}

这里可以在最后一行打个断点方便观察,运行main方法后,我们去控制台页面查看一下,发现已经注册上了

当然我们在实际项目中不会这样手动去注册服务,通过引入spring-cloud-starter-alibaba-nacos-discovery包,然后借助spring自动装配机制来进行自动注册,熟悉spring的朋友应该会很清楚这点。

相关推荐
代码哈士奇3 天前
Nestjs+nacos+kafka搭建中后台系统-后端(持续更新中)
redis·分布式·微服务·nacos·kafka·nestjs·pgsql
bxlj_jcj6 天前
Nacos注册中心:从服务注册到负载均衡
spring cloud·nacos
阿里-于怀6 天前
行业首发!Spring AI Alibaba + Nacos 支持分布式 Multi-Agent 构建
人工智能·分布式·ai·nacos·saa·multi agent
代码哈士奇7 天前
简单使用Nest+Nacos+Kafka实现微服务
后端·微服务·nacos·kafka·nestjs
曹朋羽8 天前
nacos 使用oceanbase(oracle模式)作为数据源
oracle·nacos·oceanbase
Zz_waiting.8 天前
服务注册 / 服务发现 - Nacos
nacos·服务发现·1024程序员节
bxlj_jcj8 天前
Nacos 环境搭建:从单机开发到集群生产部署
nacos
beyond阿亮12 天前
nacos支持MCP Server注册与发现
java·python·ai·nacos·mcp
Chan1612 天前
流量安全优化:基于 Nacos 和 BloomFilter 实现动态IP黑名单过滤
java·spring boot·后端·spring·nacos·idea·bloomfilter
岁岁岁平安22 天前
Java+SpringBoot+Dubbo+Nacos快速入门
java·spring boot·nacos·rpc·dubbo