热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

架构思考

2019独角兽企业重金招聘Python工程师标准闲来无事,总结了下架构设计方面的一些思考1、稳定性。一切以稳定为中心。架构尽可能简单、清晰。不过度设计2、解耦拆

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

闲来无事,总结了下架构设计方面的一些思考

    1、稳定性

            。一切以稳定为中心

            。架构尽可能简单、清晰

            。不过度设计

    2、解耦/拆分

            。稳定部分与易变部分分离

            。核心业务与非核心业务分离

            。主流程与辅流程分离

            。应用与数据分离

            。服务与实现细节分离

            。数据拆分:读写分离、分库分表、冷热数据分离

    3、抽象化

            。应用抽象化:应用只依赖服务抽象,不依赖服务实现细节、位置

            。数据库抽象化:应用只依赖逻辑数据库,不需要关心物理库的位置和分片

    4、松耦合

            。跨域调用异步化:不同业务域之间尽量异步解耦

            。非核心业务尽量异步化:核心、非核心业务之间,尽量异步解耦

            。必须同步调用时,需要设置超时时间和任务队列长度

    5、高可用

            。集群容错:应用系统集群,避免单点

            。多机房容灾,异地多活

            。分流:水平可扩展-在线扩容机器

            。降级:非核心业务可根据情况降级处理(业务直接不展示或mock数据或直接利用本地缓存)

            。限流:对流量做过滤,保证部分请求可用

            。自动化运维

    6、灵活

            。支持灰度发布,分步切流量

            。功能开关,可回退

            。A/B test,配备相应数据展示层,及时感知数据变化

    7、监控

            。服务器监控:内存、cpu、i/o、负载

            。应用监控:qps、rt、gc

            。异常监控报警

            。分布式链路追踪监控:zipkin、pinpoint

            。业务监控:核心业务生命周期监控,比如根据订单号获取所有相关生命周期和数据

    8、领域建设

            。厘清业务边界,建设领域模型

            。基础业务/服务下沉,可复用

            。平台/组件化:可搭积木式构建新业务,降低成本

            。数据收敛:只能通过服务来访问其他领域的数据

    9、依赖原则

            。禁止循环依赖

            。稳定部分依赖:稳定部分不依赖易变部分、易变部分可以依赖稳定部分

            。核心服务依赖:核心服务不依赖非核心服务、非核心服务可依赖核心服务,保证核心服务稳定

            。基础服务依赖:基础服务不向上依赖流程服务、流程服务/组合服务可向下依赖基础服务,保证基础服务稳定

            。平台服务依赖:平台服务不依赖上层应用、上层应用可依赖平台服务,保证平台服务稳定

            。非功能性服务依赖:非功能性服务不依赖功能性服务、功能性服务可依赖非功能性服务,保证非功能性服务稳定

            。跨业务域调用时,尽可能异步弱依赖

    10、服务设计

            。无状态,接口调用幂等

            。可复用,复用粒度是有业务逻辑的抽象服务,不是服务细节

            。松耦合、高内聚

            。可治理

            。基础服务之间物理隔离,包括数据层

写了这么多,无非就是围绕稳定性、可扩展性、易用性、灵活性展开的,其中重中之重是稳定性

失去了稳定性,其他一切都是扯淡

另外,架构必须紧贴业务,抛开了业务,所有技术也都是扯淡,产生不了价值


转载于:https://my.oschina.net/u/3729258/blog/1810885


推荐阅读
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 使用Python在SAE上开发新浪微博应用的初步探索
    最近重新审视了新浪云平台(SAE)提供的服务,发现其已支持Python开发。本文将详细介绍如何利用Django框架构建一个简单的新浪微博应用,并分享开发过程中的关键步骤。 ... [详细]
  • 作者:守望者1028链接:https:www.nowcoder.comdiscuss55353来源:牛客网面试高频题:校招过程中参考过牛客诸位大佬的面经,但是具体哪一块是参考谁的我 ... [详细]
  • 本文详细介绍了IBM DB2数据库在大型应用系统中的应用,强调其卓越的可扩展性和多环境支持能力。文章深入分析了DB2在数据利用性、完整性、安全性和恢复性方面的优势,并提供了优化建议以提升其在不同规模应用程序中的表现。 ... [详细]
  • 本文详细分析了JSP(JavaServer Pages)技术的主要优点和缺点,帮助开发者更好地理解其适用场景及潜在挑战。JSP作为一种服务器端技术,广泛应用于Web开发中。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
author-avatar
淡淡木香coolgirl
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有