Nacos全面解析
Posted Mr Tang
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Nacos全面解析相关的知识,希望对你有一定的参考价值。
目录
一.Nacos概要
1.Nacos简介
Nacos是阿里巴巴开源的一款支持 服务注册与发现、配置管理、服务管理 的组件。
取代以前常用的注册中心(zookeeper , eureka等等),以及配置中心(spring cloud config等等)
2.Nacos安装
1.下载安装包
官网地址:Releases · alibaba/nacos · GitHub 1.0
Releases · alibaba/nacos (github.com) 2.0
2.0.2下载地址:
链接:https://pan.baidu.com/s/1V4S1aNpgnj0h4GKlN5bnag
提取码:0gyl
说明:1.4.0以下使用的mysql驱动是8.0以下的,1.4.0以上使用的驱动就是8.0以上的了,所以大家在使用的nacos的时候要注意与mysql的对应版本问题,否则会因为nacos与mysql的版本不对应导致的nacos无法加载数据源。
2.解压使用启动脚本启动
ps:直接启动可能会报错:java.net.UnknownHostException: jmenv.tbsite.net
默认是集群模式启动,如果报错可以按照如下方式启动
进入命令行执行:startup.cmd -m standalone 启动
也可以在application.properties
中配置nacos.core.member.lookup.type=file
3.访问
nacos启动后访问控制台地址:http://localhost:8848/nacos/index.html#/login
用户名密码默认都是:nacos
3.Nacos配置外部数据源
修改D:\\software\\nacos-2.0.2\\conf\\application.properties
#下面这两行注释一定要打开,不打开下面配置的mysql数据源就不生效了
spring.datasource.platform=mysql
db.num=1
db.url.0=jdbc:mysql://localhost:3306/jg_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC
db.user=root
db.password=root
二.Nacos应用
1.注册发现
1.项目中引入nacos的相关依赖
<!--nacos-discovery-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<version>2.2.5.RELEASE</version>
</dependency>
<!--nacos-config-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
<version>2.2.5.RELEASE</version>
</dependency>
2.配置文件如下
spring:
application:
name: nacos-demo
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
3.启动类加服务发现的注解
@SpringBootApplication
@EnableDiscoveryClient
public class NacosDemoApplication
public static void main(String[] args)
SpringApplication.run(NacosDemoApplication.class, args);
4.查看nacos界面,服务列表
注意:可以通过在配置文件中配置namespace 属性控制服务属于哪个命名空间下的,默认不配置namespace都是在public的命名空间下,可以在命令空间菜单下新建命名空间。(namespace 是通过id与nacos命名空间 关联的,命名空间可是实现数据隔离)
5.测试
localhost:10086/nacos/hellohttp://localhost:10086/nacos/hello调用controller接口正确返回,说明服务注册和发现正常
2.负载均衡
1.初始化负载均衡算法
@Configuration
public class NacosDemoConfig
/***
* Nacos负载均衡算法
* @return
*/
@Bean
@Scope(value="prototype")
public IRule loadBalanceRule()
return new NacosRule();
2.在配置文件中配置权重 weight: 1
spring:
application:
name: nacos-demo
cloud:
nacos:
discovery:
namespace: public
server-addr: 127.0.0.1:8848
weight: 1
3.再起一个服务权重设置为weight: 2
-Dserver.port=10087 -Dspring.cloud.nacos.discovery.weight=2
4.启动后查看控制台
5.通过网关测试,发现调用比例为1:2
3.配置中心
需要把配置文件名称改为优先加载的bootstrap.yaml文件,否则加载不到nacos的配置
1.新建命名空间nacos-demo(实现数据隔离)id为2,配置文件中指定namespace为2
配置服务名称:name: nacos-demo
配置文件后缀名:file-extension: yaml
spring:
application:
name: nacos-demo
cloud:
nacos:
discovery:
namespace: 2
server-addr: 127.0.0.1:8848
weight: 1
config:
server-addr: 127.0.0.1:8848
namespace: 2
file-extension: yaml
2.在配置管理>配置列表中新建配置
(1)Data_id默认加载$spring.application.name.$file-extension(服务名.文件后缀)
3.项目中使用配置
@RestController
@RequestMapping("/nacos")
public class NacosDemoController
@Value("$nacostest")
private String nacostest;
@GetMapping("hello")
public String helloNacos()
return "Hello Nacos:"+nacostest;
4.测试
http://localhost:10086/nacos/hello
返回成功,配置数据生效。
4.多环境切换
通过配置Data Id实现多环境切换
配置格式为:服务名-环境.文件后缀
$spring.application.name-$profile.$file-extension:properties
1.配置开发环境配置文件如下
2.工程配置文件中指定环境配置
spring:
application:
name: nacos-demo
profiles:
active: dev
3.测试
@Value("$nacosenv")
private String nacosenv;
@GetMapping("hello")
public String helloNacos()
return "Nacos Env is:"+nacosenv;
4.访问成功,环境配置完成
5.配置刷新
默认情况下nacos已经实现了自动配置刷新功能,如果需要刷新配置直接在控制器中加入@RefreshScope注解即可
6.共享/扩展配置
(1)创建一个public.yaml作为共享配置
(2)在工程配置文件中引入共享配置
shared-configs[0]:
dataId: public.yaml
refresh: true
spring:
application:
name: nacos-demo
profiles:
active: dev
cloud:
nacos:
discovery:
namespace: 2
server-addr: 127.0.0.1:8848
weight: 1
config:
server-addr: 127.0.0.1:8848
namespace: 2
file-extension: yaml
shared-configs[0]:
dataId: public.yaml
refresh: true
(3)测试
获取public.yaml内容成功,共享配置生效
7.灰度发布
1.概述
Nacos支持以IP为粒度的灰度配置
2.灰度发布配置步骤:
(1)讲服务在不同的服务器部署,有多个实例
(2)编辑配置文件点击Beta发布
(3)填写需要发布到的ip,以逗号分割
(4)点击【发布Beta】,点击后,可以通过【停止Beata】按钮停止灰度发布
3Nacos 配置中心源码解析之 项目结构
Nacos 的 github 地址为:https://github.com/alibaba/nacos/。以下分析基于: Nacos 版本号:2.1.0
。Nacos 一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
Nacos提供四个主要功能。
-
服务发现和服务运行状况检查
Nacos简化了服务注册和通过DNS或HTTP接口发现其他服务的过程。Nacos还提供服务的实时运行状况检查,以防止向不健康的主机或服务实例发送请求。 -
动态配置管理
Dynamic Configuration Service允许您跨所有环境以集中和动态的方式管理所有服务的配置。在更新配置时,Nacos消除了重新部署应用程序和服务的需要,这使得配置更改更加高效和敏捷。 -
动态域名服务
Nacos支持加权路由,使您更容易在数据中心的生产环境中实现中间层负载均衡、灵活的路由策略、流控制和简单的DNS解析服务。它帮助您轻松实现基于dns的服务发现,并防止应用程序耦合到特定于供应商的服务发现api。 -
服务和元数据管理
Nacos提供了一个易于使用的服务仪表板,以帮助您管理服务元数据、配置、kubernetes DNS、服务运行状况和度量统计数据。
下面我们来分析一下 Nacos 框架的包结构。在分析源码之前,我们先对这个框架有一个宏观的认识。
Nacos 包结构
+ nacos
└ address # Nacos Address 服务
└ api # Nacos 服务抽象 API
└ auth # Nacos 授权相关接口,登陆、接口访问等
└ client # Nacos Java Client
└ cmdb # Nacos 内部配置管理相关
└ common # Nacos Common 包:定义工具类,通用对象等
└ config # Nacos 动态配置实现
└ consistency # Nacos 最终一致性实现
└ console # Nacos 控制台后台相关
└ console-ui # Nacos 控制台 UI 相关
└ core # Nacos 核心包:包括一些工具类,分布式存储
└ distribution # Nacos 启动相关的配置信息
└ example # Nacos 使用示例
└ istio # Nacos 与 GRPC 集成
└ naming # Nacos 命名服务,服务注册与发现
└ plugin # Nacos 插件相关,包括:授权以及加密
└ plugin-default-impl # Nacos 授权默认实现
└ sys # Nacos 系统相关的配置:包括集群单机模式以及系统参数
└ test # Nacos 测试用例
使用 mvn clean install -Dmaven.test.skip=true
编译项目:
编译成功之后:启动 console
模块中 com.alibaba.nacos.Nacos
这个类的 main
方法。注意在虚拟机启动参数添加:-Dnacos.standalone=true
单机版本启动。
启动成功后,我们就访问 http://localhost:8848/nacos
,并以 nacos/nacos
用户名密码进行登录了。
后续我们就可以很方便的进行 debug 查看源代码了。
以上是关于Nacos全面解析的主要内容,如果未能解决你的问题,请参考以下文章
Java Spring Cloud 实战之路- 使用Nacos和网关中心的创建
Java Spring Cloud 实战之路- 使用Nacos和网关中心的创建
了解Spring Cloud微服务以及微服务搭建(Nacos)
了解Spring Cloud微服务以及微服务搭建(Nacos)