顶级开源项目 Sentry 20.x JS-SDK 设计艺术(理念与设计原则篇)

简介: 顶级开源项目 Sentry 20.x JS-SDK 设计艺术(理念与设计原则篇)

理念与设计原则



本文档为 Sentry 上的 SDK 开发设置了一些常规指南。它应该帮助内部和外部开发人员了解 SDK 的设计动机以及为什么我们以某些方式做出决定。


依赖成本


依赖是有成本的,而且成本很高。我们使用的每一个依赖都增加了 SDK 的体积,并增加了更多的许可、维护和安全问题。我们知道依赖关系对于支持集成是必要的,但是对于 SDK 的基本功能来说,绝对不需要依赖关系。显然,每个规则都有例外,在某些平台上,如果没有基本的依赖关系,我们将无法工作。一个很好的例子是 Python,我们需要一个 HTTP 请求的外部库来安全地发送 HTTP 请求。


请参阅:Micropackages and Open Source Trust Scaling


优雅降级


我们不希望我们的 SDK 成为造成客户损失的原因。如果我们的 SDK 破坏了客户,那么即使客户在一个过时的平台上运行我们的 SDK,我们也失败了。这意味着,如果我们的 SDK 运行在一个过时的浏览器上,我们必须有足够的弹性,优雅地退回到不做任何事情的状态。


如果不能做到这一点,我们需要确保通过在安装时警告此类情况提前通知用户。例如,如果一个 SDK 甚至需要一个最小版本来构建,我们需要确保通知用户,并且我们以后不会造成令人困惑的错误。


兼容性为王


即使一个平台正在失去相关性,我们仍然想要支持它。我们没有责任告诉用户他们运行在过时的平台上,他们很可能知道这一点。我们不能为客户平台设定基准。如果客户需要支持一个旧的浏览器,我们至少不能破坏那个浏览器,我们还应该重新考虑是否支持它。老平台对于企业客户来说尤其重要,因为企业客户更有可能需要支持这些老平台。


客户价值问题


每个更改都有代价,应该避免为更改而更改。如果更改对客户有利,那就很好,如果更改只是实现了它自己的目的,那就增加了我们破坏现有代码或引起用户失望的机会。没有什么比客户发现自己的报告因为无意义的重构而降级更糟糕的了。


配置是有代价的


我们会优化以提供出色的开箱即用体验。定制(Customization)应该就是:定制(customization)。默认物质(Defaults matter)和这些默认值应该是明智的。如果集成可以执行,则集成应该自动激活,因为未启用每个集成只会导致更糟的客户体验。


优先考虑客户便利性而不是正确性


如果能带来更好的客户体验,做一些稍微不正确的事情是可以的。如果我们的 SDK 能够增加对更多平台的支持,那么发行过时的代码也是可以的。如果能带来更好的客户体验,那么我们的 SDK 做“不应该做的事情(things that should not be done)”是明智的。例如,我们更喜欢 monkeypatch 而不是手动配置,即使这些 monkeypatch 在其实现中可能是脆弱的。


假设新手开发人员


文档、指南和营销材料都应该以不熟悉该语言的开发新手为前提。不要仅仅为了简短的例子而使用可能不熟悉的语言特性。


写下规则


如果做出了违反或澄清本文件的决定,就应该把它们写下来。SDK 是否划定了一个平台的支持范围?应该有一个文档来概括支持什么。当对旧平台的支持被放弃时,就会出现这种情况。


在任何情况下,客户都不应该升级库而发现自己的栈不再被支持,他们只能通过编写客户支持来了解这一点。


启用 Customers


虽然我们通常应该尽量减少 SDKAPI 范围。同时,我们还需要确保使客户能够实现他们的目标。考虑一下 SDK 可能无法立即解决的情况。如果有足够的 API 可供客户以更具创造力的方式使用我们的 SDK,我们通常会认为这是额外的好处。


相关文章
|
2月前
|
JavaScript 前端开发 安全
JavaScript与TypeScript的对比,分析了两者的特性及在实际项目中的应用选择
本文深入探讨了JavaScript与TypeScript的对比,分析了两者的特性及在实际项目中的应用选择。JavaScript以其灵活性和广泛的生态支持著称,而TypeScript通过引入静态类型系统,提高了代码的可靠性和可维护性,特别适合大型项目。文章还讨论了结合使用两种语言的优势,以及如何根据项目需求和技术背景做出最佳选择。
69 4
|
2月前
|
CDN
如何在项目中使用Moment.js库?
如何在项目中使用Moment.js库?
|
3月前
|
JavaScript 测试技术 API
跟随通义灵码一步步升级vue2(js)项目到vue3版本
Vue 3 相较于 Vue 2 在性能、特性和开发体验上都有显著提升。本文介绍了如何利用通义灵码逐步将 Vue 2 项目升级到 Vue 3,包括备份项目、了解新特性、选择升级方式、升级依赖、迁移组件和全局 API、调整测试代码等步骤,并提供了注意事项和常见问题的解决方案。
116 4
|
4月前
|
算法 JavaScript 前端开发
第一个算法项目 | JS实现并查集迷宫算法Demo学习
本文是关于使用JavaScript实现并查集迷宫算法的中国象棋demo的学习记录,包括项目运行方法、知识点梳理、代码赏析以及相关CSS样式表文件的介绍。
第一个算法项目 | JS实现并查集迷宫算法Demo学习
|
3月前
|
JavaScript 前端开发 测试技术
JavaScript与TypeScript:为何TypeScript成为大型项目的首选
JavaScript与TypeScript:为何TypeScript成为大型项目的首选
39 1
|
3月前
|
人工智能 JavaScript 网络安全
ToB项目身份认证AD集成(三完):利用ldap.js实现与windows AD对接实现用户搜索、认证、密码修改等功能 - 以及针对中文转义问题的补丁方法
本文详细介绍了如何使用 `ldapjs` 库在 Node.js 中实现与 Windows AD 的交互,包括用户搜索、身份验证、密码修改和重置等功能。通过创建 `LdapService` 类,提供了与 AD 服务器通信的完整解决方案,同时解决了中文字段在 LDAP 操作中被转义的问题。
|
3月前
|
存储 JavaScript 前端开发
Vue.js项目中全面解析定义全局变量的常用方法与技巧
Vue.js项目中全面解析定义全局变量的常用方法与技巧
70 0
|
8月前
|
监控 Ubuntu Docker
Sentry 监控 Docker 方式部署
Sentry 监控 Docker 方式部署
510 0
|
8月前
|
监控 前端开发 JavaScript
Sentry 监控部署与使用(详细流程)
Sentry 监控部署与使用(详细流程)
984 0
|
存储 监控 前端开发
Sentry 监控部署与使用(详细流程)
Sentry 监控部署与使用(详细流程)
7285 0
下一篇
开通oss服务