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

使用 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 无服务器实例还是预先配置的共享或专用集群,此示例中的代码都能发挥应有作用。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

每日一题——LeetCode1544.整理字符串

方法一 字符串转数组删除元素 将字符串转为数组&#xff0c;遍历数组&#xff0c;如果碰到同一字母大写小写连续出现就原地删除这两个元素&#xff0c;最后把数组转回字符串并返回 var makeGood function(s) {let arrs.split()for(let i0;i<s.length-1;i){if(arr[i]!arr[…

基于SSM SpringBoot vue物流配送人员管理系统

基于SSM SpringBoot vue物流配送人员管理系统 系统功能 登录注册 个人中心 员工管理 考勤信息管理 小区信息管理 打卡信息管理 出勤统计管理 派单信息管理 工资结算管理 任务统计管理 开发环境和技术 开发语言&#xff1a;Java 使用框架: SSM(Spring SpringMVC Mybaits)或…

Java反射机制底层原理

反射机制 这篇文章我是参考了Java 中的反射机制&#xff08;两万字超全详解&#xff09;_java反射-CSDN博客 然后我在这里做一下总结&#xff0c;因为原文章真的很好&#xff0c;我才疏学浅没什么进行补充&#xff0c;只能做出自己的总结并且写一下自己对这个的理解。 原理&…

有效果的新闻软文推广都是怎么做的?

新闻软文推广能够在短时间内提高产品知名度&#xff0c;塑造品牌的美誉度与公信力&#xff0c;并且效果不是短期的&#xff0c;有一定的持续性&#xff0c;是数字化时代下品牌进行宣传的主要方式之一&#xff0c;受到很多企业的青睐&#xff0c;今天媒介盒子就来和大家聊聊&…

网络编程第二天

1.基于TCP的通信(面向连接的通信) 服务器代码实现&#xff1a; #include <myhead.h> #define IP "192.168.126.91" #define PORT 9999 int main(int argc, const char *argv[]) {//1、创建套接字int sfd-1;if((sfdsocket(AF_INET,SOCK_STREAM,0))-1){perror(…

Python学习DAY09_文件和异常

文件和异常 实际开发中常常会遇到对数据进行持久化操作的场景&#xff0c;而实现数据持久化最直接简单的方式就是将数据保存到文件中。 在 Python 中实现文件的读写操作其实非常简单&#xff0c;通过 Python 内置的 open 函数&#xff0c;我们可以指定文件名、操作模式、编码信…

定时任务调动框架Quartz+SpringBoot集成

Quartz 是一个基于 Java 的广泛使用的开源的任务调度框架 官网&#xff1a; http://www.quartz-scheduler.org/ 源码&#xff1a; https://github.com/quartz-scheduler/quartz 整个 Quartz 的代码流程基本基本如下&#xff1a; 1、首先需要创建我们的任务(Job)&#xff0c…

【重要公告】BSV区块链协会宣布将启动多项动态安全增强措施

​​发表时间&#xff1a;2024年2月16日 2024年2月16日&#xff0c;瑞士楚格 - BSV区块链协议的管理机构BSV区块链协会&#xff08;以下简称“BSV协会”&#xff09;宣布对其运营模式实施全新的安全架构&#xff0c;其中包括引入网络访问规则和数字资产找回协议&#xff0c;以及…

【Go语言】Go语言中的字典

Go语言中的字典 字典就是存储键值对映射关系的集合&#xff0c;在Go语言中&#xff0c;需要在声明时指定键和值的类型&#xff0c;此外Go语言中的字典是个无序集合&#xff0c;底层不会按照元素添加顺序维护元素的存储顺序。 如下所示&#xff0c;Go语言中字典的简单示例&…

Linux系统Docker部署Nexus Maven并实现远程访问本地管理界面

文章目录 1. Docker安装Nexus2. 本地访问Nexus3. Linux安装Cpolar4. 配置Nexus界面公网地址5. 远程访问 Nexus界面6. 固定Nexus公网地址7. 固定地址访问Nexus Nexus是一个仓库管理工具&#xff0c;用于管理和组织软件构建过程中的依赖项和构件。它与Maven密切相关&#xff0c;可…

如果大数据中多头借贷风险严重怎么办呢?

在大数据报告中&#xff0c;多头借贷风险、逾期风险、联系人风险、司法风险等是大数据评分评级的重要组成部分&#xff0c;大数据多头借贷风险也是很多银行和金融平台比较看重的&#xff0c;那如果大数据中多头借贷风险严重怎么办呢?本文详细为大家讲讲。 大数据多头风险是什么…

Niginx介绍和安装使用

Nginx是什么&#xff1f; Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器&#xff0c;同时也提供了IMAP/POP3/SMTP服务。Nginx是由伊戈尔赛索耶夫为俄罗斯访问量第二的Rambler.ru站点&#xff08;俄文&#xff1a;Рамблер&#xff09;开发的&#xff0c;第一…

代码随想录算法训练营第二十一天|530.二叉搜索树的最小绝对差、 501.二叉搜索树中的众数 、236. 二叉树的最近公共祖先

530.二叉搜索树的最小绝对差 题目链接/文章讲解&#xff1a; 代码随想录 视频讲解&#xff1a;二叉搜索树中&#xff0c;需要掌握如何双指针遍历&#xff01;| LeetCode&#xff1a;530.二叉搜索树的最小绝对差_哔哩哔哩_bilibili 1.方法1 1.1分析及思路 了解到差值最小的数…

DevEco Studio下载与安装(Windows)

下载地址&#xff1a; HUAWEI DevEco Studio和SDK下载和升级 | HarmonyOS开发者 安装时直接点击 next 即可。 运⾏已安装的DevEco Studio&#xff0c;⾸次使⽤&#xff0c;请选择Do not import settings&#xff0c;单击OK。 1.安装Node.js 如果本地有下载&#xff0c;可以…

C程序的编译过程

目录 一、GCC编译器 二、编译过程 1、预处理&#xff08;Preprocessing&#xff09; 2、编译&#xff08;Compilation&#xff09; 3、汇编&#xff08;Assembly&#xff09; 4、链接&#xff08;Linking&#xff09; 三、秋招真题演练 一、GCC编译器 在这里&#xf…

linux系统Jenkins工具web配置

Jenkins工具配置 插件配置系统配置系统工具配置 插件配置 下载 Maven Integration Pipeline Maven lntegration gitlab Generic webhook Trigger nodejs Blue ocean系统配置 系统配置结束系统工具配置

androidframework开发面试,阿里P8成长路线

字节跳动Android面经 一面问的 Java 和 Android 基础 1、Jvm虚拟机 2、messageQueue会不会阻塞ui线程 3、对象锁和类锁 4、之字形打印树 5、还有其他的 《Android学习笔记总结最新移动架构视频大厂安卓面试真题项目实战源码讲义》 **完整开源项目&#xff1a;docs.qq.com/doc…

Linux命名管道

Linux匿名管道-CSDN博客 目录 1.原理 2.接口实现 3.模拟日志 Linux匿名管道-CSDN博客 这上面叫的是匿名管道&#xff0c;不要将两者搞混&#xff0c;匿名管道说的是两个有血缘关系的进程相互通信&#xff0c;但是命名管道就是两个没有关系的管道相互通信。 1.原理 和匿名…

解密犯罪时间 - 华为OD统一考试(C卷)

OD统一考试&#xff08;C卷&#xff09; 分值&#xff1a; 100分 题解&#xff1a; Java / Python / C 题目描述 警察在侦破一个案件时&#xff0c;得到了线人给出的可能犯罪时间&#xff0c;形如 HH:MM 表示的时刻。 根据警察和线人的约定&#xff0c;为了隐蔽&#xff0c;该…

RabbitMQ实战学习

RabbitMQ实战学习 文章目录 RabbitMQ实战学习RabbitMQ常用资料1、安装教程2、使用安装包3、常用命令4、验证访问5、代码示例 一、RabbitMQ基本概念1.1. MQ概述1.2 MQ 的优势和劣势1.3 MQ 的优势1. 应用解耦2. 异步提速3. 削峰填谷 1.4 MQ 的劣势1.5 RabbitMQ 基础架构1.6 JMS 二…