iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >函数计算如何访问 Mongo 数据库
  • 721
分享到

函数计算如何访问 Mongo 数据库

2023-06-04 14:06:58 721人浏览 薄情痞子
摘要

这篇文章给大家介绍函数计算如何访问 MonGo 数据库,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。函数计算(Function Compute):函数计算 是事件驱动的全托管计算服务。使用函数计算,您无需采购与管理服务

这篇文章给大家介绍函数计算如何访问 MonGo 数据库,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

函数计算(Function Compute):函数计算 是事件驱动的全托管计算服务。使用函数计算,您无需采购与管理服务器等基础设施,只需编写并上传代码。函数计算为您准备好计算资源,弹性地可靠地运行任务,并提供日志查询、性能监控和报警等功能。借助函数计算,您可以快速构建任何类型的应用和服务,并且只需为任务实际消耗的资源付费。

访问 MongoDB 数据库是指在函数计算中通过编写代码调用数据库驱动库通过 tcp 协议实现对数据库进行的插入、查询等操作。通常函数计算中运行的不同函数实例之间是不共享状态的,对于结构化的数据可以通过数据库的形式进行持久化以实现状态共享。由于用户函数运行在函数计算的 VPC 中,而用户的数据库运行在用户所属的 VPC 中,所以在函数计算平台访问数据库会涉及到跨 VPC 访问的场景,下面我们先来介绍一下其工作机制。

工作机制

访问 mongoDB 的原理、工作机制与访问 Mysql 数据库完全相同,本文不再重复阐述,更详细的内容请参考 访问 Mysql 数据库 中的工作机制章节。

配置与函数编写

公共配置

创建专有网络VPC
  1. 登录 VPC控制台。

  2. 参阅 VPC  搭建专有网络 创建VPC和交换机。

创建安全

在安全组控制台 新建安全组,点击 创建安全组,设置安全组名称,网络类型选择 专有网络,并选择刚才创建的专有网络。

创建与配置 MongoDB 实例
  1. 创建适合业务需求的云数据库 MongoDB 版实例可以参考 云数据库 MongoDB 版。

    注意:创建云数据库 MongoDB 版实例需要选择和函数计算配置相同的 VPC 实例,可以配置和函数计算不同的可用区的交换机,因为相同的 VPC 实例下不同可用区交换机内网是互通的。

  2. 创建成功后,在实例信息页面左侧的导航栏中单击白名单设置

  3. 单击 default 区域框右侧的修改
    函数计算如何访问 Mongo 数据库

  4. 在弹出的对话框中,将函数计算所在的 VPC 网络的网段地址配置在白名单输入框中。

    1. 登录 VPC 控制台,在专有网络列表中找到应用所在的 VPC,单击该 VPC 的名称进入专有网络详情页面。

    2. 复制应用所在的 VPC 的 IPv4 网段
      函数计算如何访问 Mongo 数据库

    3. 组内白名单设置框中粘贴该 VPC 的 IPv4 网段地址,然后单击确定
      函数计算如何访问 Mongo 数据库

  5. 最后访问 MongoDB 数据库 host 为实例的内网地址,可以登录阿里云控制台查看:

    多种语言的客户端连接阿里云 MongoDB 可以参考 MongoDB 客户端连接。

    函数计算如何访问 Mongo 数据库

函数计算配置 VPC

注意:函数计算服务所在区域与公共配置中创建的资源所在区域一致。

  1. 在 函数计算控制台 创建服务。

    • 创建服务步骤请参考文章 服务的增删改查

  2. 【专有网络配置】选项中,选择您在步骤一中创建的 VPC 网络,交换机、安全组。

  3. 【权限配置】选项中,选择【新建角色】,点击【点击授权】,在角色快速创建页面,点击【同意授权】。

    • 这步的操作是授予函数计算对 ENI 的操作权限,函数计算访问 VPC 中资源需要的权限请参考文章 配置函数计算访问 VPC 内的资源

  4. 点击确定,新建服务完毕。

函数编写与调试

下面演示 python3 开发语言访问 MongoDB 数据库函数示例创建:

使用 Fun 工具在建立存放代码和依赖模块目录下安装依赖和项目部署。

  1. 建立一个目录,用于存放代码和依赖模块,在该目录下新建 template.yml 文件,例如 /tmp/code/template.yml,内容为:

    ROSTemplateFORMatVersion: '2015-09-01'Transform: 'Aliyun::serverless-2018-04-03'Resources: MongoDB-test:   Type: 'Aliyun::Serverless::Service'   Properties:     Description: This is MongoDB service     Role: 'acs:ram::XXXX:role/fc-public-test'     LoGConfig:       Project: XXX       Logstore: XXX     VpcConfig:       VpcId: vpc-XXXX       VSwitchIds:         - vsw-XXX       SecurityGroupId: sg-XXXX     InternetAccess: true   python-test:     Type: 'Aliyun::Serverless::Function'     Properties:       Handler: 'index.handler'       Runtime: Python3       Timeout: 10       MemorySize: 128       CodeUri: './'
  2. 在该目录下创建 Funfile 文件内容为:

    RUNTIME python3RUN fun-install pip install pymongo
  3. 执行fun install命令安装依赖:

     $ fun install using template: template.yml start installing function dependencies without Docker 安装过程。。。。 Install Success
  4. 在函数根目录下新建代码文件,例如 /tmp/code/index.py,在代码中使用 pymongo :

    # -*- coding: utf-8 -*-import uuidfrom pymongo import MongoClientdef handler(event, context):     CONN_ADDR1 = 'dds-XXX.mongodb.rds.aliyuncs.com:3717'     CONN_ADDR2 = 'dds-XXXX.mongodb.rds.aliyuncs.com:3717'     REPLICAT_SET = 'XXX'     username = 'XXX'     passWord = 'XXXX'     #获取mongoclient     client = MongoClient([CONN_ADDR1, CONN_ADDR2], replicaSet=REPLICAT_SET)     #授权. 这里的user基于admin数据库授权     client.admin.authenticate(username, password)     #使用test数据库的collection:testColl做例子, 插入doc, 然后根据DEMO名查找     demo_name = 'python-' + str(uuid.uuid1())     print ('demo_name:'+ demo_name)     doc = dict(DEMO=demo_name, MESG="Hello ApsaraDB For MongoDB")     doc_id = client.test.testColl.insert(doc)     for d in client.test.testColl.find(dict(DEMO=demo_name)):         print ('find documents:'+ str(d))     return 'success'
  5. 使用 fun 工具部署:

     $ fun deploy using template: template.yml using region: cn-hangzhou using accountId: ***********3743 using accessKeyId: ***********Ptgk using timeout: 60 部署过程。。。         function python-test deploy success service MongoDB-test deploy success

    登录控制台,即可看到相关的服务、函数被创建成功,且触发执行可以返回正确的结果。

通过本文介绍可以快速实现函数计算访问 Mongo 数据库。

使用函数计算带来的优势:

  1. 无需采购和管理服务器等基础设施,只需专注业务逻辑的开发,可以大幅缩短项目交付时间和人力成本;

  2. 提供日志查询、性能监控、报警等功能快速排查故障;

  3. 运维,毫秒级别弹性伸缩,快速实现底层扩容以应对峰值压力,性能优异;

  4. 成本极具竞争力;

关于函数计算如何访问 Mongo 数据库就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: 函数计算如何访问 Mongo 数据库

本文链接: https://www.lsjlt.com/news/238205.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • c#文本框只读属性怎么设置
    c# 文本框只读属性的设置 问题:如何设置 C# 文本框的只读属性? 回答: 要设置文本框的只读属性,可以使用 ReadOnly 属性。 详细解释: ReadOnly 属性是一个布尔值属...
    99+
    2024-05-14
    c#
  • 如何使用 Golang ORM 工具与数据库交互?
    使用 gorm orm 工具与数据库交互,可通过以下步骤轻松实现:安装和初始化(1)、定义模型(2)、建立映射(3)、创建记录(4)、读取记录(5)、更新记录(6)、删除记录(7)、事务...
    99+
    2024-05-14
    golang orm mysql git iphone
  • c++中double与float的区别
    c++++ 中 double 与 float 的区别 在 C++ 中,double 和 float 都是浮点数类型,但它们在精度、范围和内存占用方面存在差异。 精度: double:双...
    99+
    2024-05-14
    c++ 内存占用
  • 如何在 Golang 中处理数据库错误?
    在 go 中处理数据库错误的步骤包括:使用专门的 go mysql 驱动程序。实现 error 接口以创建自定义错误。检测错误,记录足够的信息,并基于错误类型执行适当的恢复操作。 如何...
    99+
    2024-05-14
    golang 数据库错误 mysql git 数据丢失
  • c++中int怎么转string
    在 c++ 中将 int 转换为 string 的方法有:使用 to_string() 函数直接转换。使用 stringstream 类。使用 sprintf() 函数。 如何在 C+...
    99+
    2024-05-14
    c++
  • 优化 C++ 服务器架构以提高吞吐量
    优化 c++++ 服务器吞吐量策略:线程池:预先创建线程池,快速响应请求。非阻塞 i/o:在等待 i/o 时执行其他任务,提升吞吐量。http/2:使用二进制协议,支持多路复用和内容压缩...
    99+
    2024-05-14
    优化 服务器架构 c++
  • 使用 C++ 堆分配器管理服务器架构中的内存
    使用 c++++ 堆分配器管理服务器内存可提高性能和稳定性。堆分配器负责分配和释放动态内存,跟踪空闲/已分配内存元数据。在服务器架构中,它用于分配应用程序对象、缓冲区和数据结构。选择堆分...
    99+
    2024-05-14
    c++ 内存管理 并发访问
  • c#怎么获取字符串中的数字
    从 c# 字符串中提取数字的方法有五种:正则表达式、循环和 char.isdigit()、int.tryparse()、string.split() 和 int.parse()、linq...
    99+
    2024-05-14
    git c#
  • C++ 异常处理在服务器架构中的最佳实践
    c++++ 异常处理在服务器架构的最佳实践:定义清晰的异常层次结构,使用自定义异常类型封装相关信息。使用异常安全函数,及时在适当范围内处理异常。提供有意义的错误消息,帮助用户了解错误并采...
    99+
    2024-05-14
    c++ 异常处理
  • c#怎么拼接字符串
    在 c# 中拼接字符串有三种方法:使用加法(+)运算符、string.concat() 方法和 stringbuilder 类。最简单的方法是使用 + 运算符将字符串连接起来,...
    99+
    2024-05-14
    c#
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作