14天学习微服务-->第1天:微服务架构入门

一、微服务架构概述

微服务架构是一种将复杂应用程序分解为一组小型、独立服务的架构风格。每个服务围绕特定的业务功能构建,并且可以独立部署和扩展。这种架构风格在过去十年中迅速发展,成为构建现代分布式系统的首选方式之一。

二、微服务架构与单体架构的区别
特性 微服务架构 单体架构
服务划分 按业务功能拆分为多个独立服务 所有功能集成在一个大型应用程序中
技术栈 可以使用不同的技术栈开发不同服务 通常使用统一的技术栈
部署方式 独立部署,互不影响 整体部署,更新复杂
扩展性 按需扩展特定服务 需要整体扩展
故障隔离 单个服务故障不影响其他服务 单点故障可能导致整个系统崩溃
开发效率 多团队并行开发,效率高 大型团队协作复杂,效率低
三、微服务架构的优缺点

优点:

  1. 高可用性:服务之间相互独立,单个服务的故障不会导致整个系统崩溃。

  2. 可扩展性:可以根据业务需求独立扩展每个服务,灵活应对流量高峰。

  3. 技术多样性:允许团队根据需求选择最适合的技术栈。

  4. 快速迭代:独立部署和服务的自治性使得团队可以快速迭代和发布新功能。

缺点:

  1. 复杂性增加:分布式系统带来了网络延迟、数据一致性等问题。

  2. 运维成本高:需要管理多个服务,增加了运维的复杂性和成本。

  3. 分布式事务管理:跨服务的事务管理较为复杂,需要额外的技术支持。

四、微服务架构如何帮助企业实现高可用性、可扩展性和灵活性
  1. 高可用性:通过服务的独立部署和隔离,即使部分服务出现故障,其他服务仍可正常运行,从而提高系统的整体可用性。

  2. 可扩展性:根据业务负载动态扩展服务实例,按需分配资源,避免资源浪费。

  3. 灵活性:支持快速迭代和独立部署,团队可以更快地响应市场需求,推出新功能。

五、Spring Cloud入门

Spring Cloud 是基于 Spring Boot 的微服务框架,提供了服务注册与发现、配置中心、断路器、网关等功能,帮助开发者快速构建微服务架构。

核心组件及其功能:

  1. 服务注册与发现(Eureka)

    • 服务提供者在启动时向注册中心注册服务信息。

    • 服务消费者从注册中心获取服务列表,动态调用服务。

    示例代码:

    复制代码
    // 服务提供者:添加依赖
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>
    
    // 启动类
    @SpringBootApplication
    @EnableDiscoveryClient
    public class ServiceProviderApplication {
        public static void main(String[] args) {
            SpringApplication.run(ServiceProviderApplication.class, args);
        }
    }
    
    // application.yml
    server:
      port: 8001
    spring:
      application:
        name: service-provider
    eureka:
      client:
        service-url:
          defaultZone: http://localhost:8761/eureka/
  2. 配置中心(Config Server)

    • 集中管理配置信息,支持动态刷新配置。

    示例代码:

    复制代码
    // 配置中心:添加依赖
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-config-server</artifactId>
    </dependency>
    
    // 启动类
    @SpringBootApplication
    @EnableConfigServer
    public class ConfigServerApplication {
        public static void main(String[] args) {
            SpringApplication.run(ConfigServerApplication.class, args);
        }
    }
    
    // application.yml
    server:
      port: 8888
    spring:
      application:
        name: config-server
      cloud:
        config:
          server:
            git:
              uri: https://github.com/your-repo/config-repo
  3. 断路器(Hystrix)

    • 防止服务雪崩,提供降级和熔断机制。

    示例代码:

    复制代码
    // 添加依赖
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
    </dependency>
    
    // 服务消费者
    @SpringBootApplication
    @EnableDiscoveryClient
    @EnableHystrix
    public class ServiceConsumerApplication {
        public static void main(String[] args) {
            SpringApplication.run(ServiceConsumerApplication.class, args);
        }
    }
    
    @RestController
    public class ConsumerController {
        @Autowired
        private RestTemplate restTemplate;
        
        @HystrixCommand(fallbackMethod = "fallback")
        public String callService() {
            return restTemplate.getForObject("http://service-provider/hello", String.class);
        }
        
        public String fallback() {
            return "Service is down!";
        }
    }
六、总结

微服务架构通过将复杂系统拆分为独立的服务,极大地提高了系统的高可用性、可扩展性和灵活性。Spring Cloud 提供了一系列强大的组件,帮助开发者快速构建和管理微服务。在学习微服务的过程中,我们需要关注其核心概念和优势,同时也要注意分布式系统带来的复杂性。希望今天的入门内容能为你打开微服务的大门,让我们一起在接下来的14天里深入探索微服务的奥秘!


感悟与启示:

微服务架构是现代软件开发的重要趋势,它不仅改变了我们构建系统的思维方式,还为企业带来了更高的灵活性和竞争力。在学习微服务的过程中,建议从实际问题出发,结合Spring Cloud的组件逐步深入实践。同时,关注架构设计的合理性,避免过度拆分导致的复杂性增加。

相关推荐
●VON16 分钟前
HarmonyOS应用开发实战(基础篇)Day01-《ArkTS基本知识》
学习·华为·harmonyos·鸿蒙·von
玄同76529 分钟前
Python Random 模块深度解析:从基础 API 到 AI / 大模型工程化实践
人工智能·笔记·python·学习·算法·语言模型·llm
符哥200832 分钟前
C++ 适合初学者的学习笔记整理
c++·笔记·学习
曦月逸霜39 分钟前
Python快速入门——学习笔记(持续更新中~)
笔记·python·学习
啊森要自信40 分钟前
CANN ops-cv:揭秘视觉算子的硬件感知优化与内存高效利用设计精髓
人工智能·深度学习·架构·transformer·cann
AI视觉网奇42 分钟前
blender 导入fbx 黑色骨骼
学习·算法·ue5·blender
国强_dev42 分钟前
轻量级实时数仓架构选型指南
架构
星火开发设计43 分钟前
this 指针:指向对象自身的隐含指针
开发语言·数据结构·c++·学习·指针·知识
roman_日积跬步-终至千里44 分钟前
【系统架构设计-综合题】计算机系统基础(1)
架构
Gain_chance1 小时前
37-学习笔记尚硅谷数仓搭建-ADS层分析并以各品牌商品下单统计为例
笔记·学习