Nacos系列(一):Nacos环境安装及Hello World示例
现在微服务架构越来越火,微服务架构中比较重要的一项就是配置中心,
Nacos是阿里巴巴的一个开源项目,它的其中一个功能就是可以作为配置中心,实现配置的动态变更、历史版本对比、配置回滚等功能。
更多的描述细节请查看官网:https://nacos.io/zh-cn/。
本篇博客主要讲解以下内容:
- Nacos环境安装(Windows&Linux)
- Spring Boot项目接入Nacos配置中心
- 初识Nacos控制台
1. Nacos环境安装(Windows)
下载地址:https://github.com/alibaba/nacos/releases。
下载官方推荐的稳定版本1.1.4:

下载完成后将其解压到你需要的目录,我这里解压到了D:\Tools\nacos,解压完成后目录如下图所示:

打开bin文件夹,双击运行startup.cmd即可启动Nacos服务端。

启动时会看到下图所示的界面:


启动成功后,会发现根目录下自动创建了2个文件夹,如下图所示:

bin文件夹下自动创建了2个文件夹和1个文件,如下图所示:

如果需要停止Nacos服务端,有以下2种方式可以选择:
将刚刚运行时打开的cmd窗口关闭
双击运行bin文件夹下的shutdown.cmd

2. Nacos环境安装(Linux)
将上面下载的zip压缩包上传到Linux服务器,我这里上传到了我的阿里云服务器的/usr/local目录下:

然后执行如下命令进行解压:
cd /usr/local
unzip nacos-server-1.1.4.zip


然后执行如下命令启动Nacos服务端,如下所示:
cd nacos/bin
sh startup.sh -m standalone

如果需要停止Nacos服务端,可以执行如下命令:
sh shutdown.sh

3. Spring Boot项目接入Nacos配置中心
首先,需要在pom.xml文件中引入以下依赖:
<dependency>
<groupId>com.alibaba.boot</groupId>
<artifactId>nacos-config-spring-boot-starter</artifactId>
<version>0.2.3</version>
</dependency>
然后在application.yml中添加Nacos Server的地址:
nacos:
config:
server-addr: 127.0.0.1:8848
如果你使用的是application.properties配置文件,按如下格式添加:
nacos.config.server-addr=127.0.0.1:8848
然后在启动类上添加@NacosPropertySource注解,dataId先使用示例的example,autoRefreshed设置为ture,开启自动刷新:

然后新建控制器ConfigController,并使用@NacosValue注解设置属性值,并开启自动刷新:
package com.zwwhnly.springbootaction.controller;
import com.alibaba.nacos.api.config.annotation.NacosValue;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RequestMapping("config")
public class ConfigController {
@NacosValue(value = "${useLocalCache:false}", autoRefreshed = true)
private boolean useLocalCache;
@RequestMapping(value = "/get", method = RequestMethod.GET)
public boolean get() {
return useLocalCache;
}
}
运行项目,访问地址:http://localhost:8080/config/get,此时返回false,如下图所示:

打开cmd窗口,执行如下命令,将useLocalCache的值设置为true:
curl -X POST "http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=example&group=DEFAULT_GROUP&content=useLocalCache=true"

再次访问地址:http://localhost:8080/config/get,此时返回true,如下图所示:

不用重启应用程序,配置就动态变更了,是不是很方便呢。
4. 初识Nacos控制台
Nacos Server启动后,可以通过地址:http://localhost:8848/nacos/index.html,访问它的控制台。
默认会跳转到以下登录页面,默认的账号和密码为:nacos nacos。

登录成功后,可以在配置管理--配置列表界面,看到我们使用的dataId,也可以查看该dataId的配置详情:


如果想要访问阿里云服务器上部署的Nacos控制台,需要在ECS服务器的安全组规则里添加如下配置,不然访问不了:

5. 源码及参考
源码地址:https://github.com/zwwhnly/springboot-action.git,欢迎下载。
Nacos系列(一):Nacos环境安装及Hello World示例的更多相关文章
- Nacos系列:Nacos的三种部署模式
三种部署模式 Nacos支持三种部署模式 1.单机模式:可用于测试和单机使用,生产环境切忌使用单机模式(满足不了高可用) 2.集群模式:可用于生产环境,确保高可用 3.多集群模式:可用于多数据中心场景 ...
- Nacos系列:Nacos的Java SDK使用
Maven依赖 Nacos提供完整的Java SDK,便于配置管理和服务发现及管理,以 Nacos-0.8.0 版本为例 添加Maven依赖: <dependency> <group ...
- hadoop环境安装及简单Map-Reduce示例
说明:这篇博客来自我的csdn博客,http://blog.csdn.net/lxxgreat/article/details/7753511 一.参考书:<hadoop权威指南--第二版(中文 ...
- Keil MDK版兼容51系列单片机开发环境安装
一.安装源文件下载 百度网盘链接:https://pan.baidu.com/s/18tnjFgVat4q2hDSh7LAD8A 提取码: 2295 二.安装及破解 1.安装51的编辑器 双击安 ...
- Vue开发环境安装并集成element-ui示例
此文为转载,原文链接:https://blog.csdn.net/weixin_44670973/article/details/88871106 在此对原文中部分内容进行补充. 补充:element ...
- Nacos系列:基于Nacos的注册中心
前言 所谓注册中心,其实是分布式架构演进过程中的产物,在系统中充当一个协调者的角色.但是,为什么需要这样一个协调者的角色呢?我们先来看一个例子,以便理解为什么分布式架构中需要有注册中心. 案例 小明和 ...
- Nacos系列:欢迎来到Nacos的世界!
什么是Nacos? Nacos 是构建以"服务"为中心的现代应用架构 (例如微服务范式.云原生范式) 的服务基础设施. Nacos可以做什么? 1.动态配置服务:支持以中心化.外部 ...
- Nacos系列:基于Nacos的配置中心
前言 在看正文之前,我想请你回顾一下自己待过的公司都是怎么管理配置的,我想应该会有以下几种方式: 1.硬编码 没有什么配置不配置的,直接写在代码里面,比如使用常量类 优势:对开发友好,开发清楚地知道代 ...
- SpringCloud系列之Nacos应用篇
前言 原先项目是以SpringConfig作为项目配置中心组件,Eureka作为服务注册发现组件,基本上就是SpringCloud全家桶,Eureka已经停更,所以前期调研可替换方案,主流替换方案有C ...
随机推荐
- stand up meeting 12/10/2015
part 组员 今日工作 工作耗时/h 明日计划 工作耗时/h UI 冯晓云 修改了详细释义的自动换行功能:设计并完成了背景图片的切换功能 6 完成单词释义热度排序 6 PDF Reade ...
- Daily Scrum 12/10/2015
Zhaoyang: Finished the implementation of query suggestion UI; Yandong: Changed the fusion algorithm ...
- reactnavigation 5.x简单例子
随着RN和reactnavigation的版本更新,网上很多老版的例子都不能用了. 自己摸索着跑通了一些简单的功能. 使用的是最新的 "react-native": &quo ...
- Python - 关于带参数的装饰器的理解
[原创]转载请注明作者Johnthegreat和本文链接 关于装饰器的理解,特别像<盗梦空间>中的进入梦境和从梦境出来的过程,一层一层的深入梦境,然后又一层一层的返回,被带入梦境的是被装饰 ...
- Javascript-异步详解
- 负载均衡服务之HAProxy基础配置(五)
前文我们聊了下haproxy的修改报文首部的配置.压缩功能以及haproxy基于http协议自定义健康状态检测机制:回顾请参考https://www.cnblogs.com/qiuhom-1874/p ...
- 高德地图首席科学家任小枫QA答疑汇总丨视觉+地图技术有哪些新玩法?
上周,阿里巴巴高德地图首席科学家任小枫在#大咖学长云对话#的在线直播活动上就计算机视觉相关技术发展以及在地图出行领域的应用与大家做技术交流,直播间互动火爆,尤其在QA环节,学弟学妹们纷纷就感兴趣的视觉 ...
- ThinkJS前端搭配vue时的Nginx配置
Thinkjs 作为奇舞团开源的nodejs mvc框架之一,引起了很多NodeJS程序员的亲赖.但是其关于静态文件处理部分支持不够完善,主要是体现在SPA单页应用,之前在ThinkJS 2.*版本时 ...
- Android应用程序开机开机启动
有很过情况都需要Android程序开机自启,也就是在手机开机之后马上执行相应的Android程序. 实现的方法就是,在手机开机的时候接受相应的广播,在Android程序中接受相应的广播. 第1步:建立 ...
- 小米Note 10 Lite海外发布 无缘中国市场
[TechWeb]5月1日消息,昨日晚间,小米Note 10 Lite在海外亮相.小米市场部副总经理臧智渊在微博透露,小米Note 10 Lite 6GB+64GB版售价349欧元(约合人民币2700 ...