SA实战 ·《SpringCloud Alibaba实战》第21章-服务配置:服务配置介绍与Nacos核心概念

简介: SA实战 ·《SpringCloud Alibaba实战》第21章-服务配置:服务配置介绍与Nacos核心概念


一不小心《SpringCloud Alibaba实战》专栏都更新到第21章了,再不上车就跟不上了,小伙伴们快跟上啊!

注意:本项目完整源码加入 「冰河技术」 知识星球即可获取,文末有入场方式。


前文回顾

在《SpringCloud Alibaba实战》专栏前面的文章中,我们实现了用户微服务、商品微服务和订单微服务之间的远程调用,并且实现了服务调用的负载均衡。

基于阿里开源的Sentinel实现了服务的限流与容错,并详细介绍了Sentinel的核心技术与配置规则。简单介绍了服务网关,并对SpringCloud Gateway的核心架构进行了简要说明,也在项目中整合了SpringCloud Gateway网关实现了通过网关访问后端微服务.

同时,也基于SpringCloud Gateway整合Sentinel实现了网关的限流功能,详细介绍了SpringCloud Gateway网关的核心技术。在链路追踪章节,我们开始简单介绍了分布式链路追踪技术与解决方案,随后在项目中整合Sleuth实现了链路追踪,并使用Sleuth整合ZipKin实现了分布式链路追踪的可视化 。

在消息服务章节,我们介绍了MQ的使用场景,引入MQ后的注意事项以及MQ的选型对比,在项目中整合了RocketMQ,并给大家介绍了RocketMQ的核心技术。

今天,我们正式进入《SpringCloud Alibaba实战》专栏的服务配置章节,很多小伙伴都知道:Nacos在微服务开发过程中,既可以用作注册中心,也可以用作配置中心。在《SpringCloud Alibaba实战》专栏的服务治理章节,我们使用Nacos实现了注册中心,在接下来的服务配置章节,我们就使用Nacos实现配置中心。老规矩,在正式整合项目前,我们还是先来简单的聊聊服务配置与Nacos作为配置中心的相关概念。

本章总览

图片.png


群魔乱舞(配置散落存储)

当我们的项目采用微服务架构后,原本单一的项目会被拆分为一个个小的微服务。原来项目中的配置文件就需要在每个微服务下都要存储一份,这些配置文件中的内容大部分都是相同的,只有个别的配置项不同。就拿数据库配置来说吧,如果每个微服务使用的技术栈都是相同的,则每个微服务中关于数据库的配置几乎都是相同的,有区别的地方可能就是:数据库连接,用户名和密码。

图片.pngimage.gif

当项目采用微服务架构后,原本在单体项目中的配置文件就会散落在各个微服务中,如果不对这些散落的配置文件进行处理,就会造成各种各样的问题。总结起来,这些问题主要体现在如下几个方面。

(1)配置文件散落在各个微服务项目中,随着整体项目的业务越来越复杂,后续会新增更多的微服务项目,微服务项目越来越多,则散落在微服务中的配置文件也会越来越多,后续会变得难以统一维护和管理。

(2)配置文件散落在各个微服务项目中,还有一个非常棘手的问题,那就是修改配置文件非常麻烦。需要我们手动去修改每个微服务下的配置文件,稍有不慎,还会增加微服务项目出错的风险。

(3)一般情况下,企业的项目发布环境包含开发环境、测试环境、预发布环境、生产环境。每个环境都需要对应不同的配置文件,如果不对这些配置文件进行统一管理,则每次发布到不同的环境时,都需要我们手动去修改每个微服务的配置文件,维护起来也是非常繁琐的。

(4)在微服务中,手动修改了配置文件之后,修改后的具体的配置项无法在微服务项目中实时更新。每次修改配置文件后,都需要重新启动微服务项目。不管是从开发角度,还是从运维角度,都是非常不友好的。

分久必合(配置中心)

基于上面的种种原因,我们绝不允许配置文件长期在各个微服务项目中分散存储,那有没有什么办法将这些配置文件统一存放和管理呢?答案就是使用配置中心。

这里,冰河先用自己的大白话给配置中心下个定义吧。

配置中心就是在微服务项目中,统一管理和维护项目配置信息的地方,它支持配置信息的集中存储,对外提供统一的接口获取配置,支持各个微服务主动调用配置中心的接口获取配置,也支持当配置信息发生变更时,由配置中心实时并且主动向各个微服务通知服务配置发生了变更,使其同步最新的配置信息。

哎,说好的大白话,读起来还是有点“官腔”,算了,不管它了,大家能够看懂就好。

在对配置中心的定义中,涵盖了三项重要内容。

(1)配置中心将各个微服务中的配置进行统一集中管理和维护,并且对外提供统一的接口获取相关配置。

(2)配置中心支持微服务主动调用配置中心的接口获取配置信息。

(3)配置信息发生变更时,配置中心能够实时并且主动向各个微服务通知服务配置发生了变更,使其同步最新的配置信息。

这里,我们还是以商城微服务化后为例,当引入配置中心后,数据库配置信息,如下图所示。

image.gif图片.png

可以看到,在微服务中引入配置中心后,配置信息不再存储到各个微服务项目中,也不用再手动修改每个微服务项目中的配置信息。而是在配置中心统一进行管理和维护。各个微服务会调用配置中心的接口获取配置信息。当配置中心的配置信息发生变更时,配置中心会主动并且实时通知各个微服务,使其获取配置中心的最新配置信息。

配置中心解决方案

针对项目采用微服务架构后的配置文件的存储与管理问题,业界也提出了不少解决方案,也开源出了很多不错的优秀项目,这里就给大家简单列举几个。

配置中心 说明
Consul 谷歌基于Go语言开发出的一款支持服务动态发现的配置管理中心服务。在Consul中,内置了服务注册与发现功能,实现了分布式一致性协议,支持Key-Value存储,支持多数据中心。
Apollo 协程开源的一款支持分布式的配置中心。支持修改后的配置动态实时生效,对项目的配置进行版本化管理,对配置的修改支持审计,支持项目的灰度发布。
Disconf 百度开源的一款支持分布式的配置中心,主要是利用Zookeeper实现配置信息变更后,实时通知各个微服务,使变更后的配置信息生效。
SpringCloud Config SpringCloud技术栈中自带的配置中心组件,支持使用Git仓库存储配置信息,不支持配置信息变更后实时生效。
Nacos SpringCloud Alibaba技术栈中的一个在微服务环境下,支持分布式服务注册与发现,支持服务元数据及流量管理,支持分布式配置中心的组件。使用Nacos可以轻松实现服务的注册与发现,以及分布式配置中心功能。

Nacos配置中心概念

核心概念 中文说明 概念说明
Namespace 命名空间 主要用于不同环境下的配置隔离,不同的环境会被划分到不同的命名空间中。
Group 配置分组 主要用于将不同的微服务划分到同一个分组中。通常情况下,会将组成整体项目的各个微服务的配置统一划分到同一个分组中。
Data ID 配置集 ID 通常情况下,在系统中,一个配置文件就是一个配置集,在这个配置文件中,能够包含系统各个方面的配置信息。配置集ID就是某个配置集的ID,也就是系统中某个配置文件的ID。

更多概念请参见:https://nacos.io/zh-cn/docs/concepts.html

「好了,今天我们就到儿吧,限于篇幅,文中并未给出完整的案例源代码,想要完整源代码的小伙伴可加入【冰河技术】知识星球获取源码。也可以加我微信:hacker_binghe,一起交流技术。」

「另外,一不小心就写了21章了,小伙伴们你们再不上车就真的跟不上了!!!」

关于星球

最近,冰河创建了【冰河技术】知识星球,《SpringCloud Alibaba实战》专栏的源码获取方式会放到知识星球中,同时在微信上会创建专门的知识星球群,冰河会在知识星球上和星球群里解答球友的提问。

今天,【冰河技术】知识星球再开放200张优惠券,还没上车的小伙伴赶紧啦,再不上车就跟不上啦!!

星球提供的服务

冰河整理了星球提供的一些服务,如下所示。

加入星球,你将获得:

1.学习SpringCloud Alibaba实战项目—从零开发微服务项目

2.学习高并发、大流量业务场景的解决方案,体验大厂真正的高并发、大流量的业务场景

3.学习进大厂必备技能:性能调优、并发编程、分布式、微服务、框架源码、中间件开发、项目实战

4.提供站点 https://binghe001.github.io 所有学习内容的指导、帮助

5.GitHub:https://github.com/binghe001/BingheGuide - 非常有价值的技术资料仓库,包括冰河所有的博客开放案例代码

6.可以发送你的简历到我的邮箱,提供简历批阅服务

7.提供技术问题、系统架构、学习成长、晋升答辩等各项内容的回答

8.定期的整理和分享出各类专属星球的技术小册、电子书、编程视频、PDF文件

9.定期组织技术直播分享,传道、授业、解惑,指导阶段瓶颈突破技巧

相关实践学习
RocketMQ一站式入门使用
从源码编译、部署broker、部署namesrv,使用java客户端首发消息等一站式入门RocketMQ。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
相关文章
|
30天前
|
缓存 安全 Nacos
nacos常见问题之服务一直在报token expired!如何解决
Nacos是阿里云开源的服务发现和配置管理平台,用于构建动态微服务应用架构;本汇总针对Nacos在实际应用中用户常遇到的问题进行了归纳和解答,旨在帮助开发者和运维人员高效解决使用Nacos时的各类疑难杂症。
69 0
|
30天前
|
网络协议 Java Nacos
nacos常见问题之在web界面 上下线服务时报错 400如何解决
Nacos是阿里云开源的服务发现和配置管理平台,用于构建动态微服务应用架构;本汇总针对Nacos在实际应用中用户常遇到的问题进行了归纳和解答,旨在帮助开发者和运维人员高效解决使用Nacos时的各类疑难杂症。
29 0
|
30天前
|
缓存 PHP Nacos
nacos常见问题之服务升级后nacos控制台看到都是不可用重启nacos后恢复如何解决
Nacos是阿里云开源的服务发现和配置管理平台,用于构建动态微服务应用架构;本汇总针对Nacos在实际应用中用户常遇到的问题进行了归纳和解答,旨在帮助开发者和运维人员高效解决使用Nacos时的各类疑难杂症。
34 4
|
1月前
|
Java Nacos Sentinel
Spring Cloud Alibaba 面试题及答案整理,最新面试题
Spring Cloud Alibaba 面试题及答案整理,最新面试题
198 0
|
1月前
|
SpringCloudAlibaba Java 持续交付
【构建一套Spring Cloud项目的大概步骤】&【Springcloud Alibaba微服务分布式架构学习资料】
【构建一套Spring Cloud项目的大概步骤】&【Springcloud Alibaba微服务分布式架构学习资料】
141 0
|
7天前
|
Java API 对象存储
对象存储OSS产品常见问题之使用Spring Cloud Alibaba情况下文档添加水印如何解决
对象存储OSS是基于互联网的数据存储服务模式,让用户可以安全、可靠地存储大量非结构化数据,如图片、音频、视频、文档等任意类型文件,并通过简单的基于HTTP/HTTPS协议的RESTful API接口进行访问和管理。本帖梳理了用户在实际使用中可能遇到的各种常见问题,涵盖了基础操作、性能优化、安全设置、费用管理、数据备份与恢复、跨区域同步、API接口调用等多个方面。
24 2
|
15天前
|
SpringCloudAlibaba 监控 Java
SpringCloud Alibaba微服务-- Sentinel的使用(保姆级)
SpringCloud Alibaba微服务-- Sentinel的使用(保姆级)
|
15天前
|
SpringCloudAlibaba Java API
SpringCloud Alibaba微服务工程搭建(保姆级)
SpringCloud Alibaba微服务工程搭建(保姆级)
|
15天前
|
SpringCloudAlibaba Java Nacos
SpringCloud Alibaba微服务 -- Nacos使用以及注册中心和配置中心的应用(保姆级)
SpringCloud Alibaba微服务 -- Nacos使用以及注册中心和配置中心的应用(保姆级)
|
22天前
Springcloud-ribbon和hystrix配置
Springcloud-ribbon和hystrix配置
7 0

热门文章

最新文章