项目架构一些注意点

这篇具有很好参考价值的文章主要介绍了项目架构一些注意点。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

考虑系统的

稳定性

一、微服务的稳定性

1、如何解决那些不稳定的因素/问题?也是常说的如何容错。

2、一个系统的高可用取决于它本身和其强依赖的组件的高可用

3、消除单点 保活机制 健康检查

注册中心如何保障稳定性

注册中心集群

微服务本身对注册信息的本地持久化
注册机制:关注下线/摘除的原因
网络抖动-->注册中心的保护机制,增量更新-->防止网络风暴

服务消费者如何保障稳定性

#### 超时机制

#### 容错机制    FailTry/FailOver/FailFast
#### 熔断   给予服务提供者一定的恢复时间,等服务提供者恢复正常后再发起调用。这种保护机制大大降低了链式异常引起的服务雪崩的可能性
#### 隔离    隔离资源
#### 降级

服务提供者如何保障稳定性

限流

重启与回滚

服务由于Bug不能提供服务,要求消费者具备容错措施:熔断/降级,在运维上具备快速回滚到前一个版本的能力。

为了复盘问题,要尽力保留现场的上下文/数据,主要来自日志的收集(jvm GC/jstack,业务log )

二、功能稳定

1. 良好的代码设计:可扩展性高,不会因为一个需求导致大面积的重构

2. 测试用例覆盖率:特殊用例

3. 上线
4. 监控

三、性能稳定

限流

降级

熔断

不稳定的问题

### DB层

#### 死锁问题:概率小

#### 慢SQL查询 

1.没有索引/错误地使用索引

2.并发高:访问量大/存在共享热表

3.复杂查询:使用搜索替代

4.数据爆表:数据量增速快 观察统计日/月/年增长量

#### 解决方案

```
并发高如何解决?
时效要求不高的后台定时任务:1. 按时间维度隔离 2.数量分片:任务分发
实时性高的交互:缓存/读写分离

数据爆表如何解决?
分库分表
冷热数据归档

### 系统层面

时延或高或低:随着流量大小变化

负载不均衡

热点数据:访问倾斜

```
接口:梳理核心链路,非核心调用:同步改异步
系统:拆分业务,各业务模块高内聚,从而达成隔离

 文章来源地址https://www.toymoban.com/news/detail-430298.html

 

运维稳定

可扩展性

可以处理更大/更多规模的业务

功能扩展

应用扩展

硬件扩展

 

到了这里,关于项目架构一些注意点的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 企业如何通过熔断降级增强服务稳定性和系统可用性?

    API 的调用稳定性被视为数据服务的最重要的指标。该指标的影响因素是多种多样的,「袋鼠云数据服务平台 DataAPI」不仅多次对于调用性能和稳定性进行压测和调优,而且还提供了多种配置项优化手段供客户进行自行调优。但是当遇到不可预期的大流量或其他突然情况时还是

    2024年02月05日
    浏览(58)
  • 【现代控制系统】李雅普诺夫稳定性 Lyapunov Stability

    2023年10月29日 平衡状态 描述系统状态的随时间的运动可以用以下的式子: x ˙ = f ( x , t ) dot x=f(x,t) x ˙ = f ( x , t ) 式中 x x x 是状态向量, f ( x , t ) f(x,t) f ( x , t ) 是关于状态与时间的函数。当系统状态不再变化的时候,状态变量的导数应为0,即: x ˙ = 0 = f ( x e , t ) dot x=0=

    2024年02月05日
    浏览(90)
  • 腾讯云镜像TencentOS Server操作系统介绍、性能稳定性测评

    腾讯云TencentOS Server镜像是腾讯云推出的Linux操作系统,完全兼容CentOS生态和操作方式,TencentOS Server操作系统为云上运行的应用程序提供稳定、安全和高性能的执行环境,TencentOS可以运行在腾讯云CVM全规格实例上,包括黑石物理服务器2.0。腾讯云服务器网分享TencentOS Server镜像

    2024年02月07日
    浏览(59)
  • 毕业设计-基于 Matlab 的电力系统稳定性分析与仿真

    目录 前言 课题背景和意义 实现技术思路 一、简单电力系统仿真软件简介 二、电力系统稳定性仿真分析 三、结论 实现效果图样例 最后     📅大四是整个大学期间最忙碌的时光,一边要忙着备考或实习为毕业后面临的就业升学做准备,一边要为毕业设计耗费大量精力。近几年

    2024年02月02日
    浏览(171)
  • 提高视觉检测系统稳定性的隐藏办法——10G高速图像采集卡

    提高视觉检测系统稳定性的隐藏办法——10G高速图像采集卡 目前,随着我国各方面配套基础设施建设的完善,企业技术、资金的积累,各行各业积极探索和大胆的尝试机器视觉技术,实现工业自动化、智能化。在机器视觉系统的使用过程中,机器视觉设备的持续稳定性以及传

    2024年02月15日
    浏览(66)
  • 苹果ios系统ipa文件签名的圈外签名是什么?稳定性怎么样?

     在全球范围内,iOS应用市场的规模和影响力不断增长,企业级应用在其中扮演着重要角色。为了在苹果设备上开发和发布内部应用,企业需要获取苹果的iOS企业级开发者证书。文章旨在探讨企业在申请此证书时需要满足的条件、注册流程,以及必要的事项注意事项。 图片来

    2024年02月05日
    浏览(54)
  • 【实用技巧】用Vue.js实现智能家居控制系统的前端交互,提高系统的稳定性

    作者:禅与计算机程序设计艺术 【实用技巧】用Vue.js实现智能家居控制系统的前端交互,提高系统的稳定性 1.1. 背景介绍 随着科技的快速发展,智能家居系统越来越受到人们的青睐。智能家居系统不仅能够提高人们的生活质量,还能节约能源、降低家庭开支。然而,智能家

    2024年02月15日
    浏览(68)
  • 【稳定性】稳定性建设之弹性设计

    随着业务的快速变化和技术的不断发展,系统面临着诸多挑战,例如流量峰值、依赖服务故障、硬件故障、网络中断、软件缺陷等,这些因素都可能影响到系统的正常运行。在这种背景下,弹性设计(Resilience Design)应运而生。弹性设计是一种系统的设计和构建方法, 系统的

    2024年02月08日
    浏览(47)
  • 【ARM Linux 系统稳定性分析入门及渐进12 -- GDB内存查看命令 “x“(examine)】

    请阅读 【ARM Linux 系统稳定性分析专栏导读】 上篇文章:ARM Linux 系统稳定性分析入门及渐进11 – GDB( print 和 p 的使用| @ 和 ::的使用|ptype|{<type>} <addr> ) examine 是GDB中x命令的全称,用于检查内存中的内容。这个命令非常强大,可以以多种格式显示内存内容。 examine 命令

    2024年02月12日
    浏览(37)
  • Redis实现方式开启新篇章,解决分布式环境下的资源竞争问题,提升系统稳定性

    分布式锁一般有三种实现方式: 数据库乐观锁; 基于Redis的分布式锁; 基于ZooKeeper的分布式锁 本篇博客将介绍第二种方式,基于Redis实现分布式锁。 虽然网上已经有各种介绍Redis分布式锁实现的博客,然而他们的实现却有着各种各样的问题,为了避免误人子弟,本篇博客将

    2024年02月07日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包