返回顶部
首页 > 资讯 > 精选 >Serverless 解惑——函数计算如何访问 Redis 数据库
  • 681
分享到

Serverless 解惑——函数计算如何访问 Redis 数据库

2023-06-04 14:06:21 681人浏览 八月长安
摘要

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

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

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

工作机制

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

配置与函数编写

公共配置

创建专有网络VPC
  1. 登录 VPC控制台。
  2. 参阅 VPC 搭建专有网络 创建VPC和交换机。
创建安全

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

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

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

  3. 单击 default 区域框右侧的修改
    Serverless 解惑——函数计算如何访问 Redis 数据库

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

    1. 登录 VPC 控制台,在专有网络列表中找到应用所在的 VPC,单击该 VPC 的名称进入专有网络详情页面。
    2. 复制应用所在的 VPC 的 IPv4 网段
      Serverless 解惑——函数计算如何访问 Redis 数据库
    3. 组内白名单设置框中粘贴该 VPC 的 IPv4 网段地址,然后单击确定
      Serverless 解惑——函数计算如何访问 Redis 数据库
  5. 最后访问 Redis 数据库 host 为实例的内网地址,可以登录阿里云控制台查看:

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

Serverless 解惑——函数计算如何访问 Redis 数据库

函数计算配置 VPC

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

  1. 在 函数计算控制台 创建服务。
    • 创建服务步骤请参考文章 服务的增删改查
  2. 【专有网络配置】选项中,选择您在步骤一中创建的 VPC 网络,交换机、安全组。
  3. 【权限配置】选项中,选择【新建角色】,点击【点击授权】,在角色快速创建页面,点击【同意授权】。
    • 这步的操作是授予函数计算对 ENI 的操作权限,函数计算访问 VPC 中资源需要的权限请参考文章 配置函数计算访问 VPC 内的资源
  4. 点击确定,新建服务完毕。

函数编写与调试

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

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

  1. 建立一个目录,用于存放代码和依赖模块,在该目录下新建 template.yml 文件,例如 /tmp/code/template.yml,内容为:
    ROSTemplateFORMatVersion: '2015-09-01'Transform: 'Aliyun::serverless-2018-04-03'Resources: Redis-test:   Type: 'Aliyun::Serverless::Service'   Properties:     Description: This is Redis service     Role: 'acs:ram::XXX:role/fc-public-test'     LoGConfig:       Project: XXX       Logstore: XXXX     VpcConfig:       VpcId: vpc-XXXXX       VSwitchIds:         - vsw-XXXX       SecurityGroupId: sg-XXXX     InternetAccess: true   python-test:     Type: 'Aliyun::Serverless::Function'     Properties:       Initializer: 'index.initializer'       Handler: 'index.handler'       Runtime: Python3       Timeout: 10       MemorySize: 128       CodeUri: './'       EnvironmentVariables:         REDIS_HOST: r-XXXXX.redis.rds.aliyuncs.com         REDIS_PASSWord: XXXXX         REDIS_PORT: '6379'
  2. 在该目录下创建 Funfile 文件内容为:
    RUNTIME python3RUN fun-install pip install redis
  3. 执行fun install命令安装依赖:

     $ fun install using template: template.yml start installing function dependencies without Docker building Redis-test/python-test Funfile exist, Fun will use container to build forcely Step 1/2 : FROM reGIStry.cn-beijing.aliyuncs.com/aliyunfc/runtime-python3.6:build-1.7.7  ---> 373f5819463b Step 2/2 : RUN fun-install pip install redis  ---> Running in f26aef48f9e5 Task => PipTask      => PYTHONUSERBASE=/code/.fun/python pip install --user redis Removing intermediate container f26aef48f9e5  ---> 809c6655f9e9 sha256:809c6655f9e93D137840b1446f46572fbab7548c5c36b6ae66599dfc2e27555b Successfully built 809c6655f9e9 Successfully tagged fun-cache-78c74899-5497-4205-a670-24e4daf88284:latest copying function artifact to /Users/txd123/Desktop/Redis/Python Install Success
  4. 在函数根目录下新建代码文件,例如 /tmp/code/index.py,在代码中使用 redis :

     # -*- coding: utf-8 -*- import os,sys import redis def initializer(context):     global conn_pool     conn_pool=redis.ConnectionPool(host=os.environ['REDIS_HOST'],password=os.environ['REDIS_PASSWORD'],port=os.environ['REDIS_PORT'],db=1,decode_responses=True) def handler(event, context):     r = redis.Redis(connection_pool=conn_pool)     r.set('test','89898')     r.set('zyh_info','{"name":"Tanya","password":"123456","account":11234}')     print(r.get('test'))     return r.get('zyh_info')
  5. 使用 fun 工具部署:

     $ fun deploy using template: template.yml using region: cn-hangzhou using accountId: ***********3743 using accessKeyId: ***********Ptgk using timeout: 60 Waiting for service Redis-test to be deployed...         Waiting for function python-test to be deployed...                 Waiting for packaging function python-test code...                 The function python-test has been packaged. A total of 25 files files were compressed and the final size was 138.78 KB         function python-test deploy success service Redis-test deploy success

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

总结

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

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

  1. 无需采购和管理服务器等基础设施,只需专注业务逻辑的开发,可以大幅缩短项目交付时间和人力成本;
  2. 提供日志查询、性能监控、报警等功能快速排查故障;
  3. 运维,毫秒级别弹性伸缩,快速实现底层扩容以应对峰值压力,性能优异;
  4. 成本极具竞争力;

“阿里巴巴云原生技术圈关注微服务、Serverless、容器、Service Mesh 等技术领域、聚焦云原生流行技术趋势、云原生大规模的落地实践,做最懂云原生开发者的技术圈。”

--结束END--

本文标题: Serverless 解惑——函数计算如何访问 Redis 数据库

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

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

猜你喜欢
  • Serverless 解惑——函数计算如何访问 Redis 数据库
    函数计算(Function Compute):函数计算 是事件驱动的全托管计算服务。使用函数计算,您无需采购与管理服务器等基础设施,只需编写并上传代码。函数计算为您准备好计算资源,弹性地可靠地运行任务,并提供日志查询、性能监控和报警等功能。...
    99+
    2023-06-04
  • 函数计算如何访问 Mongo 数据库
    这篇文章给大家介绍函数计算如何访问 Mongo 数据库,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。函数计算(Function Compute):函数计算 是事件驱动的全托管计算服务。使用函数计算,您无需采购与管理服务...
    99+
    2023-06-04
  • 函数计算怎样访问 MySQL 数据库
    本篇文章为大家展示了函数计算怎样访问 MySQL 数据库,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。函数计算(Function Compute):函数计算 是事件驱动的全托管计算服务。使用函数计算...
    99+
    2023-06-04
  • 如何设置并访问redis数据库
    Redis 是一个高性能的key-value数据库。 redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。它提供了Java,C...
    99+
    2024-04-02
  • C++ 函数库如何进行数学计算?
    c++++ 标准库中的 头文件提供丰富的数学函数,包括三角函数、双曲函数、指数和对数函数等。这些函数便于执行常见的数学运算,如计算圆的面积、勾股定理、求解二次方程以及查找极值。 C+...
    99+
    2024-04-18
    c++ 数学运算 标准库
  • 外网如何访问数据库
    小编给大家分享一下外网如何访问数据库,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! 外网访问数据库的...
    99+
    2024-04-02
  • 如何远程访问mysql数据库
    如何远程访问mysql数据库,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。方法一:将localhost改成"%"修改&...
    99+
    2024-04-02
  • VB.NET如何访问数据库原理
    这篇文章主要介绍VB.NET如何访问数据库原理,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!VB.NET访问数据库接口功能及含义: ADC:高级数据连接器(AdvancedDataConnector):提供绑定ADO...
    99+
    2023-06-17
  • Node.js开发之访问Redis数据库教程
    大家要记住,Node.js主要用于构建高性能、高可伸缩性的服务器和客户端应用,它面向的是“实时Web”。 Node.js的目标是提供一个“以简单的方式构建可扩展的网络服务器”,它受到来自Ruby语言的事件机...
    99+
    2022-06-04
    数据库 教程 Node
  • Node.js Serverless 与函数即服务:解锁云端计算的奥秘
    Node.js Serverless 的优点 无服务器架构:无需管理服务器或基础设施,开发人员可以专注于构建应用程序逻辑。 按使用付费:仅为实际使用的计算资源付费,从而降低运营成本。 高可扩展性:无服务器架构可以自动扩展,以满足应用程序...
    99+
    2024-03-10
    引言 Serverless 计算是一种云原生架构 它允许开发人员构建和部署应用程序 而无需管理服务器或基础设施。Node.js Serverless 是利用 Node.js 运行时构建和部署无服务器
  • 如何进行MySql数据库C++访问
    如何进行MySql数据库C++访问,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。 MySql数据库C++访问...
    99+
    2024-04-02
  • Aurora数据库的成本如何计算
    Aurora数据库的成本通常是根据数据库实例的类型、规格和使用时长来计算的。下面是一些影响Aurora数据库成本的因素: 实例类型...
    99+
    2024-04-02
  • python如何计算幂函数
    在python中使用pow函数计算幂函数,具体方法如下:pow:pow()函数的作用是用于计算 x 的 n 次幂函数,其中n为整数。pow()函数使用方法:class Solution:def myPow(self, x: float, n...
    99+
    2024-04-02
  • 玩转Redis-如何高效访问Redis中的海量数据
    1、前言   Redis以高性能著称,但性能再好,在面对海量数据时,若不正确的使用,也终将会有性能瓶颈,甚至造成服务宕机。 在实际项目中你是否会有以下疑问? 如何访问Redis中的海量数据,却不影响其他请求访问Redis? Redis中有...
    99+
    2018-01-16
    玩转Redis-如何高效访问Redis中的海量数据
  • WinForm中如何访问数据库并进行数据操作
    在WinForm中访问数据库并进行数据操作一般需要遵循以下步骤: 引入相关的命名空间:首先需要在代码文件中引入与数据库操作相关的命...
    99+
    2024-04-08
    winform
  • Java访问数据库实例详解
    JAVA程序想要访问数据库,需要进行如下准备: 1.安装一个数据库(这里使用mysql免安装版)2.下载该数据库的驱动包(这里使用mysql官方提供的mysql-connector-...
    99+
    2024-04-02
  • c#.net 是如何访问 SQL Server 数据库
    c#.net 是如何访问 SQL Server 数据库1、导入命名空间 using System.Data.SqlClient; //连接SQLServer 数据库专用 2、创建连接&n...
    99+
    2024-04-02
  • 如何通过ADO控件访问数据库
    今天就跟大家聊聊有关如何通过ADO控件访问数据库,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。下面以Microsoft Office&nb...
    99+
    2024-04-02
  • mysql+c语言+API如何访问数据库
    小编给大家分享一下mysql+c语言+API如何访问数据库,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!  #incl...
    99+
    2024-04-02
  • php如何访问mysql数据库服务器
    利用PHP访问到mysql数据库的方法访问过程如下://连接数据库方式1$conn = new mysqli('localhost', 'root', 'password', 'test');//连接数据库方式2// $conn = new...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作