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

相关推荐
小马爱打代码3 小时前
微服务外联Feign调用:第三方API调用的负载均衡与容灾实战
微服务·架构·负载均衡
9527华安7 小时前
FPGA实现40G网卡NIC,基于PCIE4C+40G/50G Ethernet subsystem架构,提供工程源码和技术支持
fpga开发·架构·网卡·ethernet·nic·40g·pcie4c
码荼7 小时前
学习开发之hashmap
java·python·学习·哈希算法·个人开发·小白学开发·不花钱不花时间crud
武昌库里写JAVA8 小时前
Oracle如何使用序列 Oracle序列使用教程
java·开发语言·spring boot·学习·课程设计
祁思妙想9 小时前
八股学习(三)---MySQL
数据库·学习·mysql
amazinging10 小时前
北京-4年功能测试2年空窗-报培训班学测开-第四十一天
python·学习·appium
Jyywww12110 小时前
微信小程序学习笔记
笔记·学习·微信小程序
amazinging10 小时前
北京-4年功能测试2年空窗-报培训班学测开-第三十九天
python·学习·appium
每次的天空10 小时前
Android-自定义View的实战学习总结
android·学习·kotlin·音视频
重庆小透明10 小时前
力扣刷题记录【1】146.LRU缓存
java·后端·学习·算法·leetcode·缓存