容器 - 八大架构的演进

Docker

容器虚拟化核心技术+docker生态、架构及组成部分+容器编排详解+核心原理实现

我目前就来学学基本知识。

八大架构的演进

文章目录

  • Docker
  • 八大架构的演进
    • 1. 单机架构
    • 2. 应用数据分离架构
    • 3. 应用服务集群架构
    • 4. 读写分离/主从分离架构
    • 5. 冷热分离架构
    • 6. 垂直分库架构/分布式数据库架构
    • 7. 微服务架构
    • 8. 容器编排架构

1. 单机架构

所有服务部署在一台服务器上

  • 出现原因:互联网早期,访问量小,单机足以满足需求
  • 架构原理:以电子商城为例,应用和数据库在蛋哥服务器上写作完成业务
  • 架构优缺点:
    • 部署简单,成本低
    • 性能瓶颈,数据库和应用相互竞争资源

2. 应用数据分离架构

应用和数据库服务使用不同服务器

  • 出现原因:单机存在严重的资源竞争,导致站点变慢
  • 工作原理:应用与数据在各自服务器上通过网络写作完成
  • 优缺点:
    • 成本相对可控;性能相对提升;隔离,一定的容灾能力
    • 硬件成本变高。性能有瓶颈,无法应对海量并发

3. 应用服务集群架构

引入了负载均衡(DNS ip分配;LVS/F5硬件;Nginx,应用,多级挂载),应用以集群方式运作

  • 出现原因:单个应用不足以支持海量的并发请求,高并发的时候站点响应变慢
  • 优缺点:
    • 应用服务高可用;应用服务具备一定的高性能;应用支持横向扩展
    • 数据库单点;运维工作量增加;硬件成本较高

4. 读写分离/主从分离架构

将数据库读写分散到不同节点上,数据库服务器搭建主从集群(一主一从,一主多从),大哥负责写,小弟负责读。

  • 出现原因:数据库成为瓶颈,期号互联网应用读多写少,干啥找谁(加一层mycat/tddr)

  • 架构工作原理:数据库主机通过复制同步

  • 优缺点:

    • 数据库读取性能提升;写也间接提升;可用性高
    • 热点数据频繁读取导致数据库负载很高;同步延迟;服务器成本增高

5. 冷热分离架构

引入缓存,实行冷热分离,将热点数据放入缓存中

  • 出现原因:海量请求负载过高
  • 架构工作原理:多了缓存服务器(Redis集群化)
  • 优缺点:
    • 大幅降低数据库的访问请求,性能提升非常明显
    • 缓存一致性,缓存击穿,缓存失效;
    • 单个表体量太大,数据查询很慢

6. 垂直分库架构/分布式数据库架构

数据库的数据被拆分,分布式存储处理和查询

  • 出现原因:单机写库逐渐达到性能瓶颈
  • 优缺点:
    • 跨库join,分布式事务等问题,需要解决方案,目前的mpp都有对应的解决方案
    • 数据库和缓存结合目前能抗住海量的请求,但应用的代码耦合在一起,修改一行需要整体重新发布。

7. 微服务架构

按照业务板块来划分应用代码,使单个应用的职责更清晰,可以单独升级迭代。springcloud double

  • 出现原因:扩展性差;持续开发困难;不可靠;不灵活;代码维护困难
  • 缺点:运维复杂度高;资源使用变多;处理故障困难

8. 容器编排架构

借助容器化技术(如docker)将应用/服务打包成镜像

优点:

  • 部署运维简单:一条命令完成几百个服务的部署和扩容
  • 隔离性好:容器与容器之间的文件系统、网络等相互隔离,不会产生环境冲突

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/155353.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OpenAI 的 API 简介

OpenAI Completions API 是 OpenAI 提供的一项服务,允许开发者利用 OpenAI 的语言模型(例如 GPT-3 或 GPT-4)生成文本。当开发者向该 API 提供一个文本提示(prompt)时,语言模型会尝试生成一个自然且连贯的文…

流程变量的设置和获取

流程变量在整个工作流中扮演很重要的作用。例如:请假流程中有请假天数、请假原因等一些参数都为流程变量的范围。流程变量的作用域范围是只对应一个流程实例。也就是说各个流程实例的流程变量是不相互影响的。这篇博文就简单的为大家介绍下流程变量的设置和获取。 …

【路径最全用法】python代码讲解os.path包的最全用法

目录 概览 🚗🚗os.getcwd() 🚗🚗os.chdir() 🚗🚗os.path.abspath(path) 🚗🚗os.path.basename(path) 🚗​​​​​​​🚗os.path.dirname(path) &#…

细节决定成败——我的日志去哪了?

概述 编写本文档的目的有两点。 本周遇到了一个日志丢失的问题,经过分析,觉得挺有意思的。向大家分享一下我的分析及解决思路。应该在很多项目中都会有该问题。领导和我私下讨论过多次,当前的autodomain代码对文件读取的频率太高了,如何去避…

Spring框架学习 -- 核心思想

目录 (1) Spring是什么? (2) 什么是IOC容器? (3) 从传统开发认识spring (4) 这种传统开发的缺陷 (5)解决传统开发中的缺陷 (6) 对比总结规律 (7) 理解IOC 创作不易多多支持 (1) Spring是什么? 我们常说的Spring的全称是: Spring Framework(Spring框架), 它是一个开源…

使用 Core Tools 在本地开发 Azure Functions

学习模块 使用 Core Tools 在本地创建和运行 Azure Functions - Training | Microsoft Learn 文档 使用 Core Tools 在本地开发 Azure Functions | Microsoft Learn GitHub - Azure/azure-functions-core-tools: Command line tools for Azure Functions 其它 安装适用于 A…

纯css实现边界检测小球动画

文章目录 前言实现环境话不多说直接上代码后言 前言 hello world欢迎来到前端的新世界 😜当前文章系列专栏:css实现炫酷的动画 🐱‍👓博主在前端领域还有很多知识和技术需要掌握,正在不断努力填补技术短板。(如果出现错…

北醒携全球首款256线车规量产激光雷达亮相广州国际车展

11月17日,北醒携全球首款256线车规量产激光雷达亮相广州国际车展。在车展期间,北醒还公布了与广州花都区人民政府达成投资合作,获滴滴自动驾驶投资以及与捷普联合打造的全球首条量产256线级别车规激光雷达的生产线即将贯通的等多条利好信息&a…

2023-11-20 LeetCode每日一题(最大子数组和)

2023-11-20每日一题 一、题目编号 53. 最大子数组和二、题目链接 点击跳转到题目位置 三、题目描述 给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。 子数组 是数组中的…

使用dlopenC++动态库的函数符号的常规做法

文章目录 一、Name Mangling二、extern "C"三、Loading Functions四、Loading Classes参考 一、Name Mangling 在 C 中,符号名称与函数名称相同:strcpy 的符号将是 strcpy,因为在 C 中没有两个非静态函数可以具有相同的名称。 因…

C语言童年生活二三事(ZZULIOJ1091:童年生活二三事(多实例测试))

题目描述 Redraiment小时候走路喜欢蹦蹦跳跳,他最喜欢在楼梯上跳来跳去。 但年幼的他一次只能走上一阶或者一下子蹦上两阶。 现在一共有N阶台阶,请你计算一下Redraiment从第0阶到第N阶共有几种走法。 输入:输入包括多组数据。 每组数据包括一…

antd design 5 版本 文件上传

<UploadcustomRequest{customRequest}accept".csv" showUploadList{false}><Button icon{<UploadOutlined />}>上传 CSV 文件</Button></Upload> accept 代表限制的上传类型 也可设置 .excel // 文件上传 ( CSV ) const customReques…

Python开源自动化工具Playwright安装及介绍

一个非常强大的自动化项目叫 playwright-python 它支持主流的浏览器&#xff0c;包含&#xff1a;Chrome、Firefox、Safari、Microsoft Edge 等&#xff0c;同时支持以无头模式、有头模式运行&#xff0c;并提供了同步、异步的 API&#xff0c;可以结合 Pytest 测试框架 使用&…

Kafka(四)消费者消费消息

文章目录 如何确保不重复消费消息&#xff1f;消费者业务逻辑重试消费者提交自定义反序列化类消费者参数配置及其说明重要的参数session.time.ms和heartbeat.interval.ms和group.instance.id增加消费者的吞吐量消费者消费的超时时间和poll()方法的关系 消费者消费逻辑启动消费者…

万宾科技智能井盖传感器,提升市政井盖健康

市政井盖就是城市里不可或缺的基础设施之一&#xff0c;关于它的监测工作可马虎不得。它承载着保护市民的交通安全以及城市正常运转的重要使命。虽然现在城市化的速度很快&#xff0c;但是传统的市政井盖管理方式变得有些力不从心了。井盖的覆盖范围很广&#xff0c;如果单单依…

Python 安装win32com失败

今天进行服务器迁移&#xff0c; 中间有用的python调用win32com组件让docx转换成pdf。不出意外的话出意外了&#xff0c;pip安装win32com的时候各种安装不上&#xff0c; 今天处理完问题之后&#xff0c;记录一下&#xff0c;与人方便与己方便。 在cmd上面&#xff0c;一开始…

【0235】修改私有内存(private memory)中的MyBEEntry时,st_changecount值前后变化

上一篇: 【0234】PgBackendStatus 记录当前postgres进程的活动状态 1. pg_stat_activity中xxx实时信息如何实现? 客户端(eg:psql)在连接上postmaster之后,postmaster守护进程会fork()一个后端进场(backend process),之后此客户端的所有操作、交互均有此对应的Backen…

智慧安防监控系统EasyCVR(v3.4)开放协议的介绍及使用

安防视频监控系统EasyCVR平台可拓展性强、视频能力灵活、部署轻快&#xff0c;可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等&#xff0c;以及支持厂家私有协议与SDK接入&#xff0c;包括海康Ehome、海大宇等设备的SDK等。平台可拓展性强、视频能力灵活&#xff0c;能…

2023最新软件测试20个基础面试题及答案

什么是软件测试&#xff1f; 答案&#xff1a;软件测试是指在预定的环境中运行程序&#xff0c;为了发现软件存在的错误、缺陷以及其他不符合要求的行为的过程。 软件测试的目的是什么&#xff1f; 答案&#xff1a;软件测试的主要目的是保证软件的质量&#xff0c;并尽可能大…

Kotlin 核心语法,为什么选择Kotlin ?

Kotlin 是一个基于 JVM 的新的编程语言&#xff0c;由 JetBrains 开发。与Java相比&#xff0c;Kotlin的语法更简洁、更具表达性&#xff0c;而且提供了更多的特性。 Kotlin是使用Java开发者的思维被创建的&#xff0c;Intellij作为它主要的开发IDE。对于 Android开发者&#…