前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >从理论-实战,手把手带你图解微服务架构流程设计!

从理论-实战,手把手带你图解微服务架构流程设计!

原创
作者头像
Java程序猿
修改2021-03-21 18:25:33
4620
修改2021-03-21 18:25:33
举报
文章被收录于专栏:Java核心技术Java核心技术

前言

单体架构在中等偏小的业务中比较常见,场景模式就是单个应用、单个数据库。一个程序包(例如war格式或者Jar格式)包含所有业务需求功能,这是一种比较传统的架构风格,小编将从理论-实战,为大家剖析微服务架构

一、单体架构

  1. 复杂性高,整个项目包含的模块多,依赖模糊,修改程序容易触发不可知问题。
  2. 扩展能力受限,单体应用只能整体进行扩展,无法针对业务模块的特性进行伸缩。
  3. 稳定性差,任何微小的问题,都可能导致整个应用服务直接挂掉。

二、微服务架构

微服务架构是一种架构概念,核心思想在于通过将业务功能和需求分解到各个不同的服务中进行管理,实现对业务整体解耦。围绕业务模式创建应用服务,应用服务可独立地进行开发、迭代、部署。使项目的架构更加清晰明确。

微服务优劣势

  1. 单个服务对应单个业务功能,方便理解,开发,维护;
  2. 服务独立部署,可以根据每个服务的请求量来部署满足需求的规模;
  3. 数据库,服务,架构,业务拆分等难度增大,对技术能力要求较高;

三、项目简介

微服务架构案例核心内容,基于SpringCloud框架几个核心组件,Eureka服务注册与发现组件,Feign声明式的WebService客户端组件,Zuul动态路由网关组件。进行多个数据管理,多个服务管理搭建,多个中间件集成,多业务拆分等模式,搭建SpringCloud微服务框架的综合应用案例。

核心模块

  1. 业务拆分架构设计
  2. 多个中间件服务集成
  3. 微服务下代码分块管理
  4. 多个MySQL数据源管理

四、技术选型

1、核心框架组件

  1. 基础层框架:Spring5+,SpringBoot2+,SpringCloud2+
  2. 持久层框架:mybatis,mybatis-plus
  3. 开发组件:Druid,Log4j,FastJson,JodaTime,JavaMail
  4. 中间件集成:RocketMQ,Redis,Quart,ElasticSearch
  5. 数据存储:MySQL、Redis、ElasticSearch

2、代码分层结构

五、项目架构

1、架构图解

2、架构说明

客户端接口服务

  1. 用户端服务接口;
  2. 管理端服务接口;
  3. 数据入库服务接口;
  4. 数据分析服务接口

通用服务接口

  1. RocketMQ消息队列服务 ;
  2. ElasticSearch搜索引擎服务 ;
  3. Quart定时器服务 ;
  4. Redis缓存服务 ;
  5. 基础业务:Token认证服务 ;
  6. 基础业务:MsgBox消息中心服务 ;

微服务组件

  1. 路由网关:Zuul组件;
  2. 服务注册与发现:Eureka组件;
  3. 服务间调用组件:Feign组件;

数据存储容器

MySQL、Redis、ElasticSearch

最后

小编今日分享的学习笔记到这里就结束了,欢迎大家一起交流,喜欢文章记得关注我点赞哟!

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 一、单体架构
  • 二、微服务架构
    • 微服务优劣势
    • 三、项目简介
      • 核心模块
        • 四、技术选型
      • 1、核心框架组件
        • 2、代码分层结构
        • 五、项目架构
          • 1、架构图解
            • 2、架构说明
              • 客户端接口服务
                • 通用服务接口
                  • 微服务组件
                    • 数据存储容器
                    • 最后
                    相关产品与服务
                    云数据库 Redis
                    腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
                    领券
                    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档