rest - ArangoDB Foxx 作为 REST 后端

标签 rest arangodb foxx

我正在开发一款应用程序,它将极大地受益于 Arangos 的多模型功能。考虑到应用程序对后端的需求,我得出的结论是,大多数(如果不是全部)都可以通过 REST API 提供服务,以帮助更清晰的设计,以便将来的开发和与其他应用程序的集成。然后,多个 Web 和移动前端框架将使用该 API 来处理其余逻辑。该项目将使用 NodeJS 生态系统,使用 Javascript 进行整个堆栈的开发。

.

问题本身:

是否应该并且可以使用 arangodb + Foxx 创建完整的后端堆栈来服务 REST API,从而避免堆栈中的另一层/组件?例如Express/hapi/loopback 等

.

主要后端要求:

  • 使用角色进行身份验证
  • session
  • 加密
  • 复杂查询(我最初想法的根源,以避免数据库和后端之间的多次跳转)
  • 条目解析、验证和清理
  • 计划任务

.

主要寻找:

  • 已知的设计优势
  • 已知的设计限制
  • “隐藏的”瓶颈
  • future 可能出现的其他遗憾

.

附带问题(可能会回答上面的一些问题):Foxx 可以利用一些通过 npm 提供的节点中间件吗?

预先感谢您的宝贵时间!

最佳答案

您可以使用 ArangoDB Foxx 作为应用程序的唯一后端,但是在执行此操作时,请务必牢记 Foxx 的限制(与 Node.js 等通用 JS 环境相比)。

你提到了加密。虽然 ArangoDB 确实支持某些加密技术(例如 HMAC 签名和密码的 PBKDF2 key 派生),但支持并不像 Node.js 那样详尽和可扩展。此外,当使用计算成本高昂的加密技术时,这将影响数据库的性能(因为与 Node.js Foxx 不同,Foxx 是严格同步的,因此所有操作都应被视为阻塞)。

ArangoDB 不支持开箱即用的基于角色的身份验证,但使用 Foxx 在 ArangoDB 中实现它是完全合理的(就像在 Node.js 中实现它一样,只是您不需要离开数据库) .

对于 session ,通常有两种可能的方法:您可以使用包含 session 文档的集合(使用 ArangoDB 作为 session 后端),或者可以通过使用签名 token 使服务保持无状态(Foxx 提供开箱即用的 JWT 支持) )。

复杂/存储查询和输入验证(使用最初为 hapi 编写的 joi 模式库)实际上是 Foxx 的一些主要用例,因此这些应该不会有任何问题。

Foxx 有自己的排队任务机制,也可以提前安排或定期重复。但是,根据您的要求,外部作业或消息队列可能更适合。好处是您可以立即开始使用内置作业队列,并且如果在开发过程中出现需要,仍然可以转向专用解决方案。

对于中间件和 NPM 包:Foxx 与 Node.js 代码不完全兼容。虽然我们提供了大量的兼容性代码并尽可能保持核心模块兼容,但一个很大的区别是 Node.js 通常用于执行异步操作,而在 ArangoDB 中所有操作都是同步的。

如果您的 Node.js 模块不使用加密、文件或网络 I/O,也不使用异步 API(例如 setTimeout、Promise),它们可能与 Foxx 兼容。许多实用程序库(例如 lodash)都可以毫无问题地运行。即使您发现某个模块不起作用,也可以为其编写一个适配器,就像我们对 mocha(集成到 Foxx 中)和 GraphQL(通过 NPM 上的 graphql-sync 包)所做的那样。

根据我的经验,将 Foxx 服务放在一层 Node.js 后面(例如,一个简单的 Express 应用程序,主要代理您的 Foxx API)和/或将后端的某些部分委托(delegate)给 Node.js 是一个很好的方法。独立的 Node.js 微服务(例如与电子邮件或 LDAP 等非 HTTP 服务集成),可以通过 HTTP 集成到 Foxx 中。

还有一件事:虽然由于特定于 Node 的依赖关系和异步逻辑,许多现有的 Express 中间件可能与 Foxx 不兼容,但 ArangoDB 3 将带来新版本的 Foxx,支持使用功能上与 Express 兼容的中间件API。

关于rest - ArangoDB Foxx 作为 REST 后端,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37448943/

相关文章:

来自 AQL 的 Arangodb LET 变量可在 FILTER 中使用

arangodb - Windows 上的 Foxx 和 ArangoDB 入门 - "errorMessage":"unknown path"

arangodb - 我可以在 arangodb 中远程创建 javascript 函数吗

rest - ServiceM8 - 我可以过滤多个字段吗

json - 从 Grails RestfulController 索引/搜索操作渲染分页元数据

arangodb - 时间序列差异 - ArangoDB(AQL 或 Python)

clojurescript - ArangoDB Foxx 和 Clojure 脚本

rest - 如何在不包括祖 parent 的情况下获得产品所属的类别?

Angular 9 和 .NET Web Api - 如何使用 http.post 请求修复 CORS 问题

arangodb - 如何使用ArangoDB和PHP遍历图形