当前位置: 首页 > news >正文

微服务基础概念【内含图解】

目录

拓展补充:

单体架构

分布式架构

面向服务的体系结构

云原生

微服务架构

什么是微服务?

微服务定义


拓展补充:

单体架构

        单体架构:将业务的所有功能集中在一个项目中开发,最终打成一个包部署

优点:架构简单、部署成本低

缺点:耦合度高

代码之间的“边界”模糊,万一修改一处的代码,很有可能影响到其他模块的代码

分布式架构

        分布式架构:根据业务功能对系统进行拆分,每个业务模块作为独立项目开发,称为一个服务

优点:

  • 降低服务耦合
  • 有利于服务升级

缺点:

  • 服务要拆分
  • 服务治理的问题:
  1. 服务拆分粒度如何?

  2. 服务集群地址如何维护?

  3. 服务之间如何实现远程调用?

  4. 服务健康状态如何感知?

面向服务的体系结构

【摘自百度】

面向服务的体系结构(service-oriented architecture)

        一种包含服务提供者、服务请求者和服务中介,并且遵照开放的互操作协议来实现服务共享和组合的软件体系结构。将不同的服务通过定义良好的接口和协议联系起来,这使服务可以以一种统一和通用的方式进行交互,独立于硬件平台、操作系统和编程语言

云原生

        云原生是基于分布部署和统一运管的分布式云,以容器、微服务、DevOps等技术为基础建立的一套云技术产品体系

微服务架构

微服务架构:一种经过良好架构设计的分布式架构方案

  • 单一职责:微服务拆分粒度更小,每一个服务都对应唯一的业务能力,做到单一职责,避免重复业务开发
  • 面向服务:微服务对外暴露业务接口
  • 自治:团队独立、技术独立、数据独立、部署独立
  • 隔离性强:服务调用做好隔离、容错、降级,避免出现级联问题

什么是微服务?

        维基上对其定义为:一种软件开发技术- 面向服务的体系结构(SOA)架构样式的一种变体,它提倡将单一应用程序划分成一组小的服务,服务之间互相协调、互相配合,为用户提供最终价值。每个服务运行在其独立的进程中,服务与服务间采用轻量级的通信机制互相沟通(通常是基于HTTP的RESTful API)。每个服务都围绕着具体业务进行构建,并且能够独立地部署到生产环境、类生产环境等。另外,应尽量避免统一的、集中式的服务管理机制,对具体的一个服务而言,应根据上下文,选择合适的语言、工具对其进行构建

微服务定义

        传统的单体架构的业务系统打散为更细粒度的单位,这个打小的单位就微服务

每个单位它都是可以独立的进行需求设计、开发、测试、部署和交付

每个单位都可以做到独立自治

http://www.lryc.cn/news/134893.html

相关文章:

  • Dockerfile创建 LNMP 服务+Wordpress 网站平台
  • 消息中间件篇
  • 基本定时器
  • MySQL 中文全文检索
  • Redis——list类型详解
  • npm 安装 git 仓库包
  • 问题来了!你知道你穿的防砸劳保鞋的保护包头都是什么材料
  • 计算机网络-物理层(三)编码与调制
  • Linux面试笔试题(6)
  • qt中窗口的布局
  • 玄子Share - HTML Emmet 语法详细介绍
  • Linux上安装和使用git到gitoschina和github上_亲测
  • 合宙Air724UG LuatOS-Air LVGL API--简介
  • 「Vue|网页开发|前端开发」01 快速入门:用vue-cli快速写一个Vue的HelloWorld项目
  • 7.5.tensorRT高级(2)-RAII接口模式下的生产者消费者多batch实现
  • 华为OD-最大括号深度
  • 【Leetcode】108. 将有序数组转换为二叉搜索树
  • 【树莓派打怪升级】:玩转个人Web世界!
  • mysql5.7在centos环境下的常见故障
  • hive中get_json_object函数不支持解析json中文key
  • Azure VM上意外禁用NIC如何还原恢复
  • 神经网络简单理解:机场登机
  • Sping源码(七)— 后置处理器
  • docker导出、导入镜像、提交
  • shell的变量
  • CentOS系统环境搭建(十三)——CentOS7安装nvm
  • uniapp评论列表插件获取
  • 3.redis数据结构之List
  • 安装使用MySQL8遇到的问题记录
  • Mysql、Oracle 中锁表问题解决办法