【java面经】微服务架构速记

目录

由来

是什么

本质

和单体架构的区别

适用项目

开发框架

[Spring Cloud(流行)](#Spring Cloud(流行))

Dubbo

Dropwizard

Consul,etcd&etc(微服务的模块)

由来

独立系统,SOA服务切换时间长,成本高,不够稳定

是什么

  • 一套小服务来开发单个应用,每个服务运行在自己的进程中,使用HTTP API等轻量级机制通信
  • 服务可以使用不同编程语言实现,不同数据存储技术
  • 最低限度集中管理

本质

  • 目的是有效拆分应用,实现敏捷开发和部署
  • inter-operate:定义好系统边界和接口,系统内部耦合和沟通,最终呈现出统一风格界面,权限管理,安全策略等等

和单体架构的区别

  • 单体架构代码量大,维护困难;微服务每个模块相当于单独项目,代码明显减少,好解决问题
  • 单体架构所有模块使用同一数据库,存储方式单一(岂不是不安全?);微服务架构每个模块可以有自己的存储方式(redis,mysql等等),数据库也是单个模块对应的数据库
  • 单体架构所有模块开发使用的技术一样;微服务开发模式更灵魂,可以有不同的开发技术

适用项目

按照业务本身独立性来划分,如果是非常底层的(操作系统内核,存储系统,网络系统,数据库系统等)就不要使用微服务,否则造成集成工作量急剧上升

开发框架

Spring Cloud(流行)

http://projects.spring.io/spring-cloud

Dubbo

http://dubbo.io

Dropwizard

http://www.dropwizard.io (关注单个微服务的开发)

Consul,etcd&etc(微服务的模块)
相关推荐
24k小善20 分钟前
Flink TaskManager详解
java·大数据·flink·云计算
杜小暑24 分钟前
动态内存管理
c语言·开发语言·动态内存管理
想不明白的过度思考者25 分钟前
Java从入门到“放弃”(精通)之旅——JavaSE终篇(异常)
java·开发语言
我真的不会C1 小时前
QT窗口相关控件及其属性
开发语言·qt
CodeCraft Studio1 小时前
Excel处理控件Aspose.Cells教程:使用 Python 在 Excel 中进行数据验
开发语言·python·excel
.生产的驴1 小时前
SpringBoot 封装统一API返回格式对象 标准化开发 请求封装 统一格式处理
java·数据库·spring boot·后端·spring·eclipse·maven
火柴盒zhang1 小时前
websheet之 编辑器
开发语言·前端·javascript·编辑器·spreadsheet·websheet
Pasregret1 小时前
多级缓存架构深度解析:从设计原理到生产实践
缓存·架构
国科安芯1 小时前
面向高性能运动控制的MCU:架构创新、算法优化与应用分析
单片机·嵌入式硬件·安全·架构·机器人·汽车·risc-v
猿周LV1 小时前
JMeter 安装及使用 [软件测试工具]
java·测试工具·jmeter·单元测试·压力测试