nacos是Spring Cloud Alibaba开源项目,可用于作为Spring Cloud的注册中心和配置中心。
先要详细了解可以查看nacos官方说明文档
为什么需要配置中心
当然是为了便于对配置文件进行统一管理。springcloud是以springboot为基础,springboot最终的几乎都是打包成一个可执行的jar包(当然也可以打包成war包)。所有的配置文件是打包在jar包中,当工程的配置文件需要修改,就需要修改配置文件,然后重新打包部署,非常麻烦。当我们只有少量工程以及修改频率很低,上面的操作还可以接受,但是当数量很多时,显然上面的方法弊端明显。
假如此时我们的工程采用配置中心统一管理配置文件,我们只需要在配置中心修改配置内容,正在运行的项目就可以自动更新配置,大大降低了配置文件修改的成本和代价。
Spring Cloud 也为我们提供的配置中心解决方案:Spring Cloud Config
但是该方案似乎目前还是不太完善,例如:
- 需要结合Spring Cloud Bus 使用,才能实现自动更新。当Server端的配置文件更新后,客户端并不能发现配置文件发生了修改,并实现自动更新。而是依靠Spring Cloud Bus 通知相关的客户端更新配置文件。显然这对于需要我们在项目中添加Spring Cloud Bus,增加了我们工程的复杂度。
- 配置文件的存储依赖SVN或者git。Spring Cloud Config只是接受客户端的请求,然后从svn和git服务器上读取配置文件,然后发送给客户端。
下面我们来看一下Nacos的介绍以及介绍一下单机模式启动Nacos Server端
官方给出的介绍
> Nacos 提供用于存储配置和其他元数据的 key/value 存储,为分布式系统中的外部化配置提供服务器端和客户端支持。使用 Spring Cloud Alibaba Nacos Config,您可以在 Nacos Server 集中管理你 Spring Cloud 应用的外部属性配置。
Spring Cloud Alibaba Nacos Config 是 Config Server 和 Client 的替代方案,客户端和服务器上的概念与 Spring Environment 和 PropertySource 有着一致的抽象,在特殊的 bootstrap 阶段,配置被加载到 Spring 环境中。当应用程序通过部署管道从开发到测试再到生产时,您可以管理这些环境之间的配置,并确保应用程序具有迁移时需要运行的所有内容。
说了那么多废话,下面开始Nacos
下载Nacos Server端
https://github.com/alibaba/nacos/releases
我下载的是当前的最新稳定版本0.7.0,当前nacos的更新也十分的活跃也已经发布了0.8.0-SNAPSHOT版本。有兴趣的小伙伴也可以下载源码自己打包。
解压
tar -zxvf nacos-server-0.7.0.tar.gz
解压后目录如下:
bin文件夹下存放的启动和停止命令,windows和linux下的启动和关闭命令分别对应cmd和sh文件
conf文件夹下存放配置文件,
启动Nacos Server(官方给出的启动方法如下)
Linux/Unix/Mac
启动命令(standalone代表着单机模式运行,非集群模式):
sh startup.sh -m standalone
Windows
启动命令:
cmd startup.cmd
或