调研报告之系统架构

标签: 无 分类: 未分类 创建时间:2022-11-05 07:06:41 更新时间:2025-04-28 14:37:41

前言

一直想考软件架构师来着,一直考不上,于是就整理了系统架构的一些东西。

1.淘宝

淘宝架构的演进

2.京东

京东架构的演进

参考文章:
1.京东到家商品系统架构演进
2. davideuler / architecture.of.internet-product 各个大公司的一些架构的PPT演讲或者是资料。

3.概念

  • IaaS
    基础设施即服务 (IaaS) 通过云为组织提供按需基础设施资源,例如计算、存储、网络和虚拟化。客户不必管理、维护或更新自己的数据中心基础设施,但需要对操作系统、中间件、虚拟机以及所有应用或数据负责。

  • CaaS
    容器即服务 (CaaS) 提供和管理所有硬件和软件资源,以使用容器开发和部署应用。CaaS 有时被视为 IaaS 的子集或扩展,它使用容器而不是虚拟机作为其主要资源。开发者和 IT 运营团队可以使用 CaaS 来开发、运行和管理应用,而无需构建和维护基础设施或平台来运行和管理容器。客户仍必须编写代码并管理其数据和应用,但用于构建和部署容器化应用的环境由云服务提供商管理和维护。

  • PaaS
    平台即服务 (PaaS) 提供和管理所有硬件和软件资源,以便通过云开发应用。开发者和 IT 运维团队可以使用 PaaS 来开发、运行和管理应用,而无需自行构建和维护基础设施或平台。客户仍必须编写代码并管理其数据和应用,但用于构建和部署应用的环境由云服务提供商管理和维护。

  • SaaS
    软件即服务 (SaaS) 提供整个应用栈,交付可供客户访问和使用的完整云端应用。SaaS 产品完全由服务提供商管理(包括所有更新、bug 修复和整体维护),可直接使用。大多数 SaaS 应用都可以直接通过网络浏览器访问,这意味着客户不必在其设备上下载或安装任何东西。

参考文章:
【1】.PaaS、IaaS、SaaS 与 CaaS:它们有何不同? 这是谷歌对相关服务的说明,同时提供了相应的产品,而且有对应的优缺点。

4.文章

参考文章:
【1】.深入架构原理与实践 这是一本关于架构设计的开源书籍,这几年互联网基础设施技术出现了很大的更新迭代,比如容器技术(Container、Kubernetes)、服务网格(ServiceMesh)、无服务器(Serverless)、高性能网络(DPDK、XDP、RDMA)等等,我对这些技术有一些浅薄的见解和实践,但远没达到深刻理解的境界,我尝试使用 费曼学习法 把这些东西体系化地总结输出。一方面加深自我的学习认知,另一方面也希望这些输出对其他人有所帮助。

5.Istio

  • 定义
    Istio 是一种开源服务网格,可帮助组织在任何位置运行基于微服务的分布式应用。为何使用 Istio?借助 Istio,组织可以保护、连接和监控微服务,从而更快捷安全地实现企业应用现代化改造。

  • 优点
    (1)实现一致的服务网络
    (2)利用 Istio 的优势保护您的服务
    (3)提升应用性能

  • 用途
    (1)保护云原生应用
    (2)高效管理流量
    (3)监控服务网格
    (4)使用 Kubernetes 和虚拟机轻松部署
    (5)利用高级功能简化负载均衡
    (6)强制执行政策

参考文章:
【1】.Istio 是什么? Istio 是一种服务网格,是一种现代化的服务网络层,它提供了一种透明、独立于语言的方法,以灵活且轻松地实现应用网络功能自动化。它是一种管理构成云原生应用的不同微服务的常用解决方案。Istio 服务网格还支持这些微服务彼此之间的通信和数据共享方式。
小额赞助
本人提供免费与付费咨询服务,感谢您的支持!赞助请发邮件通知,方便公布您的善意!
**光 3.01 元
Sun 3.00 元
bibichuan 3.00 元
微信公众号
广告位
诚心邀请广大金主爸爸洽谈合作
每日一省
isNaN 和 Number.isNaN 函数的区别?

1.函数 isNaN 接收参数后,会尝试将这个参数转换为数值,任何不能被转换为数值的的值都会返回 true,因此非数字值传入也会返回 true ,会影响 NaN 的判断。

2.函数 Number.isNaN 会首先判断传入参数是否为数字,如果是数字再继续判断是否为 NaN ,不会进行数据类型的转换,这种方法对于 NaN 的判断更为准确。

每日二省
为什么0.1+0.2 ! == 0.3,如何让其相等?

一个直接的解决方法就是设置一个误差范围,通常称为“机器精度”。对JavaScript来说,这个值通常为2-52,在ES6中,提供了Number.EPSILON属性,而它的值就是2-52,只要判断0.1+0.2-0.3是否小于Number.EPSILON,如果小于,就可以判断为0.1+0.2 ===0.3。

每日三省
== 操作符的强制类型转换规则?

1.首先会判断两者类型是否**相同,**相同的话就比较两者的大小。

2.类型不相同的话,就会进行类型转换。

3.会先判断是否在对比 null 和 undefined,是的话就会返回 true。

4.判断两者类型是否为 string 和 number,是的话就会将字符串转换为 number。

5.判断其中一方是否为 boolean,是的话就会把 boolean 转为 number 再进行判断。

6.判断其中一方是否为 object 且另一方为 string、number 或者 symbol,是的话就会把 object 转为原始类型再进行判断。

每日英语
Happiness is time precipitation, smile is the lonely sad.
幸福是年华的沉淀,微笑是寂寞的悲伤。