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

微服务架构设计模式-(15)部署

关联概念

  • 流程
    • 将软件投入到生产环境
  • 架构
    • 软件运行的环境结构

生产环境四个关键功能

  • 服务管理接口
    • 使开发人员能够创建、更新和配置服务
  • 运行时服务管理
    • 确保始终运行一定数量的服务实例
    • 非中断更新
  • 监控
    • 让开发人员了解服务情况,包括日志文件和各种应用指标
    • 可观测性
  • 请求路由
    • 将用户的请求路由到服务

部署模式

  • 编程语言特定的发布包格式
  • 举例
    • js
      • 发布就是发布源代码+模块目录
    • go
      • 某个目录下的可执行文件

部署模式一
直接将发布包部署到机器上的问题

  • 缺乏对技术栈的封装
    • 运维需要了解服务的具体细节,比如说用什么实现的啊,如果是web应用,那么需要安装apache啊
  • 无法约束服务实例消耗的资源
    • 一个进程可能消耗掉整个机器的资源
  • 缺少隔离
    • 多个服务同时运行时,不可靠,服务之间相互影响
  • 很难定位实例的位置

部署模式二
将服务部署为虚拟机

  • 虚拟机镜像打包部署到生产环境,每个服务实例都是一个虚拟机
  • 好处
    • 封装了技术栈
    • 隔离了服务实例
    • 使用了成熟的云计算基础设施
  • 弊端
    • 资源利用效率低
      • 一个服务拥有整个虚拟机的开销,包括操纵系统
    • 部署速度慢
      • 构建虚拟机需要几分钟
    • 系统管理额外开销
      • 操纵系统有时候需要打补丁

部署模式三

  • 将服务部署为容器
  • docker
    • 构建docker镜像
      • dockerfile描述如何构建镜像
      • docker build
    • 把docker镜像推送到镜像仓库
    • 运行docker容器
      • docker run
        • 从容器中拉取镜像
        • 创建并启动
  • 好处
    • 封装技术栈
    • 服务实例隔离
    • 服务实例资源受到限制
    • 轻量级,快速
  • 弊端
    • 需要承担大量的容器镜像管理工作
    • 负责给系统和运行时打补丁

Kubernetes

  • docker编排框架,docker之上的一个软件层
  • 将一组计算机硬件资源转换程运行服务的单一资源池
    • 只需要告诉编排框架运行n个实例,其他由它帮你搞定
  • docker编排框架功能
    • 资源管理
      • 一组计算机,变成一个资源迟,一个计算机
    • 调度
      • 选择要运行容器的机器
        • 意思是把服务功能有关系的部署到同一台机器上
    • 服务管理
      • 服务的名词对应到具体服务
      • 服务版本管理
  • 架构
    • 主节点
      • 负责管理集群
      • 运行多个组件
        • API服务器
          • k8s命令
        • etcd
          • 存储集群数据键值的NoSql数据库
        • 调度器
          • 选择要运行的Pod的节点
        • 控制器管理器
          • 运行控制器,确保集群状态与预期状态匹配
    • 普通节点
      • 运行一个或多个pod
        • pod由一组容器组成
      • 运行多个组件
        • kubelet
          • 创建和管理节点上运行的pod
        • kube-proxy
          • 管理网络,包括跨pod的负载均衡
        • pods
          • 应用程序服务
  • 关键概念
    • Pod
      • 基本部署单元
    • Deployment
      • Pod的声明性规范
      • 每个服务都是k8s的一个deployment,控制pod的数量和版本
    • Service
      • 向客户端提供的一个静态/稳定的网络地址
      • 具有一个IP和DNS名称,并对一个或多个Pod的流量进行负载均衡
        • 这里的IP和DNS只能在K8s内部访问
        • 当然可以配置成外部访问
    • ConfigMap
      • 键值对的配置
        • pod的定义中可以引用

Istio

  • 一个链接、管理和保护微服务的开放平台
  • 是网络层,所有的网络流量都通过Istio进行处理
  • 功能
    • 流量管理
      • 服务发现
      • 负载均衡
      • 路由规则
      • 断路器
    • 通信安全
      • 传输层安全协议(TLS)保护服务间通信
    • 遥测
      • 捕获流量相关的指标,分布式跟踪
    • 策略执行
      • 强制实施配额和费率限制

边车

  • 与服务实例并行运行的进程或容器,负责实现服务运行需要的公共功能

相关文章:

微服务架构设计模式-(15)部署

关联概念 流程 将软件投入到生产环境 架构 软件运行的环境结构 生产环境四个关键功能 服务管理接口 使开发人员能够创建、更新和配置服务 运行时服务管理 确保始终运行一定数量的服务实例非中断更新 监控 让开发人员了解服务情况,包括日志文件和各种应用指标可观…...

Redis:数据结构

简单动态字符串SDS Redis没有直接使用C语言传统的字符串表示(以空字符结尾的字符数组,以下简称C字符串),而是自己构 建了一种名为简单动态字符串(simple dynamic string, SDS)的抽象类型,并将SDS用作Redis的默认字符 串表示。 SDS 的实现…...

2.18 设置language和中文输入法

文章目录一:设置language二:设置中文输入法一:设置language nvidia的开发板上默认只有English,需要点击如下管理: 接着进入如下界面: 此时图中的“汉语(中国)”应该是没有的&…...

图解LeetCode——剑指 Offer 28. 对称的二叉树

一、题目 请实现一个函数,用来判断一棵二叉树是不是对称的。如果一棵二叉树和它的镜像一样,那么它是对称的。 二、示例 2.1> 示例 1: 【输入】root [1,2,2,3,4,4,3] 【输出】true 2.2> 示例 2: 【输入】root [1,2,2,nul…...

Qt Desginer布局方法

首先将我们需要的控件拖拽到一个合适的位置,该例子中用到了两个label,两个lineEdit和两个pushButton。 然后我们需要利用弹簧来控制控件到控件之间的距离以及控件到窗体边界的距离,因为这里只有一组控件(两个label,两个…...

C/C++、Java、Python的比较及学习(3)

函数间的值传递与地址传递 值传递方式:指主调函数把实参的值赋给形参。 在这种传递方式下,主调函数中的实参地址与被调函数中的形参地址是相互独立的。 函数被调用时,系统为形参变量分配内存单元,并将实参的值存入到对应形参的内存…...

智慧校园建设方案

第一章、 智慧教学 6.1. 校本资源库 提供校本资源管理功能,实现学校内的教学资源的共建共享,促进教师之间的交流学习,提升学校的整体教学水平。在本系统中学校可以统一采购资源接入到校本资源库中供教师下载使用,教师也可以将…...

ARM uboot 源码分析5 -启动第二阶段

一、start_armboot 解析6 1、console_init_f (1) console_init_f 是 console(控制台)的第一阶段初始化。_f 表示是第一阶段初始化,_r 表示第二阶段初始化。有时候初始化函数不能一次一起完成,中间必须要夹杂一些代码,…...

【ip neigh】管理IP邻居( 添加ARP\NDP静态记录、删除记录、查看记录)

一、邻居管理存在状态 1、NUD_NONE: 初始状态。当一个新的路由缓存条目被创建时,arp_bind_neighbour()函数被调用.如果找不到相匹配的ARP缓存条目, neigh_alloc()将创建一个新的ARP缓存条目并设置状态为NUD_NONE. 2、NUD_INCOMPLETE:未完成状…...

Java程序员线上排查问题神器-Arthas

文章目录前言一、Arthas是什么?二、快速入门1.下载2.如何运行三、常用命令1.dashboard2.trace总结前言 最近公司项目版本迭代升级,在开发新需求导致没什么时间写博客。 在开发需求的过程中,我写了一个接口,去批量调内部已经写好…...

上市公司企业持续创新能力、创新可持续性(原始数据+计算代码+计算结果)(2008-2021年)

数据来源:自主计算 时间跨度:2008-2021年 区域范围:沪深A股上市公司 指标说明: 参考何郁冰(2017)[1]的做法,将持续创新作为独立研究变量,同时采用创新投入指标(研发经费) 和创新…...

华为OD机试 - 考古学家(JS)

考古学家 题目 有一个考古学家发现一个石碑 但是很可惜 发现时其已经断成多段 原地发现N个断口整齐的石碑碎片 为了破解石碑内容 考古学家希望有程序能帮忙计算复原后的石碑文字组合数 你能帮忙吗 备注: 如果存在石碑碎片内容完全相同,则由于碎片间的顺序不影响复原后的碑…...

Leetcode.2100 适合打劫银行的日子

题目链接 Leetcode.2100 适合打劫银行的日子 Rating : 1702 题目描述 你和一群强盗准备打劫银行。给你一个下标从 0开始的整数数组 security,其中 security[i]是第 i天执勤警卫的数量。日子从 0开始编号。同时给你一个整数 time。 如果第 i天满足以下所…...

linux ubuntu查日志信息以及错误排查

目录 一、linux的日志文件 1、常用日志文件 2、其他日志文件 二、历史日志的查看 1、查看Logrotate的配置信息 2、查看日志配置 一、linux的日志文件 Linux系统中最有趣的(可能也是最重要的)目录之一是/var/log。根据文件系统层次结构标准,在系统中运行的大多数…...

DOS经典软件,落下帷幕,新型国产平台,蓬勃发展

提起DOS时代,总让人难以忘怀,陷入深深回忆中,风靡一时的许多软件,如今早已不在,这几款被称为DOS必装的软件,更是让人惋惜。 你还记得这图吗?堪称DOS系统最经典的软盘复制与映像生成软件&#xf…...

MongoDB数据存储格式

前言 之前分享了MongoDB的基本命名和视图等信息,本文分享一下MongoDB的数据存储类型,使用方式。基础的MongoDB信息就学习完啦,之后会继续分享MongoDB进阶的一些东西。 MongoDB数据存储格式前言1 文件结构1.2 字段名称2 点符号2.2 嵌入式文件…...

ARC126D Pure Straight

ARC126D Pure Straight 题目大意 给一个长度为nnn的整数序列A(a1,a2,…,an)A(a_1,a_2,\dots,a_n)A(a1​,a2​,…,an​),其中ai∈[1,k]a_i\in [1,k]ai​∈[1,k]。 你可以做如下操作任意次: 交换相邻两个元素 求最小的操作次数,使得序列AA…...

基于RK3588的嵌入式linux系统开发(四)——uboot镜像下载(基于RKDevTool工具)

官方提供的SDK中包含RKDevTool工具(RKDevTool_Release_v2.92)和相应的驱动(DriverAssitant_v5.1.1)。本节主要介绍在windows操作系统环境下利用RKDevTool下载以上生成的uboot镜像和bootloader镜像。注意:本节使用的板卡…...

设计模式之策略模式与责任链模式详解和应用

目录1.策略模式1.1 目标1.2.内容定位1.3.定义1.4.应用场景1.5.促销优惠业务场景1.6 用策略模式实现选择支付方式的业务场景1.7 策略模式在框架源码中的体现1.8 策略模式的优缺点2 责任链模式2.1 责任链楼式的应用场景2.2 利用责任链模式进行数据校验拦截2.3 责任链模式和建造者…...

广度优先搜索(BFS)-蓝桥杯

一、BFS搜索的原理BFS搜索的原理:“逐层扩散”,从起点出发,按层次从近到远,逐层先后搜索。编码:用队列实现。应用:BFS一般用于求最短路径问题,BFS的特点是逐层搜索,先搜到的层离起点…...

Java Type类

文章目录Type简介Type分类1. 原始类型(Class)2. 参数化类型(ParameterizedType)3. 类型变量(TypeVariable)4. 通配符类型(WildcardType)5. 泛型数组类型(GenericArrayType)Type简介 Type是Java编程语言中所有类型的公共高级接口。它们包括原始类型、参数化类型、数组类型、类型…...

Springboot扩展点之CommandLineRunner和ApplicationRunner

Springboot扩展点系列:Springboot扩展点之ApplicationContextInitializerSpringboot扩展点之BeanFactoryPostProcessorSpringboot扩展点之BeanDefinitionRegistryPostProcessorSpringboot扩展点之BeanPostProcessorSpringboot扩展点之InstantiationAwareBeanPostPro…...

ngixn 常用配置之文件类型与自定义 log

大家好,我是 17 。 总结了一些 nginx 的常用配置。从入口文件开始,今天讲一下文件类型和自定义log 为了讲述方便,环境为 CentOS 7, nginx 版本 1.21。 配置文件入口 /etc/nginx/nginx.conf这是入口文件,这个文件里…...

【100个 Unity实用技能】 | Unity 通过自定义菜单将资源导出

Unity 小科普 老规矩,先介绍一下 Unity 的科普小知识: Unity是 实时3D互动内容创作和运营平台 。包括游戏开发、美术、建筑、汽车设计、影视在内的所有创作者,借助 Unity 将创意变成现实。Unity 平台提供一整套完善的软件解决方案&#xff…...

0.3调试opencv源码的两种方式

调试opencv源码的两种方式 上两篇我们分别讲了如何配置opencv环境,以及如何编译opencv源码方便我们阅读。但我们还是无法调试我们的代码,无法以我们的程序作为入口来一步一步单点调试看opencv是如何执行的。 【opencv源码解析0.1】VS如何优雅的配置ope…...

Redis的常见操作和Session的持久化

安装Redis使用yum命令,直接将redis安装到linux服务器:yum -y install redis启动redis使用以下命令,以后台运行方式启动redis:redis -server /etc/redis.conf &操作redis使用以下命令启动redis客户端:redis-cli设置…...

TypeScript笔记(二)

背景 上一篇文章我们介绍了TypeScript的一些特性,主要是其与JavaScript的比较,接下来我们将会开始学习Type的语法,这篇文章将会介绍TypeScript的数据类型。 原始数据类型 TypeScript是JavaScript的超集,TypeScript的数据类型就…...

【MyBatis】源码学习 03 - 类型处理器 TypeHandler

文章目录前言参考目录学习笔记1、type 包中类的归类总结2、类型处理器2.1、TypeReference 类3、类型注册表3.1、TypeHandlerRegistry#getTypeHandler前言 本文内容对应的是书本第 8 章的内容,主要是关于类型处理器 TypeHandler 的学习。 这一章节的学习有些地方理…...

建造《流浪地球2》中要毁灭人类的超级量子计算机MOSS的核心量子技术是什么?

1.《流浪地球2》中的量子计算机 2023年中国最火的电影非《流浪地球2》莫属,在《流浪地球2》中有一个人工智能机器人MOSS ,它的前身是“550W”超级量子计算机,“MOSS”是它给自己起的名字(“550W”倒转180度就是“MOSS”&#xff…...

数据结构~七大排序算法(Java实现)

目录 插入排序 直接插入排序 希尔排序 选择排序 直接选择排序 堆排序 交换排序 冒泡排序 快速排序 递归实现 优化版本 归并排序 插入排序 直接插入排序 public class MySort {public static void insertSort(int[] array) {for (int i 1; i < array.length;…...

企业网站项目的流程/seo整站优化方案

本章比较入门&#xff0c;主要是mySQL和编辑器navicat的安装&#xff0c;简单的表插入和字符串的理解。首先SQL相对于Excel的优点在于可以储存更多数据&#xff0c;以及方便多人同时访问。关系数据库主要有3种管理系统&#xff1a;mySQL&#xff0c; ORACLE &#xff0c;SQL Se…...

网络用户提要求找人帮忙做的网站/百度搜索官网

&#x1f4e2;前言&#x1f332;原题样例&#xff1a;旋转字符串&#x1f33b;C#方法&#xff1a;判断子串&#x1f33b;Java 方法&#xff1a;判断子串&#x1f4ac;总结&#x1f4e2;前言 &#x1f680; 算法题 &#x1f680; &#x1f332; 每天打卡一道算法题&#xff0c;…...

电子商务网站设计代做/郑州关键词排名顾问

前沿就是关于摘苹果的数量。。。。。。。。。。。。 解题思路&#xff1a;利用自身身高加上凳子的高度进行 原题&#xff1a;参考洛谷官方 一、实现&#xff1a; #输入参数 high1list(map(int,input().split( ))) high2int(input())#实现摘苹果 nums0 for i in range(len…...

织梦网站建设流程/西安百度网站排名优化

5.1 wireshark简介和抓包原理及过程 5.2 实战&#xff1a;WireShark 抓包及快速定位数据包技巧 5.3 实战&#xff1a;使用 WireShark 对常用协议抓包并分析原理 数据包分析称为数据包嗅探&#xff0c;协议分析&#xff0c;我们捕获和解析网络上传输数据包的一个过程。为了更…...

银川网站推广/seo狂人

我们经常需要写代码&#xff0c;查看代码&#xff0c;查看代码时一般会用记事本&#xff0c;但是记事本的功能太弱&#xff0c;而写代码时有的编译器大的编辑功能太弱&#xff0c;像IAR keil之类的&#xff0c;因此需要一个小巧好用的替代记事本的编辑软件。Notepad我用了很久了…...

网站建设要符合哪些标准/静态网站模板

整个视频打包下载地址&#xff1a;史上最全的数据结构视频教程系列分享之《[北大张铭 教学版]数据结构与算法&#xff08;C&#xff09;》&#xff0c;转载请保留出处和链接&#xff01; 更多优秀资源请访问&#xff1a;我是码农 数据结构与算法是计算机专业一门相当重要的专业…...