架构设计 25 不要

本贴最后更新于 364 天前,其中的信息可能已经渤澥桑田
  • 不要为了省事放弃你的职业精神与底线
  • 不要在你的架构设计中出现单点
  • 不要把简单事情复杂化,90% 的情况下单体应用仍然是大多数项目的首选考虑
  • 不要为了使用微服务去使用微服务,只有在现实业务中组织架构的业务域明确切割后,且单体应用无法承载的情况下,才考虑微服务化
  • 不要触碰分布式事务中间件(如 Seata、TDDL),这会让你的系统难以理解,难以维护;遇到分布式事务,建议业务硬代码,如果出现大量分布式事务,则说明服务设计的不合理
  • 不要认为你的系统是安全的,即使是纯内网应用,你的 RESTfuI API 仍然是脆弱的,建立合理的认证与授权机制
  • 不要出现问题时才想到设计监控系统,监控系统的重要性如何强调都不为过
  • 不要尝试让程序员去时刻关注应用底层细节,程序员就是要写好业务代码,你替程序员考虑越多,你越值钱
  • 不要轻易尝试 DDD,因为认知不同,各层级人员难以达成共识,最后做出来的东西就是四不像
  • 不要忽略数据一致性问题,设计应用程序时先考虑 AP 模型(最终一致性)还是 CP 模型(强一致、线性一致性)
  • 不要高估文档的价值,文档这东西不维护就是废品,尝试通过设计简单化或技术手段实现文档自动化
  • 不要过度解耦,适度耦合是良性的,可以让应用结构更简单,零合只会出现在课本中
  • 不要忽略分布式架构的代价,注册中心、配置中心、服务治理、CI、CD、分布式事务会让中小团队痛不欲生
  • 不要过分专注技术,应用设计前先考虑这个需求是否是必须的,在技术方案之外是否存在其他解决方式
  • 不要把单元测试当成累赘,这是软件质量保证最重要环节
  • 不要忽略应用的健壮性问题,非主干任务做好熔断降级,主线任务做好限流预防
  • 不要认为 Redis 是可靠的,AOF 会丢失一秒数据,RDB 会丢失上一次 bgsave 之后的数据
  • 不是所有场景都需要同步调用,非主线任务且返回值不敏感操作,如消息群发等任务采用异步调用 +WebHook/状态轮询更合适
  • 不要迷信去中心化设计,如果未达到中心化组件的性能瓶颈,中心化设计结构更简单更容易理解,比如:中心化负载均衡器 Nginx 与去中心化 Spring Cloud Loadbalancer
  • 不要刻意加入 Redis 中间件,很多情况增加 MySQLInnodb Buffer Pool 效果一样好,结构也更简单
  • 不要尝试让研发与运维绑定,好的做法是提前建议内部规约,基于“开发与生产对等”策略进行设计
  • 不要认为架构师是程序员的进阶版!架构师从上向下,程序员是自下向上,思考模式完全不同,这是最难的
  • 不要相信前端发来的请求,后端要做好二次校对,合理运用 RedistToken 机制
  • 不要照本宣科,要有质疑精神,要看应用场景。例如:Access Token+Refresh Token 纯粹的无状态方案就一定比 Redis 维护 Access Token 有状态方案好吗?
  • 不要迷信“分库分表”,上古时代的产物在性能爆炸的今天兴许不再适用,基于分片的分布式关系型数据库产品是更好的选择

  • 架构

    我们平时所说的“架构”主要是指软件架构,这是有关软件整体结构与组件的抽象描述,用于指导软件系统各个方面的设计。另外还有“业务架构”、“网络架构”、“硬件架构”等细分领域。

    142 引用 • 442 回帖 • 2 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖 • 2 关注
  • FreeMarker

    FreeMarker 是一款好用且功能强大的 Java 模版引擎。

    23 引用 • 20 回帖 • 468 关注
  • 笔记

    好记性不如烂笔头。

    311 引用 • 794 回帖
  • Mobi.css

    Mobi.css is a lightweight, flexible CSS framework that focus on mobile.

    1 引用 • 6 回帖 • 765 关注
  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 120 关注
  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖 • 1 关注
  • wolai

    我来 wolai:不仅仅是未来的云端笔记!

    2 引用 • 14 回帖 • 1 关注
  • BookxNote

    BookxNote 是一款全新的电子书学习工具,助力您的学习与思考,让您的大脑更高效的记忆。

    笔记整理交给我,一心只读圣贤书。

    1 引用 • 1 回帖 • 5 关注
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 496 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖
  • CloudFoundry

    Cloud Foundry 是 VMware 推出的业界第一个开源 PaaS 云平台,它支持多种框架、语言、运行时环境、云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的问题。

    4 引用 • 16 回帖 • 196 关注
  • Gzip

    gzip (GNU zip)是 GNU 自由软件的文件压缩程序。我们在 Linux 中经常会用到后缀为 .gz 的文件,它们就是 Gzip 格式的。现今已经成为互联网上使用非常普遍的一种数据压缩格式,或者说一种文件格式。

    9 引用 • 12 回帖 • 182 关注
  • 链书

    链书(Chainbook)是 B3log 开源社区提供的区块链纸质书交易平台,通过 B3T 实现共享激励与价值链。可将你的闲置书籍上架到链书,我们共同构建这个全新的交易平台,让闲置书籍继续发挥它的价值。

    链书社

    链书目前已经下线,也许以后还有计划重制上线。

    14 引用 • 257 回帖
  • Hadoop

    Hadoop 是由 Apache 基金会所开发的一个分布式系统基础架构。用户可以在不了解分布式底层细节的情况下,开发分布式程序。充分利用集群的威力进行高速运算和存储。

    93 引用 • 122 回帖 • 616 关注
  • uTools

    uTools 是一个极简、插件化、跨平台的现代桌面软件。通过自由选配丰富的插件,打造你得心应手的工具集合。

    7 引用 • 28 回帖
  • OneDrive
    2 引用 • 6 关注
  • ReactiveX

    ReactiveX 是一个专注于异步编程与控制可观察数据(或者事件)流的 API。它组合了观察者模式,迭代器模式和函数式编程的优秀思想。

    1 引用 • 2 回帖 • 177 关注
  • OpenStack

    OpenStack 是一个云操作系统,通过数据中心可控制大型的计算、存储、网络等资源池。所有的管理通过前端界面管理员就可以完成,同样也可以通过 Web 接口让最终用户部署资源。

    10 引用 • 1 关注
  • SMTP

    SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。

    4 引用 • 18 回帖 • 636 关注
  • WebClipper

    Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。

    3 引用 • 9 回帖 • 1 关注
  • 反馈

    Communication channel for makers and users.

    120 引用 • 906 回帖 • 280 关注
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    694 引用 • 537 回帖 • 1 关注
  • 创业

    你比 99% 的人都优秀么?

    81 引用 • 1395 回帖
  • HTML

    HTML5 是 HTML 下一个的主要修订版本,现在仍处于发展阶段。广义论及 HTML5 时,实际指的是包括 HTML、CSS 和 JavaScript 在内的一套技术组合。

    108 引用 • 295 回帖
  • Caddy

    Caddy 是一款默认自动启用 HTTPS 的 HTTP/2 Web 服务器。

    10 引用 • 54 回帖 • 182 关注
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖 • 3 关注
  • DNSPod

    DNSPod 建立于 2006 年 3 月份,是一款免费智能 DNS 产品。 DNSPod 可以为同时有电信、网通、教育网服务器的网站提供智能的解析,让电信用户访问电信的服务器,网通的用户访问网通的服务器,教育网的用户访问教育网的服务器,达到互联互通的效果。

    6 引用 • 26 回帖 • 534 关注