• 细解“微服务”架构体系——SpringCloud Alibaba!


    01 前言

    "微服务”一词源于 Martin Fowler的名为 Microservices的,博文,可以在他的官方博客上找到http:/ /martinfowler . com/articles/microservices.html简单地说,微服务是系统架构上的一种设计风格,它的主旨是将一个原本独立的系统拆分成多个小型服务,这些小型服务都在各自独立的进程中运行,服务之间通过基于HTTP的 RESTfuL AP进行通信协作。常见微服务框架:Spring的spring cloud、阿里dubbo、华为ServiceComb、腾讯Tars、Facebook thrift、新浪微博Motan。本章节我们先从了解组成完整系统的各个组件开始,下章节将利用这些组件,搭建出一个完善的分布式系统。

    1.1 Spring Cloud

    这就不用多说了,官网有详细的介绍。

    1.2 Spring Cloud Alibaba

    Spring Cloud Alibaba 致力于提供微服务开发的一站式解决方案。此项目包含开发分布式应用微服务的必需组件,方便开发者通过 Spring Cloud 编程模型轻松使用这些组件来开发分布式应用服务

    主要组件
    Sentinel:把流量作为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。
    Nacos:一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
    RocketMQ:一款开源的分布式消息系统,基于高可用分布式集群技术,提供低延时的、高可靠的消息发布与订阅服务。
    Dubbo:Apache Dubbo™ 是一款高性能 Java RPC 框架。
    Seata:阿里巴巴开源产品,一个易于使用的高性能微服务分布式事务解决方案。

    02 服务注册与发现

    Eureka:官方宣布2.x不再开源(闭源),之前的版本已经停止更新;也就说Eureka将来更多的技术提升已经没有了。所以,如果希望注册中心有更多强大功能的话,还需要另辟蹊径 。
    Zookeeper:在企业级Zookeeper注册中心与 Dubbo组合比较多一些,kafka使用的也是,随着Eureka的停更,我们可以通过spring-cloud-starter-zookeeper-discovery这个启动器,将Zookeeper做为springcloud的注册中心。
    Consul:go语言开发的,也是一个优秀的服务注册框架,使用量也比较多。
    Nacos:来自于SpringCloudɵɹibaba,在企业中经过了百万级注册考验的,不但可以完美替换Eureka,还能做其他组件的替换,所以,Naocs也强烈建议使用。

    2.1 介绍下Nacos用作注册中心

    (1)Nacos简介

    Nacos(Dynamic Naming and Configur ation Service) 是阿里巴巴2018年7月开源的项目,致力于发现、配置和管理微服务。

    (2)Nacos安装

    单节点

    1. --下载镜像
    2. docker pull nacos/nacos-server:1.3.1
    3. --启动容器
    4. docker run --name nacos --env MODE=standalone --privileged=true -p 8848:8848 --restart=always -d dc833dc45d8f

    访问:

    http://127.0.0.1:8848/nacos 账号密码都是nacos

    集群

    安装前提

    1. 64 bit OS Linux/Unix/Mac,推荐使用Linux系统。
    2. 集群需要依赖mysql,单机可不必
    3. 3个或3个以上Nacos节点才能构成集群

    (3)搭建Nacos高可用集群步骤:

    1、需要去Nacos官网clone Nacos集群项目nacos-docker
    2、nacos-docker是使用的Docker Compose对容器进行编排,所以首先需要安装Docker Compose详细信息可参照Nacos官网:https:/ /http://nacos.io/zh-cn/docs/quick-start-docker.html

    1)安装Docker Compose
    什么是Docker Compose
    Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。

    1. #在Linux下下载(下载到/usr/local/bin)
    2. curl -L https://github.com/docker/compose/releases/download/1.25.0/run.sh > /usr/local/bin/docker-compose
    3. # 设置文件可执行权限
    4. chmod +x /usr/local/bin/docker-compose
    5. # 查看版本信息
    6. docker-compose --version

    2)克隆Nacos-docker项目

    1. #切换到自定义目录
    2. cd /usr/local/nacos
    3. #开始clone
    4. git clone https://github.com/nacos-group/nacos-docker.git

    3)运行nacos-docker脚本

    1. #执行编排命令
    2. docker-compose -f /usr/local/nacos/nacos-docker/example/cluster-hostname.yaml up

    上面的编排命令主要下载mysql镜像和nacos镜像,自动完成镜像下载/容器启动
    Pulling from nacos/nacos-mysql,版本是5. 7(执行初始化脚本)
    Pulling nacos3 (nacos/nacos-server:latest)最新版本

    4)停止、启动

    1. #启动
    2. docker-compose -f /usr/local/nacos/nacos-docker/example/cluster-hostname.yaml start
    3. #停止
    4. docker-compose -f /usr/local/nacos/nacos-docker/example/cluster-hostname.yaml stop

    5)访问Nacos

    1. http://192.168.1.1:8848/nacos
    2. http://192.168.1.1:8849/nacos
    3. http://192.168.1.1:8850/nacos

    (4)Nacos快速入门

    配置服务提供者

    服务提供者可以通过 Nacos 的服务注册发现功能将其服务注册到 Nacos server 上。

    添加nacos依赖

    1. <dependency>
    2. <groupId>com.alibaba.cloud</groupId>
    3. <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    4. <version>${latest.version}</version>
    5. </dependency>

    添加配置

    1. server.port=8070
    2. spring.application.name=nacos-demo
    3. spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848

    启动类

    1. @SpringBootApplication
    2. @EnableDiscoveryClient
    3. public class NacosProviderApplication {
    4. public static void main(String[] args) {
    5. SpringApplication.run(NacosProviderApplication.class, args);
    6. }
    7. @RestController
    8. class EchoController {
    9. @RequestMapping(value = "/echo/{string}", method = RequestMethod.GET)
    10. public String echo(@PathVariable String string) {
    11. return "Hello Nacos Discovery " + string;
    12. }
    13. }
    14. }

    启动后,控制台:

    说明注册成功,后台查看该服务:

    下面我们用spring cloud 整合naocs实现服务调用

    配置服务消费者

    添加配置

    1. server.port=8080
    2. spring.application.name=service-consumer
    3. spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848

    添加启动类:服务消费者使用 @LoadBalanced RestTemplate 实现服务调用

    1. @SpringBootApplication
    2. @EnableDiscoveryClient
    3. public class NacosConsumerApplication {
    4. @LoadBalanced
    5. @Bean
    6. public RestTemplate restTemplate() {
    7. return new RestTemplate();
    8. }
    9. public static void main(String[] args) {
    10. SpringApplication.run(NacosConsumerApplication.class, args);
    11. }
    12. @RestController
    13. public class TestController {
    14. private final RestTemplate restTemplate;
    15. @Autowired
    16. public TestController(RestTemplate restTemplate) {this.restTemplate = restTemplate;}
    17. @RequestMapping(value = "/echo/{str}", method = RequestMethod.GET)
    18. public String echo(@PathVariable String str) {
    19. return restTemplate.getForObject("http://service-provider/echo/" + str, String.class);
    20. }
    21. }
    22. }

    (5)测试

    启动 ProviderApplication 和 ConsumerApplication ,调用 http://localhost:8080/echo/2018,返回内容为 Hello Nacos Discovery 2018。

    03 分布式配置中心解决方案与应用

    目前市面上用的比较多的配置中心有(时间顺序)
    Disconf:2014年7月百度开源的配置管理中心,同样具备配置的管理能力,不过目前已经不维护了,最近的一次提交是4-5年前了。
    Spring Cloud Configÿ

  • 相关阅读:
    编程开发中的的字符编码与解码-原理篇
    Android13 下拉菜单栏中添加快捷截图按钮
    2022年6月青少年机器人技术等级考试(一级)实际操作试卷
    Vue3-shallowRef与shallowReactive
    Access-Control-Allow-Origin跨域问题,使用Nginx配置来解决
    SpringBoot数据层测试事务回滚
    FullCalendarDemo5 控件的实例讲解—拖拽实现值班排班(二)
    基于Web的商城后台管理系统的设计与实现
    杭电oj 2037 今年暑假不AC C语言
    【Game Of AutoTest】3、游戏自动化测试的框架设计
  • 原文地址:https://blog.csdn.net/weixin_66896902/article/details/126849278