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的组件逐步深入实践。同时,关注架构设计的合理性,避免过度拆分导致的复杂性增加。

相关推荐
m0_7482405410 分钟前
AutoSar架构学习笔记
笔记·学习·架构
剑客狼心17 分钟前
OneData体系架构详解
架构·onedata
siy23332 小时前
[c语言日寄]结构体的使用及其拓展
c语言·开发语言·笔记·学习·算法
mit6.8243 小时前
What is Json?
c++·学习·json
ps酷教程3 小时前
sentinel微服务保护
微服务·架构·sentinel
拾忆,想起3 小时前
微服务入门:从零开始构建你的微服务架构
spring·spring cloud·微服务·架构
ThisIsClark3 小时前
【gopher的java学习笔记】Java中Mapper与Entity的关系详解
java·笔记·学习
m0_548049703 小时前
SpringCloud学习笔记【尚硅谷2024版】
笔记·学习·spring cloud