微服务学习:基础理论
一、微服务和应用现代化
1、时代的浪潮,企业的机遇和挑战
在互联网化+数字化+智能化+全球化的当今社会,IT行业也面临新的挑战:
- 【快】业务需求如“滔滔江水连绵不绝”,企业需要更快的交付
- 【变】林子大了,百色用户,企业需要提供更个性化、更精细、随时变化的服务体验
- 【巨】万川汇聚,一叶扁舟,企业需要处理浩如烟海般的请求与数据,同事确保平稳与准确
企业想要在竞争中取得优势,必须比对手更快地把产品推出市场;拥抱市场变化,随时快速地相应用户新需求;不断扩大用户规模,持续增加处理吞吐。如果不能在瞬息万变的市场情况下做出快速反应,那只能被远远地甩在身后。
2、新技术的出现,为微服务奠定了发展的基础
- 移动化、云计算、物联化,促进了新型业务模式创新,需要依赖技术和新平台
- 容器技术的出现,为服务多了以后如何自动化部署、如何运维提供了完美的解决方案,解决了微服务“最后一公里”落地的问题,从而完成了微服务生态最后一块拼图。
- Devops理念已逐渐被业界广泛接受,越来越多的企业开始践行Devops实施。Devops为微服务的开发、测试及运维的自动化提供了坚实的基座。
3、新时代IT行业面临的四个变化
- 用户行为的变化:业务应用的用户访问不可预估,突发性访问增多,微博事件和小红书海外流量突然激增就是最好的案例
- 业务模式的变化:所有业务访问都是通过互联网渠道,包括Web、手机APP、微信小程序等
- 业务系统开发的变化:应用再也不像以前半年/一年进行规划,随时会有需求变化,两周一个迭代成为常态。业务应用交付周期短,质量要求高
- 运维模式的变化:要求全天候值守,在线升级和快速响应。不同团队特别是外包团队使用不同的技术栈,无法统一管控
因此,我们评估是否需要采用微服务架构,往往考察这五大关键条件:
- 数据量和业务复杂度
- 团队规模
- 应对业务流量变化
- 是否需要足够的容错容灾
- 功能重复度和差错成本
二、服务理论基础与设计原则
什么是微服务?
一起合作的独立小服务单元
1、微服务理论基础——康威定律
组织形式等同系统设计——设计系统的组织,其产生的设计等同于组织之内、组织之间的沟通结构
- 第⼀定律:Communication dictates design(组织沟通⽅式会通过系统设计表达出来)
- 第⼆定律:There is never enough time to do something right, but there is always enough
time to do it over(时间再多⼀件事情也不可能做的完美,但总有时间做完⼀件事情) - 第三定律:There is a homomorphism from the linear graph of a system to the linear graph
of its design organization(线型系统和线型组织架构间有潜在的异质同态特性) - 第四定律: The structures of large systems tend to disintegrate during development,
qualitatively more so than with small systems(⼤的系统组织总是⽐⼩系统更倾向于分解)

第⼀定律:组织沟通⽅式会通过系统设计表达出来
5个⼈的项⽬组,需要沟通的渠道是 5*(5–1)/2 = 10
15个⼈的项⽬组,需要沟通的渠道是15*(15–1)/2 = 105
50个⼈的项⽬组,需要沟通的渠道是50*(50–1)/2 = 1,225
150个⼈的项⽬组,需要沟通的渠道是150*(150–1)/2 = 11,175
⼈与⼈的沟通是⾮常复杂的,⼀个⼈的沟通精⼒是有限的,所以当问题太复杂需要很多⼈解决的时候,我们需要做拆分组织来达成对沟通效率的管理
在团队内部进⾏频繁的、细粒度的沟通。对于团队外部,定义好接⼝,契约,只进⾏粗粒度的沟通。这样可以降低沟通成本,同时也符合⾼内聚,低耦合原则

第二定律:时间再多⼀件事情也不可能做的完美,但总有时间做完⼀件事情
复杂的系统需要通过容错弹性的⽅式持续优化,不要指望⼀个⼤⽽全的设计或架构,好的架构和设计都是慢慢迭代出来的
复杂系统包括但不限于以下模块:
- 持续集成
- 敏捷开发
- 弹性伸缩
- 监控告警
- 灰度发布
- 熔断隔离
拥抱变化,解决当下,先完成一个一个小目标
第三定律:线型系统和线型组织架构间有潜在的异质同态特性
你想要什么样的系统,就搭建什么样的团队,反之亦然。

第四定律:合久必分,分而治之
⼀个⼤的组织因为沟通成本/管理问题,总为被拆分成⼀个个⼩团队(2 pizza team)

2、微服务的标准
通过康威定律可以得出行为标准:
- ⽤⼀切⼿段提升沟通效率。能2个⼈讲清楚的事情,就不要拉更多⼈,每个⼈每个系统都有明确的分⼯,出了问题知道⻢上找谁,避免踢⽪球。
- 通过MVP(最⼩化可实⾏产品,Minimum Viable Product)的⽅式来设计系统,通过不断的迭代来验证优化,系统应该是弹性设计的。
- 你想要什么样的系统设计,就架构什么样的团队。最好按业务来划分团队,让团队⾃然⾃治内聚,明确的业务边界会减少和外部的沟通成本。
- 做⼩⽽美的团队,⼈多会带来沟通的成本,让效率下降。
从而得出微服务的核心标准:
- 分布式服务组成的系统
- 按照业务而不是技术来划分组织
- 做有生命的产品而不是项目
- 去中心化
- 自动化运维(Devops)
- 容错
- 快速演化
3、微服务设计战略

三、微服务改造
1、微服务架构VS单体架构

2、微服务架构面临的挑战
- 运维要求较高:需要保证几十甚至几百的微服务的正常运行与协作,给运维带来很大的挑战
- 分布式固有的复杂性:系统容错、网络延迟、分布式事务等问题需要解决
- 接口调整成本高:修改一个微服务的API,可能需要所有使用该接口的微服务做出调整
- 可能得重复劳动:多个微服务可能使用相同的功能,但功能本身并没有达到可以分解成微服务的程度,从而导致代码重复
3、如何改造
改造路径:

微服务与微服务平台

单体架构的微服务化

相关文章:
微服务学习:基础理论
一、微服务和应用现代化 1、时代的浪潮,企业的机遇和挑战 在互联网化数字化智能化全球化的当今社会,IT行业也面临新的挑战: 【快】业务需求如“滔滔江水连绵不绝”,企业需要更快的交付【变】林子大了,百色用户&…...
C++实现设计模式---迭代器模式 (Iterator)
迭代器模式 (Iterator) 迭代器模式 是一种行为型设计模式,它提供了一种方法,顺序访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示。 意图 提供一种方法,可以顺序访问一个容器对象中的元素,而无需暴露其…...
海康工业相机的应用部署不是简简单单!?
作者:SkyXZ CSDN:SkyXZ~-CSDN博客 博客园:SkyXZ - 博客园 笔者使用的设备及环境:WSL2-Ubuntu22.04MV-CS016-10UC 不会吧?不会吧?不会还有人拿到海康工业相机还是一脸懵叭?不会还有人…...
Windows电脑安装File Browser与cpolar轻松搭建本地云盘
文章目录 前言1.下载安装File Browser2.启动访问File Browser3.安装cpolar内网穿透3.1 注册账号3.2 下载cpolar客户端3.3 登录cpolar web ui管理界面3.4 创建公网地址 4.固定公网地址访问 前言 无论是个人用户还是企业团队,都希望能够有一个高效、安全的解决方案来…...
mac配置 iTerm2 使用lrzsz与服务器传输文件
mac配置 1. 安装支持rz和sz命令的lrzsz brew install lrzsz2. 下载iterm2-send-zmodem.sh和iterm2-recv-zmodem.sh两个脚本 # 克隆仓库 git clone https://github.com/aikuyun/iterm2-zmodem ~/iterm2-zmodem# 进入到仓库目录 cd ~/iterm2-zmodem# 设置脚本文件可执行权限 c…...
【HBuilderX 中 Git 的使用】
目录: 一:安装必要的版本控制工具二:把Github上的项目克隆到本地三:将本地的项目上传到Github上 一:安装必要的版本控制工具 1️⃣ 安装 TortoiseGit 工具,下载地址:https://tortoisegit.org/do…...
Golang结合MySQL和DuckDB提高查询性能
要在Golang中组合MySQL和DuckDB以提高查询性能,请考虑使用混合查询执行方法。这种方法利用了MySQL强大的事务管理和DuckDB闪电般的分析处理能力。本文介绍如何充分利用两者的方法。 各取所长 用MySQL处理事务,用DuckDB处理分析 MySQL应该处理常规的INS…...
学技术学英语:TCP的三次握手和四次挥手
单词 汉语意思 音标 acknowledge 承认,确认 /əkˈnɒl.ɪdʒ/ acknowledgment 确认,承认 /əkˈnɒl.ɪdʒ.mənt/ duplex 双向的 /ˈdjuː.pleks/ establish 建立 /ɪˈstb.lɪʃ/ handshake 握手,握手协议 /ˈhnd.ʃeɪk…...
xiao esp32 S3播放SD卡wav音频
本文旨在使用xiao esp32 S3 播放SD卡上的音频文件 1 硬件准备 SD卡 2 代码实现 2.1 依赖库 ESP32-audioI2S-master 2.2 代码 #include "Arduino.h" #include "Audio.h" #include "SD.h"// Digital I/O used #define I2S_DOUT 6 #defi…...
Unity中实现伤害跳字效果(简单好抄)
第一步骤安装并导入Dotween插件(也可以不用导入之后直接下载我的安装包) 官网DOTween - 下载 第二步: 制作跳字预制体 建议把最佳适应打开,这样就不怕数字太大显示不全了。 第三步:创建一个空对象并编写脚本JumpNumbe…...
GaussDB日常维护操作
GaussDB日常维护操作 日常维护检查操作系统参数数据库健康状态日志收集日志清理应用连接数表的例行维护索引重建慢SQL诊断 日常维护检查 实例状态检查: #检查集群实例状态 gs_check -U omm -i CheckClusterStatecm_ctl query -Cvipd#检查主备DN的角色和同步状态 g…...
redis实现限流
令牌桶逻辑 计算逻辑: 代码: import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool;/*** ClassName RedisRateLimiterTokenBucket* Description TODO* Author zhang zhengdong* DATE 2025/1/17 20:22* Version 1.0*/ public class…...
基于SpringBoot和PostGIS的各国及所属机场信息检索及可视化实现
目录 前言 一、空间数据简介 1、全球国家信息表 2、机场信息表 3、国家机场检索实现 二、SpringBoot后台实现 1、模型层实现 2、控制层实现 三、WebGIS可视化实现 1、Leaflet界面实现 2、国家及其机场可视化成果 3、全球机场数量排行榜 四、总结 前言 新春佳节即将…...
python http server运行Angular 单页面路由时重定向,解决404问题
问题 当Angular在本地ng server运行时候,可以顺利访问各级路由。 但是运行ng build后,在dist 路径下的打包好的额index.html 必须要在服务器下运行才能加载。 在服务器下我们第一次访问路由页面时是没有问题的,但是尝试刷新页面或手动输入路…...
GPT-4o背后的语音技术
GPT-4o背后的语音技术 GPT-4o是一个any2any的多模态模型,能够接受文本、音频、图像、视频等多模态输入,也能够生成包含文本、语音、图像和视频等混合内容的多模态输出。本文主要谈语音多模态的实现,并分享一些对于语音研究未来发展的看法。 GPT-4o (“o” 代表 “omni”) …...
微透镜阵列精准全检,白光干涉3D自动量测方案提效70%
广泛应用的微透镜阵列 微透镜是一种常见的微光学元件,通过设计微透镜,可对入射光进行扩散、光束整形、光线均分、光学聚焦、集成成像等调制,进而实现许多传统光学元器件难以实现的特殊功能。 微透镜阵列(Microlens Array&#x…...
Spring boot框架下的RocketMQ消息中间件
1. RocketMQ 基础概念 1.1 核心概念 以下是 RocketMQ 核心概念在 Spring Boot 的 Java 后端代码中的实际使用方式: Producer(生产者) 定义:Producer 是负责发送消息到 RocketMQ 的组件。它可以将消息发送到指定的 Topic。 实…...
记录一次 centos 启动失败
文章目录 现场1分析1现场2分析2搜索实际解决过程 现场1 一次断电,导致 之前能正常启动的centos 7.7 起不来了有部分log , 关键信息如下 [1.332724] XFS(sda3): Internal error xfs ... at line xxx of fs/xfs/xfs_trans.c [1.332724] XFS(sda3): Corruption of in-memory data…...
C++学习第五天
创作过程中难免有不足,若您发现本文内容有误,恳请不吝赐教。 提示:以下是本篇文章正文内容,下面案例可供参考 一、构造函数 问题1 关于编译器生成的默认成员函数,很多童鞋会有疑惑:不实现构造函数的情况下…...
openharmony标准系统方案之瑞芯微RK3568移植案例
标准系统方案之瑞芯微RK3568移植案例 本文章是基于瑞芯微RK3568芯片的DAYU200开发板,进行标准系统相关功能的移植,主要包括产品配置添加,内核启动、升级,音频ADM化,Camera,TP,LCD,…...
《数论探微:进阶版》(Arithmetic Tales: Advanced Edition)伪
一、核心问题及解决方案(按踩坑频率排序) 问题 1:误删他人持有锁——最基础也最易犯的漏洞 成因:释放锁时未做身份校验,直接执行 DEL 命令删除键。典型场景:服务 A 持有锁后,业务逻辑耗时超过…...
从“微信群聊”理解HGNN:给算法工程师的超图神经网络直觉构建指南
超图神经网络直觉指南:用微信群聊思维重构高阶关系建模 想象一下,你被拉进了一个学术讨论群,群里既有计算机视觉专家,也有自然语言处理研究员,还有几位跨领域的学者。每次有人发言,信息并非只传递给某一个人…...
JW Player插件开发教程:如何快速扩展播放器功能
JW Player插件开发教程:如何快速扩展播放器功能 【免费下载链接】jwplayer No Longer Maintained 项目地址: https://gitcode.com/gh_mirrors/jw/jwplayer JW Player是一款功能强大的开源媒体播放器,通过插件系统可以轻松扩展其功能。本文将带你快…...
如何用Draw.io ECE库快速绘制专业电路图:免费电子工程绘图终极指南
如何用Draw.io ECE库快速绘制专业电路图:免费电子工程绘图终极指南 【免费下载链接】Draw-io-ECE Custom-made draw.io-shapes - in the form of an importable library - for drawing circuits and conceptual drawings in draw.io. 项目地址: https://gitcode.c…...
显微图像拼接的三大困境与MIST的突破性解决方案
显微图像拼接的三大困境与MIST的突破性解决方案 【免费下载链接】MIST Microscopy Image Stitching Tool 项目地址: https://gitcode.com/gh_mirrors/mist3/MIST 你是否曾经面对数百张高分辨率显微图像,却苦于找不到一个既快速又精准的拼接工具?当…...
终极指南:5步掌握waifu2x-caffe图像超分辨率技术
终极指南:5步掌握waifu2x-caffe图像超分辨率技术 【免费下载链接】waifu2x-caffe waifu2xのCaffe版 项目地址: https://gitcode.com/gh_mirrors/wa/waifu2x-caffe waifu2x-caffe是一款基于深度学习的图像超分辨率工具,专门用于二次元插画和照片的…...
别再只盯着复现了!从CVE-2022-10270看企业内网向日葵客户端的隐形风险与排查指南
企业内网向日葵客户端隐形风险排查实战手册 向日葵远程控制软件在企业内网中的广泛使用,为IT运维带来了便利,同时也埋下了安全隐患。2022年曝光的CVE-2022-10270漏洞让企业安全团队意识到,仅依靠终端用户自主更新远远不够。本文将系统性地介绍…...
从零搭建高安全低代码表单系统,手把手实现JWT动态权限校验+防CSRF提交+审计日志闭环,7天交付标准SaaS组件
第一章:从零构建高安全低代码表单系统概览 高安全低代码表单系统并非传统表单引擎的简单封装,而是融合身份鉴权、字段级加密、动态权限策略与不可篡改审计能力的一体化平台。其核心目标是在显著降低前端开发门槛的同时,满足金融、政务等强监管…...
【NoC片上网络 On-Chip Network】第一章:从总线到NoC,解锁多核芯片的通信瓶颈
1. 多核芯片的通信革命:从总线到NoC的必然选择 十年前我第一次接触多核处理器设计时,团队还在为四核芯片的总线仲裁争得面红耳赤。当时谁也没想到,短短几年后我们会面临上百个核心的通信难题。就像城市交通从乡间小道突然变成超级都市的立体…...
LangChain揭秘:AI“大脑”+“手脚”+“记忆”,OpenClaw如何轻松打造智能助手?
LangChain是一个Python开发框架,用于定义AI流程、集成RAG(知识库)和Skills(工具箱),控制逻辑。RAG提供信息,Skills执行任务。OpenClaw是集成RAG和Skills的完整AI助手框架,具备记忆和…...
