使用 MongoDB Atlas 无服务器实例更高效地开发应用程序

news/发布时间2024/9/20 8:47:35

使用 MongoDB Atlas无服务器实例更高效地开发应用程序

身为开发者,数据库并不一定需要您来操心。您可不想耗费时间来预配置集群或调整集群大小。同样地,您也不想操心因未能正确扩展而导致经费超标。

MongoDB Atlas 可为您提供多个数据库部署选项。虽然您可以选择预先配置的共享或专用集群,但为了能够以最佳方式满足需求,您仍然不得不持续确定数据库资源的规模并作出相关估算,以及负责随之而来的集群容量管理。尽管预先配置集群并非什么坏事,但若是您的开发处于闲置状态,或者开发的增长期或下滑期频繁出现,预先配置可能就没有意义了。此时,您完全可以转为选择无服务器实例来协助减轻容量管理的负担,腾出时间来专门编写代码。无服务器实例为您的应用程序提供按需数据库端点,该端点将根据应用程序需求自动扩展或缩减到零,并且只根据您的使用情况向您收费。

在这个简短但贴心的教程中,我们会探索如何轻松应用 MongoDB Atlas 无服务器实例,以及如何以其为参照开发应用程序。

部署 MongoDB Atlas无服务器实例

我们首先来看如何部署新的 MongoDB Atlas 无服务器实例。完成 MongoDB 部署的方法有很多,但在本文的示例中,我们将始终使用 Web 仪表盘和一些点击操作。

在 MongoDB Atlas仪表盘中,单击“创建”按钮。
在这里插入图片描述

选择“无服务器”以及应当存储此实例的云供应商。

如果可能,请选择与您的应用程序所在位置相匹配的云供应商。这样可确保您的数据库和应用程序之间的延迟最低。

选择单击“创建实例”按钮后,实例即已准备就绪!

不过,这些操作还不够。要想在 Web 仪表盘之外的位置使用 Atlas 无服务器实例,就需要先创建一些数据库访问规则和网络访问规则。

我们先来添加一个新数据库用户。
在这里插入图片描述

选择对您来说最合理的身份验证类型。为了使本教程简单明了,我建议选择“密码”选项。

涉及到用户权限时,您当然可以使用“内置角色”,但对于任意应用程序,最好还是根据应允许用户执行的操作来定义“特定权限”。在这个项目中,我们将使用一个“示例”数据库和一个“人员”集合,因此只授予该数据库和集合 readWrite 访问权限才是合理做法。

在创建用户及定义访问权限时,请运用自己的最佳判断力。

创建用户后,我们就可以处理网络访问的相关内容。完成最后这一步后,我们就能够以数据库为参照开始开发工作。
在这里插入图片描述

在“网络访问”选项卡中,添加应允许访问的 IP 地址。如果您像我一样在本地开发和测试,只需添加您的本地 IP 地址即可。请务必记得在必要时为您的服务器或云供应商添加 IP 范围。如果需要,您还可以使用专用网络。

数据库和网络访问的设置已经完成,我们现在应获取将在本教程下一步中使用的 URI 字符串。

在“数据库”选项卡中,单击无服务器实例对应的“连接”按钮。
在这里插入图片描述

选择要使用的编程语言并记下 URI。

使用热门编程技术与 Atlas 无服务器实例交互

到这里,您应该已经部署了 Atlas 无服务器实例。我们会花一点时间利用应用程序代码来连接实例,并进行一些交互,例如基本的 CRUD。

对于此特定示例,我们将搭配使用 JavaScript 与 MongoDB Node.js 驱动程序,但相同的规则和概念会继续应用,只是与您希望使用的编程语言存在语言差异。

在本地计算机上,创建项目目录,并使用命令行导航到该目录。在它成为您的工作目录后,您就需要执行以下命令:

在这里插入图片描述

通过上面的命令,我们完成 Node.js 项目初始化,安装了 MongoDB Node.js 驱动程序,并创建了一个包含我们的代码的 main.js 文件。

打开 main.js 文件并添加以下 JavaScript 代码:

在这里插入图片描述

那么,上面的代码发生了什么?

首先,我们会使用无服务器实例的 URI 字符串来定义客户端。这个字符串与您在本教程前面记录的字符串相同,其应该包含用户名和密码。

在客户端中,我们可以建立连接并获得对要使用之数据库和集合的引用。在运行应用程序之前,数据库和集合不需要存在。

接下来,我们将使用 MongoDB 查询 API 执行三种不同的操作。首先,向我们的集合插入一个新文档。插入完成后,在 try/catch 块没有发现错误的情况下,我们会找到姓氏匹配的所有文档。对于此示例,应该只有一个文档,但您完全没法知道您的代码是什么样子。如果找到一个文档,它就会被打印到控制台。最后,我们将删除姓氏匹配的任何文档。

最后,若您跟着我的示例执行所有步骤,那么您的集合中不应该存在任何文档。然而,您的集合中(在某个时间点)确实存在过一个文档,只不过我们将它删除了。

我们通过一个基本示例了解了如何围绕按需数据库构建应用程序,但这个示例并没有真正凸显出如此操作的好处。怎么改变这个情况呢?

使用合理的应用场景推送Atlas 无服务器实例

我们知道,预先配置和无服务器集群能够稳定运作。从开发的角度来看,使用相同的代码最终会得到相同的结果。

让我们来设想一个场景:Atlas 中的无服务器实例可以降低开发成本、减少扩展负担以满足需求。假设您有一个不是常规类型的网上商店。这家网上商店大部分时间的客流量都很少,但由于您主营闪电式交易,每周五上午 9 点到中午 12 点之间的客流量会激增 1000%。

我就不赘述较低的客流量,但 1000% 的流量增长不容小觑,很可能需要每周五对预先配置的集群进行某种扩展干预才行。否则,您就需要付费使用更大型的数据库。

让我们使用下面的 Node.js 代码具象化这个示例:
在这里插入图片描述

在上面的示例中,我们采用了由 Express 框架提供技术支持的 Web 应用程序,其中有两个端点函数。一个端点用于获得交易,另一个端点则用于创建购买。其余内容,请自行想象。

要对流量会突发的这款应用程序执行负载测试并模拟无服务器实例的潜在价值,我们可以使用 Apache JMeter 等类似工具。

使用 JMeter 后,您可以定义它在发出 HTTP 请求时使用的线程数和迭代次数。
在这里插入图片描述

请记住,我们在此示例中模拟的是一种突发情况。如果您确实决定要尝试 JMeter,且面对突发情况时过度操作,您收到的帐单或许会让您哭笑不得。如果您有兴趣了解无服务器的计费方式,请查看文档中的定价页面。
在这里插入图片描述

在 JMeter 线程组中,您需要定义每个线程或迭代所发生的活动。在本例中,我们向 Node.js API 发送 HTTP 请求。

由于 API 需要 JSON,我们可以定义请求的标头信息。
在这里插入图片描述

取得线程信息、HTTP 请求信息和标头信息后,您就可以运行 JMeter,最终会看到同时参照 Web 应用程序和数据库而推进的大量活动。

同样,此示例的很多内容都会留给您自行想象,因为要想看到无服务器实例的扩展优势,您就需要开发过程中难以模拟的大量突发流量。无论如何,这个示例应该能给您带来一些启发。

结论

从上面的示例可以看到,利用 MongoDB Atlas 开发可以多么快速,其还能为您免去亲自调整集群大小的负担。使用 MongoDB Atlas 无服务器实例后,您的数据库能够适当扩展以满足应用程序需求,且您只需为具体需求付费。这样就不必为不间断运行且大小并不合适的集群付费。它还能为您节省时间,不必对集群进行大小调整。

无论您使用的是 Atlas 无服务器实例还是预先配置的共享或专用集群,此示例中的代码都能发挥应有作用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.bcls.cn/yXkU/10111.shtml

如若内容造成侵权/违法违规/事实不符,请联系编程老四网进行投诉反馈email:xxxxxxxx@qq.com,一经查实,立即删除!

相关文章

【刷题】位运算

消失的两个数字 消失的两个数字 “单身狗”进阶版思路 class Solution { public:vector<int> missingTwo(vector<int>& nums) {int ret 0;int n nums.size();for(int i 0; i < n; i){ret ^ (nums[i] ^ i);}ret ^ (n ^ (n 1) ^ (n 2));// 按位异或的…

比Windows 还要早称霸全球的操作系统

走进历史的尘埃&#xff0c;比Windows 还要早称霸全球的操作系统&#xff0c;你还记得吗&#xff1f; 当我们回首家用电脑的辉煌历程&#xff0c;不禁会想起那个曾经统治全球操作系统市场的巨无霸——DOS&#xff08;Disk Operating System&#xff09;。在1995年Windows 95横…

C++多线程学习09:并发队列

参考 链接&#xff1a;恋恋风辰官方博客 并发队列&线程安全栈 代码结构&#xff1a; 并发队列ThreadSafeQueue.h&#xff1a; #pragma once#include <mutex> #include <queue>template<typename T> class threadsafe_queue { private:mutable std::m…

leetcode刷题(javaScript)——栈相关场景题总结

在LeetCode刷题中&#xff0c;栈是一个非常有用的数据结构&#xff0c;可以解决许多问题&#xff0c;包括但不限于以下几类问题&#xff1a; 括号匹配问题&#xff1a;例如检查括号序列是否有效、计算表达式的值等。逆波兰表达式求值&#xff1a;使用栈来实现逆波兰表达式的计算…

5GC SBA架构

协议标准&#xff1a;Directory Listing /ftp/Specs/archive/23_series/23.501/ (3gpp.org) NF描述说明NSSFNetwork Slice Selection Function网络切片选择&#xff0c;根据UE的切片选择辅助信息、签约信息等确定UE允许接入的网络切片实例。NEF Network Exposure Function网络开…

Ainx的全局配置

&#x1f4d5;作者简介&#xff1a; 过去日记&#xff0c;致力于Java、GoLang,Rust等多种编程语言&#xff0c;热爱技术&#xff0c;喜欢游戏的博主。 &#x1f4d7;本文收录于Ainx系列&#xff0c;大家有兴趣的可以看一看 &#x1f4d8;相关专栏Rust初阶教程、go语言基础系列…

mysql,for循环执行sql

遇到一个问题&#xff0c;我需要模拟上百万数据来优化sql&#xff0c;线上数据down不下来&#xff0c;测试库又没有&#xff0c;写代码执行要么慢要么就是sql语句太长。 于是&#xff0c;直接用mysql自带的功能去实现&#xff01; 简单而简单 mysql可以for循环&#xff1f;没…

Docker 第十九章 : 阿里云个人镜像仓使用

Docker 第十九章 : 阿里云个人镜像仓使用 本章知识点: 如何创建镜像库,如何设置密码,如何登录与退出个人镜像仓,如何本地打镜像,如何将本地镜像推送到个人镜像库。 背景 在项目YapiDocker部署中,因读取mongo:latest 版本不一致,导致后续执行步骤的异常。遇到此场景…

Python中网络请求超时的原因及解决方案

在进行网络数据爬取过程中&#xff0c;网络请求超时是一个令人头疼的问题。尤其在Python中&#xff0c;我们常常需要应对各种网络爬虫、API调用或其他网络操作&#xff0c;而网络请求超时的原因千奇百怪。在本篇文章中&#xff0c;我们将深入了解网络请求超时的可能原因&#x…

MATLAB环境下基于局部高斯分布拟合能量的图像分割方法

局部高斯分布拟合能量模型利用局部图像灰度均值和方差信息构造能量泛函&#xff0c;能量泛函由局部图像轮廓内外的高斯分布拟合项和正则项构成&#xff0c;拟合项驱使演化曲线向目标轮廓演化&#xff0c;正则项保持演化曲线的光滑度和避免重新初始化水平集函数。局部高斯分布拟…

拦截器Interceptor(黑马学习笔记)

学习完了过滤器Filter之后&#xff0c;接下来我们继续学习拦截器Interceptor。 拦截器我们主要分为三个方面进行讲解&#xff1a; 1.介绍下什么是拦截器&#xff0c;并通过快速入门程序上手拦截器 2.拦截器的使用细节 3.通过拦截器Interceptor完成登录校验功能 我们先学习第一…

LNMP架构介绍及配置--部署Discuz社区论坛与wordpress博客

一、LNMP架构定义 1、LNMP定义 LNMP&#xff08;Linux Nginx Mysql Php&#xff09;是指一组通常一起使用来运行动态网站或者服务器的自由软件名称首字母缩写&#xff1b;Linux系统下NginxMySQLPHP这种网站服务器架构。 Linux是一类Unix计算机操作系统的统称&#xff0c;是目…

【数据结构】归并排序

算法描述 归并排序&#xff08;MERGE-SORT&#xff09;是建立在归并操作上的一种有效的排序算法,该算法是采用分治法&#xff08;Divide andConquer&#xff09;的一个非常典型的应用。将已有序的子序列合并&#xff0c;得到完全有序的序列&#xff1b;即先使每个子序列有序&a…

【嵌入式——QT】数值输入和显示组件

数值输入和显示组件 QSlider&#xff1a;滑动条&#xff0c;通过滑动来设置数值&#xff1b;QScrollBar&#xff1a;卷滚条&#xff0c;与QSlider类似&#xff0c;还可以用于卷滚区域&#xff1b;QProgressBar&#xff1a;进度条&#xff0c;一般用于显示任务进度&#xff0c;…

YOLOv9-Openvino和ONNXRuntime推理【CPU】

1 环境&#xff1a; CPU&#xff1a;i5-12500 Python&#xff1a;3.8.18 2 安装Openvino和ONNXRuntime 2.1 Openvino简介 Openvino是由Intel开发的专门用于优化和部署人工智能推理的半开源的工具包&#xff0c;主要用于对深度推理做优化。 Openvino内部集成了Opencv、Tens…

【C++从0到王者】第四十六站:图的深度优先与广度优先

文章目录 一、图的遍历二、广度优先遍历1.思想2.算法实现3.六度好友 三、深度优先遍历1.思想2.代码实现 四、其他问题 一、图的遍历 对于图而言&#xff0c;我们的遍历一般是遍历顶点&#xff0c;而不是边&#xff0c;因为边的遍历是比较简单的&#xff0c;就是邻接矩阵或者邻接…

AI:136-基于深度学习的图像生成与风格迁移

🚀点击这里跳转到本专栏,可查阅专栏顶置最新的指南宝典~ 🎉🎊🎉 你的技术旅程将在这里启航! 从基础到实践,深入学习。无论你是初学者还是经验丰富的老手,对于本专栏案例和项目实践都有参考学习意义。 ✨✨✨ 每一个案例都附带关键代码,详细讲解供大家学习,希望…

【iOS ARKit】协作 Session 实例

协作 Session 使用注意事项 协作 Session 是在 ARWorldMap 基础上发展起来的技术&#xff0c;ARWorldMap 包含了一系列的地标、ARAnchor 及在观察这些地标和 ARAnchor 时摄像机的视场&#xff08;View&#xff09;。如果用户在某一个位置新创建了一个 ARAnchor&#xff0c;这时…

qtcreator-ros 安装记录

文章目录 ros_qtc_pluginros_qt_demo参考链接ros_qtc_plugin ROS Qt Creator 插件是专门为 ROS 开发的,通过简化任务和为 ROS 工具创建集中位置来提高开发人员的效率。由于它建立在Qt Creator平台之上,用户可以访问其所有现有功能,例如:语法高亮,代码索引,编辑器(C++,…

团结引擎——DotNet Wasm方案

参考&#xff1a;团结引擎 DotNet WebAssembly(Wasm) 介绍 一、当前编译流程 通过IL2CPP将C#转成C/C&#xff1b;通过Emscripen将C/C转成WebAssembly&#xff1b; 二、 当前存在问题 IL2CPP在处理类似泛型、反射结构时&#xff0c;由于缺少运行时信息&#xff0c;必须全量生…
推荐文章