我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

函数计算(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 等技术领域、聚焦云原生流行技术趋势、云原生大规模的落地实践,做最懂云原生开发者的技术圈。”

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

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

下载Word文档

猜你喜欢

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

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

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

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

函数计算怎样访问 MySQL 数据库

本篇文章为大家展示了函数计算怎样访问 MySQL 数据库,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。函数计算(Function Compute):函数计算 是事件驱动的全托管计算服务。使用函数计算
2023-06-04

java项目访问不到数据库的表如何解决

如果 Java 项目无法访问数据库表,可能有以下几个原因和解决方法:1. 数据库连接配置问题:检查数据库连接配置是否正确,包括数据库的 URL、用户名、密码等信息。确保连接数据库的参数正确无误。2. 数据库权限问题:确认项目使用的数据库用户
2023-09-23

redis缓存和数据库一致性问题如何解决

在使用Redis缓存时,常常会遇到与数据库一致性的问题。当数据发生变更时,需要保证Redis缓存与数据库的数据保持一致。以下是几种常见的解决方案:1. 缓存穿透:在查询缓存时,如果缓存中不存在对应的数据,会直接查询数据库。但是当数据库中也不
2023-08-24

代理IP访问阿里云数据库失败,如何解决?解决方案

最近有朋友反馈在使用代理IP访问阿里云数据库时出现了无法连接的情况,导致无法进行正常的数据处理工作。这篇文章将详细解释这个问题的原因,并提供一些可能的解决方法。原因分析:首先,我们分析一下问题可能的原因。代理IP的访问是否被阿里云数据库拒绝?如果阿里云数据库的防火墙设置有问题,可能会阻止代理IP的访问。此外,代理
代理IP访问阿里云数据库失败,如何解决?解决方案
2023-12-11

登录EasyConnect后无法通过jdbc访问服务器数据库如何解决

这篇文章主要介绍“登录EasyConnect后无法通过jdbc访问服务器数据库如何解决”,在日常操作中,相信很多人在登录EasyConnect后无法通过jdbc访问服务器数据库如何解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作
2023-07-05

企业实践 | 如何更好地使用 Apache Flink 解决数据计算问题?

业务数据的指数级扩张,数据处理的速度可不能跟不上业务发展的步伐。基于 Flink 的数据平台构建、运用 Flink 解决业务场景中的具体问题等随着 Flink 被更广泛的应用于广告、金融风控、实时 BI、实时数仓、实时推荐等多种业务场景,在生产实践中已有丰富的
企业实践 | 如何更好地使用 Apache Flink 解决数据计算问题?
2015-10-25

C#开发中如何处理大数据处理和并行计算问题解决方法

C#开发中如何处理大数据处理和并行计算问题解决方法,需要具体代码示例在当前信息时代,数据量的增长呈指数级增长。对于开发人员来说,处理大数据和并行计算已经成为一项重要的任务。在C#开发中,我们可以借助一些技术和工具来解决这些问题。本文将介绍一
2023-10-22

如何通过JDBC访问MySQL数据库?手把手实现登录界面(图解+完整代码)

💁 个人主页:黄小黄的博客主页 ❤️ 支持我:👍 点赞 🌷 收藏 🤘关注 🎏 格言:一步一个脚印才能承接所谓的幸运 本文来自专栏:JDBC从入门到实战 欢
2023-08-25

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录