微服务架构、springCloud组件和概念详解

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 一:什么是微服务(Microservice)    微服务英文名称Microservice,Microservice架构模式就是将整个Web应用组织为一系列小的Web服务。

一:什么是微服务(Microservice)

    微服务英文名称Microservice,Microservice架构模式就是将整个Web应用组织为一系列小的Web服务。这些小的Web服务可以独立地编译及部署,并通过各自暴露的API接口相互通讯。它们彼此相互协作,作为一个整体为用户提供功能,却可以独立地进行扩。

       微服务架构需要的功能或使用场景

 1:我们把整个系统根据业务拆分成几个子系统。

 2:每个子系统可以部署多个应用,多个应用之间使用负载均衡。

 3:需要一个服务注册中心,所有的服务都在注册中心注册,负载均衡也是通过在注册中心注册的服务来使用一定策略来实现。

 4:所有的客户端都通过同一个网关地址访问后台的服务,通过路由配置,网关来判断一个URL请求由哪个服务处理。请求转发        到服务上的时候也使用负载均衡。

 5:服务之间有时候也需要相互访问。例如有一个用户模块,其他服务在处理一些业务的时候,要获取用户服务的用户数据。

 6:需要一个断路器,及时处理服务调用时的超时和错误,防止由于其中一个服务的问题而导致整体系统的瘫痪。

 7:还需要一个监控功能,监控每个服务调用花费的时间等。

     目前主流的微服务框架:Dubbo、 SpringCloud、thrift、Hessian等,目前国内的中小企业用的大多数都是Dubbo,SpringCloud估计很少,也许有些开发同学都没听说过。

  

二:SpringCloud项目简介

   springCloud是基于SpringBoot的一整套实现微服务的框架。他提供了微服务开发所需的配置管理、服务发现、断路器、智能路由、微代理、控制总线、全局锁、决策竞选、分布式会话和集群状态管理等组件。最重要的是,

      跟spring boot框架一起使用的话,会让你开发微服务架构的云服务非常好的方便。

     SpringBoot旨在简化创建产品级的 Spring 应用和服务,简化了配置文件,使用嵌入式web服务器,含有诸多开箱即用微服务功能

  相关组件架构图

  

  spring cloud子项目包括:

  1. Spring Cloud Config:配置管理开发工具包,可以让你把配置放到远程服务器,目前支持本地存储、Git以及Subversion。

  2. Spring Cloud Bus:事件、消息总线,用于在集群(例如,配置变化事件)中传播状态变化,可与Spring Cloud Config联合实现热部署。

  3. Spring Cloud Netflix:针对多种Netflix组件提供的开发工具包,其中包括Eureka、Hystrix、Zuul、Archaius等。

         (1)Netflix Eureka:云端负载均衡,一个基于 REST 的服务,用于定位服务,以实现云端的负载均衡和中间层服务器的故障转移;

         (2) Netflix Hystrix:容错管理工具,旨在通过控制服务和第三方库的节点,从而对延迟和故障提供更强大的容错能力。

         (3)Netflix Zuul:边缘服务工具,是提供动态路由,监控,弹性,安全等的边缘服务。

         (4)Netflix Archaius:配置管理API,包含一系列配置管理API,提供动态类型化属性、线程安全配置操作、轮询框架、回调机制等功能。

4. Spring Cloud for Cloud Foundry:通过Oauth2协议绑定服务到CloudFoundry,CloudFoundry是VMware推出的开源PaaS云平台。

5. Spring Cloud Sleuth:日志收集工具包,封装了Dapper,Zipkin和HTrace操作。

6. Spring Cloud Data Flow:大数据操作工具,通过命令行方式操作数据流。

7. Spring Cloud Security:安全工具包,为你的应用程序添加安全控制,主要是指OAuth2。

8. Spring Cloud Consul:封装了Consul操作,consul是一个服务发现与配置工具,与Docker容器可以无缝集成。

9. Spring Cloud Zookeeper:操作Zookeeper的工具包,用于使用zookeeper方式的服务注册和发现。

10. Spring Cloud Stream:数据流操作开发包,封装了与Redis,Rabbit、Kafka等发送接收消息。

11. Spring Cloud CLI:基于 Spring Boot CLI,可以让你以命令行方式快速建立云组件。

 

     SpringCloud特点

1:约定优于配置

2:开箱即用、快速启动

3:适用于各种环境

4:轻量级的组件

5:组件支持丰富,功能齐全

三: SpringBoot了解

       Spring Boot让我们的Spring应用变的更轻量化。比如:你可以仅仅依靠一个Java类来运行一个Spring引用。你也可以打包你的应用为jar并通过使用java -jar来运行你的Spring Web应用。

      由于SpringCloud依赖SpringBoot,所以在学习SpringCloud框架之前需要了解下SpringBoot。

      SpringBoot的主要优点:

1:为所有Spring开发者更快的入门

2:开箱即用,提供各种默认配置来简化项目配置

3:内嵌式容器简化Web项目

4:没有冗余代码生成和XML配置的要求

      通过一个helloWorld了解下 地址:http://start.spring.io/

      本文主要介绍了相关概念的东西实际操作和应用在后面的文中慢慢介绍

相关资料:中文网:https://springcloud.cc/

                  英文官网:https://spring.io/projects

原文网址:https://www.cnblogs.com/xiaojunbo/p/7090742.html

相关实践学习
部署高可用架构
本场景主要介绍如何使用云服务器ECS、负载均衡SLB、云数据库RDS和数据传输服务产品来部署多可用区高可用架构。
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
23小时前
|
运维 负载均衡 API
构建高效微服务架构的七大关键策略
【5月更文挑战第27天】 在当前企业级应用开发中,微服务架构已成为实现敏捷、可扩展和灵活部署的主流解决方案。本文将深入探讨构建和维护一个高效微服务系统的七个关键策略,包括服务划分原则、API网关设计、服务发现与注册、配置管理、熔断机制、分布式跟踪及持续集成和部署。这些策略不仅有助于提升系统的稳定性和弹性,还能确保在不断变化的业务需求面前,系统能够快速响应并保持高效的运行状态。
|
1天前
|
机器学习/深度学习 监控 持续交付
构建高效微服务架构:后端开发的新趋势探索深度学习在图像识别中的边界
【5月更文挑战第27天】随着业务需求的快速变化和市场竞争的激烈,企业需要更灵活、高效和可扩展的系统来支持其运营。微服务架构作为一种新兴的软件开发模式,已经成为后端开发领域的热门话题。本文将深入探讨微服务架构的概念、优势以及如何构建一个高效的微服务架构,帮助后端开发者更好地应对业务挑战。 【5月更文挑战第27天】 随着人工智能的不断进步,深度学习技术已经在图像识别领域取得了显著成就。本文将深入探讨深度学习模型在处理复杂图像数据时的挑战与机遇,分析现有技术的局限性,并提出潜在的改进方向。通过实验验证,我们将展示如何通过创新的网络架构、数据增强策略和损失函数设计来提升模型性能。本研究不仅为深度学习
|
1天前
|
监控 安全 数据管理
构建高效微服务架构的五大核心要素
【5月更文挑战第27天】在现代软件开发中,微服务架构以其灵活性、可扩展性和容错性而受到企业青睐。本文将深入探讨构建一个高效微服务架构所需的五大核心要素:服务划分策略、通信机制、数据管理、安全性和监控与日志系统。这些要素是确保微服务架构能够高效运行并适应快速变化需求的关键。我们将逐一解析每个要素的重要性及其实现方法,为后端开发者提供一套全面的指导原则和实践技巧。
|
1天前
|
消息中间件 缓存 数据库
构建高性能微服务架构:从理论到实践
【5月更文挑战第27天】在现代软件开发中,微服务架构已成为实现可扩展、灵活和容错系统的关键设计模式。本文将深入探讨如何构建一个高性能的微服务系统,包括关键的设计理念、技术选型以及性能优化策略。我们将通过分析真实案例,提供一套实用的指导原则和最佳实践,帮助开发者提升系统的响应速度和处理能力,从而满足不断变化的业务需求。
|
1天前
|
存储 运维 监控
探索微服务架构下的系统监控策略
【5月更文挑战第27天】在当今快速迭代和持续部署盛行的软件工程实践中,微服务架构以其灵活性、可扩展性成为了众多企业技术选型的宠儿。然而,随之而来的复杂性也给系统监控带来了前所未有的挑战。本文深入剖析了在微服务环境中实施有效监控的策略,探讨了如何通过日志聚合、性能指标监控与分布式追踪技术相结合,实现对微服务生态系统的全方位把控。我们将分享一系列实践经验,并讨论监控策略的最佳实践,以期为面临类似挑战的开发者和运维团队提供参考。
|
1天前
|
存储 监控 安全
构建高效微服务架构:后端开发的新范式
【5月更文挑战第27天】随着现代软件开发的复杂性日益增加,传统的单体应用架构面临着可扩展性和维护性的瓶颈。本文探讨了采用微服务架构作为解决方案的优势与挑战,并详细阐述了在设计、部署和优化微服务过程中的关键实践和技术考量。通过将大型应用程序拆分成一系列小型、自治的服务,开发团队可以更灵活地应对市场变化,提高系统的可靠性,同时促进技术创新。
|
1天前
|
消息中间件 监控 持续交付
构建高效微服务架构:后端开发的新范式
【5月更文挑战第27天】在现代软件开发领域,随着业务需求的不断复杂化和开发团队规模的增长,传统的单体应用架构逐渐显得笨重且难以维护。微服务架构作为解决这一问题的银弹,其设计理念是拆分大型应用程序为一系列小型、自治的服务单元,每个单元负责一个功能模块并独立运行在其各自的进程中。本文探讨了微服务架构的设计原则、技术选型、以及在实施过程中可能面临的挑战,并提供了一系列解决方案和最佳实践,旨在帮助后端开发人员构建更加灵活、可扩展且高效的系统。
|
1天前
|
消息中间件 持续交付 开发者
构建高效的微服务架构:后端开发的新范式
【5月更文挑战第27天】在现代软件开发中,微服务架构已经成为一种流行的设计模式,它通过将大型应用程序拆分成一组小型、松散耦合的服务来提供灵活性和可扩展性。本文将探讨微服务架构的关键概念、优势以及如何在实际项目中实现这种架构。我们将重点关注后端开发的挑战,包括服务的划分、通信、数据一致性和安全性等方面,并提供实用的解决方案和最佳实践。
|
1天前
|
监控 负载均衡 数据库
构建高效微服务架构:后端开发者的技术挑战与策略
【5月更文挑战第27天】 在数字化转型的浪潮中,微服务架构已成为软件开发的一大趋势。它通过拆分传统单体应用,实现服务的细粒度管理和独立部署,从而提高了系统的可扩展性和灵活性。然而,随之而来的是一系列技术挑战,包括服务治理、数据一致性、网络延迟等问题。本文将探讨这些挑战并提出相应的解决策略,以帮助后端开发者构建和维护一个高效的微服务系统。
|
1天前
|
监控 API 持续交付
构建高效微服务架构:后端开发的新范式
【5月更文挑战第27天】随着现代软件系统的复杂性日益增长,传统的单体应用架构已难以满足快速迭代和灵活部署的需求。微服务架构作为一种新兴的后端开发模式,以其高度模块化和独立部署的特性,为解决这一难题提供了有效的解决方案。本文将深入探讨微服务架构的设计原则、核心技术以及在实现中的最佳实践,旨在为后端开发人员提供构建和维护高效、可靠微服务系统的指导。