函数计算(Function Compute):函数计算 是事件驱动的全托管计算服务。使用函数计算,您无需采购与管理服务器等基础设施,只需编写并上传代码。函数计算为您准备好计算资源,弹性地可靠地运行任务,并提供日志查询、性能监控和报警等功能。借助函数计算,您可以快速构建任何类型的应用和服务,并且只需为任务实际消耗的资源付费。
访问 MongoDB 数据库是指在函数计算中通过编写代码调用数据库驱动库通过 TCP 协议实现对数据库进行的插入、查询等操作。通常函数计算中运行的不同函数实例之间是不共享状态的,对于结构化的数据可以通过数据库的形式进行持久化以实现状态共享。由于用户函数运行在函数计算的 VPC 中,而用户的数据库运行在用户所属的 VPC 中,所以在函数计算平台访问数据库会涉及到跨 VPC 访问的场景,下面我们先来介绍一下其工作机制。
访问 MongoDB 的原理、工作机制与访问 Mysql 数据库完全相同,本文不再重复阐述,更详细的内容请参考 访问 Mysql 数据库 中的工作机制章节。
在安全组控制台 新建安全组,点击 创建安全组,设置安全组名称,网络类型选择 专有网络,并选择刚才创建的专有网络。
创建适合业务需求的云数据库 MongoDB 版实例可以参考 云数据库 MongoDB 版。
注意:创建云数据库 MongoDB 版实例需要选择和函数计算配置相同的 VPC 实例,可以配置和函数计算不同的可用区的交换机,因为相同的 VPC 实例下不同可用区交换机内网是互通的。
创建成功后,在实例信息页面左侧的导航栏中单击白名单设置。
单击 default 区域框右侧的修改。
在弹出的对话框中,将函数计算所在的 VPC 网络的网段地址配置在白名单输入框中。
最后访问 MongoDB 数据库 host 为实例的内网地址,可以登录阿里云控制台查看:
多种语言的客户端连接阿里云 MongoDB 可以参考 MongoDB 客户端连接。
注意:函数计算服务所在区域与公共配置中创建的资源所在区域一致。
###函数编写与调试
下面演示 Python3 开发语言访问 MongoDB 数据库函数示例创建:
使用 Fun 工具在建立存放代码和依赖模块目录下安装依赖和项目部署。
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: './'
RUNTIME python3 RUN fun-install pip install pymongo
fun install
命令安装依赖:$ fun install using template: template.yml start installing function dependencies without docker 安装过程。。。。 Install Success
# -*- coding: utf-8 -*- import uuid from pymongo import MongoClient def 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'
$ 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 数据库。
使用函数计算带来的优势:
阿里云函数服务是一个全新的,支持事件驱动编程模式的计算服务。 他帮助用户聚焦自身业务逻辑,以 Serverless的方式构建应用,快速的实现低成本,可扩展,高可用的系统,而无需考虑服务器等底层基础设施的管理。 用户能够快速的创建原型,同样的架构能随业务规模平滑伸缩。让计算变得更高效,更经济,更弹性,更可靠。无论小型创业公司,还是大型企业,都受益其中。我们的团队正在迅速扩张,求贤若渴。我们想寻找这样的队友:
基本功扎实。既能阅读论文追踪业界趋势,又能快速编码解决实际问题。
严谨的,系统化的思维能力。既能整体考虑业务机会,系统架构,运维成本等诸多因素,又能掌控设计/开发/测试/发布的完整流程,预判并控制风险。
好奇心和使命感驱动。乐于探索未知领域,不仅是梦想家,也是践行者。
坚韧、乐观、自信。能在压力和困难中看到机会,让工作充满乐趣!
如果您对云计算充满热情,想要构建一个有影响力计算平台和生态体系,请加入我们,和我们一起实现梦想!
构建新一代 Serverless 计算平台,包括:
yixian.dw AT alibaba-inc.com
“阿里巴巴云原生技术圈关注微服务、Serverless、容器、Service Mesh 等技术领域、聚焦云原生流行技术趋势、云原生大规模的落地实践,做最懂云原生开发者的技术圈。”