西安一码通的崩溃这个锅多半要由数据库来背

目前it界最大的新闻莫过于西安一码通的崩溃事件,这不仅是it圈的热点,也成为了全国瞩目的大事件,甚至连工信部总工程师都亲临现场。

许多IT界人士认为,责任不应该完全归咎于数据库,他们提出了以下两个理由:

第一个理由是,这个事件太大,数据库无法承担所有的责任。

第二个理由是从手机APP到数据库,中间有很多环节,不能单单说是数据库的问题。

然而,我认为这两个理由都站不住脚:

第一个理由显然不成立。正如大家所知,“成败在于细节”,业界许多大型系统的崩溃往往源于一个小小的bug。不仅IT项目如此,甚至一场大型战斗的胜败也可能由一个细节决定。

否定第二个理由需要从IT应用的通用架构说起。一个典型的IT应用的通用架构如下图所示:

西安一码通的崩溃这个锅多半要由数据库来背西安一码通的网络配置大致也逃不出这个架构。西安一码通注册量达4000万,日均扫码800万次。这个压力在业界只能算是一般水平。分析一下应用的各个环节,数据库与其他环节有两个显著的不同之处:

通义灵码 通义灵码

阿里云出品的一款基于通义大模型的智能编码辅助工具,提供代码智能生成、研发智能问答能力

通义灵码 31 查看详情 通义灵码

各个环节(除了数据库外)随着负载的增加,处理时间会成正比延长,但数据库不同。一旦数据库的负载达到一个临界点,性能会呈指数级恶化!

其他环节的性能提升可以通过增加资金投入来解决,但数据库的性能需要通过技术手段进行优化才能大幅提升,再好的硬件也无法弥补烂SQL的问题!而且数据库很难进行水平扩展,通常只能在短期内进行纵向扩展,硬件升级的空间也有限。

从报道来看,在第一次全国瞩目的西安一码通崩溃后,该应用已经进行了升级,包括网络。由于这是一个重大事件,资金不会是问题。现在既然用钱无法解决问题,一个合理的推断是数据库的性能出现了问题。

再说一下应用容易产生烂SQL的原因有两个:一个原因是SQL通常由开发人员编写,而不是DBA,他们中的许多人不了解数据库,只是把数据库当成一个黑盒子来使用,仅关注数据存储而不考虑效率。另一个原因是SQL语言只需编写要做什么,而不需要编写如何做。把如何做交给数据库自己决定。这样烂SQL就经常产生,随便添加一个索引就可以让SQL的速度提高几百倍甚至几万倍。但西安一码通出了这么大的事情,谁敢进行变更呢?要知道,业界90%的事故都是由变更引起的。西安一码通虽然运行缓慢,但它还能运转,如果进行变更,可能会导致应用停止服务,这不是更糟糕吗?!

关于我:

姚远,Oracle ACE,华为云MVP,曾任IBM公司数据库部门经理,在数据库和相关领域拥有20多项技术认证。两次获得国家部级科技进步奖,并发明了两项计算机相关专利。

以上就是西安一码通的崩溃这个锅多半要由数据库来背的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/463466.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
Win7局域网如何设置不用密码就能访问共享文件
上一篇 2025年11月8日 04:24:12
下一篇 2025年11月8日 04:24:17

相关推荐

  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • MySQL数据库不支持中文的解决办法

    接上一篇文章,在解决了mysql+flask环境配置问题之后,往数据库存中文字符串会报1366错误,提示不正确的字符。继而发现默认的mysql采用了latin1字符集,这种编码是不支持中文的。 如果想支持中文的话,需要设置一下mysql字符集。 众所周知utf-8是可以的,gbk也没问题,为了可扩展…

    用户投稿 2026年5月10日
    000
  • php实现哪些功能

    PHP是一种通用脚本语言,可用来实现广泛的功能,包括:动态Web开发:生成响应用户请求的动态 веб页面。内容管理系统(CMS):构建允许用户管理网站内容的CMS。电子商务:开发具有购物车、订单处理和支付网关集成的电子商务网站。服务器端编程:编写命令行脚本和工具。文件操作:创建、读取、写入和删除文件…

    2026年5月10日
    000
  • 如何优化JavaScript代码的性能以避免运行时瓶颈?

    优化JavaScript性能需减少DOM操作,通过缓存查询、使用DocumentFragment和合并样式修改来降低重排重绘;2. 采用事件委托减少内存占用并提升绑定效率;3. 拆分长任务,利用requestIdleCallback、Web Worker和requestAnimationFrame避…

    2026年5月10日
    000
  • Go语言中随机数生成器的正确播种方法与性能优化

    本文深入探讨Go语言中随机数生成器的正确播种方法,强调仅需在程序启动时播种一次的重要性。通过分析常见错误(如在循环中重复播种),我们展示了如何避免性能瓶颈并确保生成高质量的随机序列。文章提供了优化的代码示例,涵盖了高效的字符串构建技巧,旨在帮助开发者编写健壮且高效的随机数生成逻辑。 理解伪随机数生成…

    2026年5月10日
    000
  • 如何在Golang中进行性能基准对比

    Golang中通过testing包的Benchmark功能量化性能差异,编写以Benchmark开头的测试函数并使用go test -bench=.运行,通过对比ns/op值评估不同实现的效率,结合b.ResetTimer()控制变量确保公平,并可用pprof分析瓶颈。 在Golang中进行性能基准…

    2026年5月10日
    000
  • SQL查询:精确判断事件过期,结合日期与时间列

    本文旨在解决数据库中事件过期判断不精确的问题,特别是当事件的过期日期和时间分别存储在不同列时。我们将探讨两种主流的sql查询策略:一种是利用逻辑运算符`or`和`and`进行分情况判断,另一种是通过合并日期和时间列为单一时间戳进行直接比较。文章将详细阐述每种方法的实现方式、适用场景及相关注意事项,确…

    2026年5月10日
    100
  • HTML表单如何实现白名单功能?怎样只允许授权用户?

    要实现%ignore_a_1%的白名单功能并确保只有授权用户操作,核心答案是必须依赖后端服务器进行严格的身份认证、会话管理、授权检查和数据验证,前端仅能提供用户体验层面的初步提示而不能保障安全;具体而言,首先通过用户身份认证(如用户名/密码或oauth)确认用户身份,服务器创建会话并返回标识符,后续…

    2026年5月10日
    800
  • Golang反射与标签解析结合使用实例

    Golang反射结合结构体标签的核心优势在于提供运行时动态解析和操作结构体元数据的能力,实现高度灵活、解耦的系统设计。通过reflect.TypeOf(obj).Field(i).Tag.Get(“tag_name”)模式,可在不修改结构体的前提下集中管理JSON序列化、数据…

    2026年5月10日
    300
  • Golang解释器模式如何应用 特定领域语言的实现思路

    golang解释器模式用于定义语言文法并构建解释器执行dsl,核心是通过ast和解释逻辑实现;1. 处理复杂dsl需借助antlr生成解析器、使用visitor模式解耦;2. 性能瓶颈在递归调用,可通过缓存结果、编译字节码、jit或优化ast结构来提升;3. 解释器模式适合灵活的dsl场景,编译器模…

    2026年5月10日
    100
  • 如何用C#实现数据库的跨平台迁移?使用EF Core工具?

    使用EF Core实现跨平台数据库迁移,需定义实体与DbContext,通过动态配置不同数据库提供程序,利用EF Core CLI生成并应用迁移,结合Fluent API处理数据库差异,确保结构与数据兼容。 要实现数据库的跨平台迁移,C# 中最常用且高效的方式是使用 Entity Framework…

    2026年5月10日
    000
  • Python连接MySQL 5.1:克服旧版认证与字符集兼容性挑战

    本教程详细阐述了如何使用Python 3和mysql.connector库成功连接到老旧的MySQL 5.1数据库。文章重点介绍了解决旧版认证协议和字符集兼容性问题的关键配置,特别是use_pure=True和charset=’utf8’的重要性,并提供了可运行的代码示例。同…

    2026年5月10日
    000
  • 如何编写SIMD优化代码 使用编译器内置函数

    使用SIMD intrinsic可显著提升数值计算性能,通过编译器内置函数实现比汇编更便捷;需包含对应头文件如emmintrin.h(SSE)、immintrin.h(AVX)、arm_neon.h(NEON),并使用特定数据类型如__m128、float32x4_t;关键步骤包括数据对齐(如用_m…

    2026年5月10日
    000
  • c++如何使用Intel VTune Profiler分析热点_c++性能瓶颈定位神器【工具】

    c++kquote>Intel VTune Profiler分析C++热点只需三步:编译带-g调试信息的程序(如g++ -O2 -g)、运行Hotspots分析、按CPU Time排序定位前3–5热点函数;需关注CPU Time(inclusive/self)、Module(区分自研/系统库)…

    2026年5月10日
    100
  • Golanggoroutine调度策略与性能优化

    Go调度器采用M:N模型,通过G、M、P协同实现高效并发。G为轻量协程,M为系统线程,P为逻辑处理器,P持有本地G队列,M绑定P执行任务,优先从本地队列取G,减少锁竞争;本地为空时从全局或其他P队列窃取,实现负载均衡。常见问题包括goroutine泄漏、频繁创建销毁、阻塞系统调用和任务分配不均。应对…

    2026年5月10日
    100
  • Golang性能优化的基本原则是什么 解析高效Go代码的核心准则

    go程序中常见的内存优化策略包括预分配切片容量、使用strings.builder或bytes.buffer进行字符串拼接、利用sync.pool复用对象以减少gc压力、避免大对象的值传递而改用指针传递、复用缓冲区以减少临时对象分配,以及警惕切片或字符串切片操作导致的底层数组隐式引用内存泄漏,这些策…

    2026年5月10日
    000
  • Python中高效模拟无重叠球体随机运动:利用cKDTree和Numba提升性能

    本文探讨了在Python中高效模拟大量无重叠球体随机运动的方法。针对原始实现中因逐个球体碰撞检测导致的性能瓶颈,我们引入了多项优化策略。通过利用scipy.spatial.cKDTree的批量查询和多核并行能力,并结合Numba进行关键计算的热点加速,实现了显著的性能提升,有效解决了大规模球体运动模…

    2026年5月10日
    000
  • 想提升IT技能?哪些含金量高的认证值得考?

    it职业发展:高含金量认证助您成功 想在IT领域提升竞争力?选择合适的认证至关重要。本文推荐几项国内外认可度高的IT认证,助您在职业道路上更进一步。 热门认证推荐: 1. 高级软件设计师(软考高级): 国内IT领域含金量最高的认证之一。涵盖软件工程、项目管理及计算机基础知识。证明您在软件设计和开发方…

    2026年5月10日
    000
  • 什么是资产代币化(Asset Tokenization)?它如何将现实世界资产带入区块链?

    资产代币化是通过区块链将房产、股票等实体资产权益转化为可分割的数字代币。首先选择目标资产并由合规机构确权估值,随后在链上发行对应代币并通过智能合约绑定权益比例,实现自动化分红与转让。为确保真实性,引入第三方审计和去中心化预言机同步链下数据,资金流由托管账户与链上地址联动记录,提升透明度。代币化降低投…

    2026年5月10日
    000
  • 优化Python中大量球体无重叠随机运动模拟的策略

    本文旨在探讨并优化在Python中模拟大量(百万级别)球体随机运动同时避免重叠的性能问题。针对初始方案中逐个球体移动和碰撞检测导致的效率低下,我们将介绍三种关键优化策略:利用scipy.spatial.cKDTree的批量邻居查询、启用多核并行处理,以及使用Numba加速计算密集型代码段。通过这些方…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信