Spring Cloud Alibaba 之Nacos
- 2020 年 11 月 6 日
- 笔记
- Spring-cloud-alibaba
Nacos 技术讲解
一提到分布式系统就不的不提一下 CAP 原则
什么是CAP
CAP原则又称CAP定理,指的是在一个分布式系统中,一致性(Consistency)、可用性(Availability)、分区容错性(Partition tolerance)。CAP 原则指的是,这三个要素最多只能同时实现两点,不可能三者兼顾。
CAP 的原则下 Alibaba Naos 同时支持AP和CP模式,他根据服务注册选择临时和永久来决定走AP模式还是CP模式,他这里支持CP模式对于我的理解来说,应该是为了配置中心集群,因为nacos可以同时作为注册中心和配置中心,因为他的配置中心信息是保存在nacos里面的,假如因为nacos其中一台挂掉后,还没有同步配置信息, 就可能发生配置不一致的情况., 配置中心的配置变更是服务端有监听器,配置中心发生配置变化, 然后服务端会监听到配置发生变化,从而做出改变
下面我搭建一个简单的微服务系统,针对这个系统进行讲解
系统架构图:
这个主要完成一个一个前端页面进行实时计算的功能,大家可以理解为一个简单的计算器.
- website : 前端
- Gateway :服务网关
- UserCenter : 用户服务
- MqCenter: 消息服务
- AlogirthmCenter: 计算服务
- ConfigCenter: 配置中心
- ServiceDiscovery(Nacos):服务发现
- CPP 为C 语言编写的计算流程
此项目包括用到的技术栈包括,Spring Cloud Alibaba/Spring Boot/Mysql/MQ/Linux 等
什么是Nacos
官方文档
上面是Nacos 的官网大家可以自行了解下,对Nacos 做一个深入的了解,正所谓师傅领进门,修行在个人,大家还要多学习,多了解
天也不早了 ,人也不少了,闲话少说,先干正事。
** Nacos 下载地址**
选择对应版本进行解压(注意 Nacos 解压后 是一个完整的运行包,如果用的不熟练,不要动里面的配置信息)
下载完成后解压后进入到 bin 目录 在终端运行命令
- MAC
sh startup.sh -m standalone
(standalone代表着单机模式运行,后看会单独讲解集群模式的搭建和启动方法) - Windows
cmd startup.cmd
启动成功后 默认账号密码 nacos/nacos(初始账号密码)
登录后可以看到左上角中英文切换,英语不好的同学们 可以切换到中文
- 配置管理主要是用来做项目配置,比如配置文件等可以用nacos来管理 因为nacos不仅仅是服务中心,也是配置中心(后面有讲)
- 服务管理是用来管理每个微服务,每个在nacos上注册的微服务在这里都可以看到
- 命名空间是用来做服务环境区分,当项目需要开发,测试, 生产等多个不同的配置, 命名空间就可以做配置隔离。
- 集群管理 后面会单独讲解
下一章会讲解如何在Nacos 上注册一个简单的微服务