一、SpringCloudAlibaba简介

待更新

二、Nacos概述

1、什么是nacos?

一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台,相当于注册中心 + 配置中心的组合,等价于Eureka+Config +Bus。

2、能干嘛?

  • 替代Eureka做服务注册中心
  • 替代config做服务配置中心

3、去哪下?

官网下载:点击访问

 这里我下载的是Windows版本,下载完成后进入文件夹的bin目录下启动nacos:

4、怎么运行访问?

上面我们已经将 Nacos 初步安装好了,在启动时需要注意以下问题:

  • 如果我们直接通过cmd启动startup.cmd 发现能启动但是会报错,因为nacos默认启动方式是集群,所以我们需要更改为单机模式 startup.cmd -m standalone

  • 这个时候可以正常启动了,但是我们使用Nacos是用来搞微服务的,为什么还要搞单机呢?
    Nacos默认是以集群方式启动的,但是对于初学者来说可能是初次安装没有集群环境需要进行一些配置,在入门阶段我们还是以单机为主进行练手。
  • 配置集群模式启动

将cluster.conf.example文件复制一份去掉.example后缀,然后进入文件修改,添加端口,然后就可以通过 startup.cmd 进行启动。

  • 访问 localhost:8848/nacos

三、Nacos之服务注册中心

官方文档:点击查看

1、服务提供者模块(建moudle、改pom、写yml、主启动、业务类)

(1)创建moudle:cloudalibaba-provider-payment9001

(2)改pom(添加依赖):

  • 父pom(公用):
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>2.1.0.RELEASE</version><type>pom</type><scope>import</scope>
</dependency>
  • 子pom:
<!--SpringCloud ailibaba nacos -->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

(3)编写配置文件 application.yml

server:port: 9001spring:application:name: nacos-payment-provider #注册服务名称cloud:nacos:discovery:server-addr: localhost:8848 #配置Nacos地址
#打开全部监控端点
management:endpoints:web:exposure:include: '*'

(4)主启动类 PaymentMain9001.java

@EnableDiscoveryClient  //开启服务提供者或消费者,客户端的支持,用来注册服务或连接到注册中心
@SpringBootApplication  //主启动
public class PaymentMain9001
{public static void main(String[] args) {SpringApplication.run(PaymentMain9001.class, args);}
}

(5)编写业务类 PaymentController.java

@RestController
public class PaymentController
{@Value("${server.port}")private String serverPort;@GetMapping(value = "/payment/nacos/{id}")public String getPayment(@PathVariable("id") Integer id){return "nacos registry, serverPort: "+ serverPort+"\t id"+id;}
}

(6)测试

  • 启动Nacos和cloudalibaba-provider-payment9001模块。
  • 访问http://localhost:9001/payment/nacos/1
  • 在服务列表中发现注册到Nacos服务注册中心中的服务:nacos-payment-provider

2、服务提供者模块(副本,测试nacos的负载均衡功能)

(1)复制一份9001模块的代码改一下文件名和端口号,不过多赘述;

(2)在同一服务名下存在两个健康的实例。

 3、服务消费者(建moudle、改pom、写yml、主启动、业务类)

(1)创建moudle:cloudalibaba-consumer-nacos-order83

(2)改pom(添加依赖):

<!--SpringCloud ailibaba nacos -->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

(3)编写配置文件 application.yml

server:port: 83spring:application:name: nacos-order-consumer  #注册服务名称cloud:nacos:discovery:server-addr: localhost:8848#消费者将要去访问的微服务名称(注册成功进nacos的微服务提供者)
service-url:nacos-user-service: http://nacos-payment-provider 

(4)主启动类 OrderNacosMain83.java

@EnableDiscoveryClient  //开启服务提供者或消费者,客户端的支持,用来注册服务或连接到注册中心
@SpringBootApplication  //主启动
public class OrderNacosMain83
{public static void main(String[] args){SpringApplication.run(OrderNacosMain83.class,args);}
}

(5)编写业务类,需要添加一个RestTemplate的配置类:

@Configuration
public class ApplicationContextBean
{//这里就是创建一个轮询负载均衡的RestTemplate Bean@Bean@LoadBalancedpublic RestTemplate getRestTemplate(){return new RestTemplate();}
}
@RestController
public class OrderNacosController
{@Resourceprivate RestTemplate restTemplate;@Value("${service-url.nacos-user-service}")private String serverURL;@GetMapping("/consumer/payment/nacos/{id}")public String paymentInfo(@PathVariable("id") Long id){return restTemplate.getForObject(serverURL+"/payment/nacos/"+id,String.class);}}

(6)测试

  • 启动Nacos和9001、9002、83模块。
  • 访问 http://localhost:83/consumer/payment/nacos/13
  • 可以发现83模块会访问9001/9002,轮询负载

 4、服务注册中心对比

这里先来了解一下什么是CAP模型?

  • 一致性(Consistency):同一时刻同一请求的实例返回结果相同,所有数据具有强一致性。
  • 可用性(Availability):所有实例的读写请求在一定时间内可以得到正确的响应。
  • 分区容错性(Partition tolerance):在网络异常的情况下系统仍能提供正常的服务。

这就是CAP原则,又被称为CAP定理,但是三个特性不可能同时被满足,所以分布式系统设计要考虑的是在满足P(分区容错性)的前提下选择C(一致性)还是A(可用性),即:CP或AP

CP:

AP:

服务注册与发现框架 CAP模型 控制台管理 社区活跃度
Eureka AP 支持 低(2.x版本闭源)
Zookeeper CP 不支持
Consul CP 支持
Nacos AP/CP 支持

四、Nacos之服务配置中心

1、nacos作为配置中心----基本配置

(1)创建子模块: cloudalibaba-config-nacos-client3377

(2)编写pom文件:

<!--nacos-config-->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>

(3)编写application.yml:

Nacos同springcloud-config一样,在项目初始化时,要保证先从配置中心进行配置拉取,拉取之后,才能保证项目的正常启动。

        bootstrap.yml

server:port: 3377
spring:application:name: nacos-config-clientcloud:nacos:discovery:server-addr: localhost:8848 #nacos服务注册中心地址config:server-addr: localhost:8848 #nacos作为配置中心地址file-extension: yaml #指定yaml格式的配置

        application.yml

spring:profiles:active: dev # 表示开发环境

(4)创建主启动类:

@EnableDiscoveryClient
@SpringBootApplication
public class NacosConfigClientMain3377
{public static void main(String[] args) {SpringApplication.run(NacosConfigClientMain3377.class, args);}
}

(5)编写业务类:

@RestController
@RefreshScope //在控制器类加入@RefreshScope注解使当前类下的配置支持Nacos的动态刷新功能。
public class ConfigClientController
{@Value("${config.info}")private String configInfo;@GetMapping("/config/info")public String getConfigInfo() {return configInfo;}
}

2、在Nacos中添加配置信息

(1)Nacos中的匹配规则:官方文档

(2)在Nacos中新增配置

  • 配置文件命名规则

  •  Nacos 配置页面对应:

(3)测试,启动3377模块

发起请求访问: localhost:3377/config/info

修改配置文件内容,如果可以动态刷新,那么Nacos Config中心配置成功!

3、Nacos作为配置中心----分类配置(针对多环境多项目管理)

首先先来说一下为什么会产生分类配置?它在我们实际的开发中又起到了一个什么样的作用呢?最后我们来实际测试一下分类配置该如何使用。

  • 在实际的开发中,一个系统通常情况下会有dev开发环境、test测试环境、prod生产环境。那么我们该如何保证指定环境启动时服务能正确读取到Nacos上相应环境的配置文件呢?
  • 一个大型分布式微服务系统会有很多微服务子项目,每个微服务项目又都会有相应的开发环境、测试环境、预发环境、正式环境......我们该怎么对这些微服务配置进行管理呢?

针对上述问题,nacos提供了一种便捷的解决方案,我们先来看一下它的图形化管理界面:

(1)Namespace+Group+Data ID三者之间的关系

如上图,简单来说,这种分类配置的设计思想类似于java中的包名-类名-...最外层的namespace用来区分部署环境,Group和DataID逻辑上区分两个目标对象(默认情况下:Namespac=public,Group=DEFAULT_GROUP,默认Cluster【集群】是DEFAULT)。

  • Namespace主要用来实现隔离(也就是nacos默认命名空间为public)。

假设我们现在有三个环境:开发、测试、生产环境,那么我们就可以创建三个Namespace,不同的Namespace之间是相互隔离的。

  • Group默认是DEFAULT_GROUP,Group可以把不同的微服务划分到同一个分组里面去。
  • Service就是微服务。一个Service可以包含多个Cluster(集群),Nacos默认Cluster是DEFAULT,Cluster是指对指定微服务的一个虚拟划分。

比如说为了容灾,将Service微服务分别部署在黄杭州机房和广州机房,这时就可以给杭州机房的Service微服务起一个集群名称(HZ),给广州机房的Service微服务起一个集群名称(GZ),还可以让同一机房的微服务相互调用,以提升性能。

  • 最后是Instance,就是微服务的实例。

(2)DataID配置

首先我们先使用【默认空间+默认分组】来新建dev和test两个DataID。

在yml配置文件中通过spring.profile.active属性就能进行多环境下配置文件的读取:

(3)Group分组方案(实现环境的区分

在config下增加一条group的配置即可。 可配置为DEV_GROUP或TEST_GROUP

 (4)Namespace命名空间

 新建dev和test的Namespace:

回到服务列表,可以发现在public的基础上多了dev和test:

 进入配置列表dev命名空间下创建三个配置文件:

通过bootstrap+application实现命名空间区分开发环境,在config下增加一条namespace的配置即可。其值即为命名空间的ID

五、Nacos集群和持久化配置(重要)

篇幅过长,见下一篇文章:https://blog.csdn.net/friggly/article/details/126832789

SpringCloudAlibaba微服务分布式架构相关推荐

  1. 微服务分布式架构中,如何实现日志链路跟踪

    摘要:接口设计出来返回结果值和编码,还有哪些是需要我们优化的结果参数?微服务分布式架构中,如何实现日志链路跟踪? 本文分享自华为云社区<微服务分布式架构中,如何实现日志链路跟踪?>,作者: ...

  2. 全网疯传,阿里 P8 技术官的架构笔记外泄:微服务分布式架构实践手册

    前言 阿里 P8 大佬的架构笔记:微服务分布式架构实践手册从企业的真实需求出发,理论结合实际,深入讲解 Spring Cloud 微服务和分布式系统的知识. 整份笔记共分为 4 部分: 第一部分:概述 ...

  3. 微服务分布式架构中,如何实现日志链路跟踪?

    本文主要讲解了spring cloud微服务使用Feign作为微服务间的通讯框架的情况下,如何使用统一的日志ID来追踪一次请求日志,高效排查日志.核心解决了以下问题: 1.代码无入侵 2.线程池(主/ ...

  4. 一文详解微服务分布式架构

    本文将介绍微服务架构和相关的组件,介绍它们是什么以及为什么要使用微服务架构和这些组件.本文侧重于简明地表达微服务架构的全局图景,因此不会涉及具体如何使用组件等细节. 要理解微服务,首先要先理解不是微服 ...

  5. 一文详解微服务分布式架构!

    本文将介绍微服务架构和相关的组件,介绍它们是什么以及为什么要使用微服务架构和这些组件.本文侧重于简明地表达微服务架构的全局图景,因此不会涉及具体如何使用组件等细节. 要理解微服务,首先要先理解不是微服 ...

  6. 微服务分布式架构中,如何高效收集请求/响应日志

    本文主要讲述了spring cloud微服务使用Feign作为微服务间的通讯框架的情况下,如何配置统一的日志打印,能更直观地在日志中收集有效信息. (以下只提供了核心代码截图,详细代码可通过githu ...

  7. 阿里架构师推荐,微服务分布式构架开发实战PDF,快快收藏吧

    什么是微服务架构 微服务是一种软件架构风格,目标是将一个复杂的应用拆分成多个服务模块,每个模块专注单一业务功能对外提供服务,并可以独立编译及部署,同时各模块间互相通信彼此协作,组合为整体对外提供完整服 ...

  8. 微服务分布式构架开发实战PDF,阿里架构师推荐,快快收藏吧

    什么是微服务架构 微服务是一种软件架构风格,目标是将一个复杂的应用拆分成多个服务模块,每个模块专注单一业务功能对外提供服务,并可以独立编译及部署,同时各模块间互相通信彼此协作,组合为整体对外提供完整服 ...

  9. 微服务+分布式再上一“城”,腾讯云数据库TDSQL助力海峡银行新一代核心系统上线

    日前,福建海峡银行新一代核心业务系统正式上线,关键业务系统采用"微服务+分布式"架构,顺利完成数据库国产化替换. 新核心改造历时14个月,依托腾讯云企业级分布式数据库TDSQL良好 ...

最新文章

  1. 可能是最好的跨域解决方案了
  2. linux网卡O I流量查询,查看linux server网络I/0流量的shell脚本
  3. VS2010 + OpenCV 2.4.1 环境配置
  4. 浅谈.Net版(C#)的CMP模式
  5. Flutter SliverAnimatedOpacity 透明渐变动画效果
  6. python super()
  7. Python学习之not,and,or篇
  8. HDU1317 —— 最长路+判断正环
  9. PIC单片机(PIC16F15323)的环境搭建
  10. 《SAP快速入门》视频课程
  11. c语言程序设计在未来前景,转型背景下C程序设计课程的实施方案
  12. 传奇私服服务器怎么增加npc,传奇添加NPC的方法以及形象代码计算
  13. 普林斯顿邓嘉学生亲述:一定要博士学位?不,我本科生也能在大厂当应用科学家...
  14. chat--hxxdfd
  15. 在Groovy中使用字符串 - 51CTO.COM
  16. 赵小楼《天道》《遥远的救世主》深度解析(124)遇事别怕,出事别躲
  17. 有趣的“灵魂”库集合
  18. 微信小程序滚动Tab选项卡:左右滑动切换、触底加载分页
  19. 别闹,你真的会发邮件吗?
  20. 《python灰帽子》笔记--构建自己的调试器

热门文章

  1. 2017 寒假练习题 Part 1
  2. EN 13226木地板带有凹槽与舌状连接的实木地板
  3. 中国文化概论名词解释题
  4. Java包名如何命名
  5. 拍摄的多段视频怎么去掉声音?两种方法快速实现
  6. 图像处理之LUT表的使用
  7. 跟着大宇学MySQL------目录帖
  8. ICCV 2021 Oral | 姿态估计——零基础看懂RLE
  9. 别人的18岁,恐怕会碾压你的38岁
  10. SQL Server出现对象名和列名无效的解决方法