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

Stella981
• 阅读 479

函数计算(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. 【权限配置】选项中,选择【新建角色】,点击【点击授权】,在角色快速创建页面,点击【同意授权】。
  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 python3 RUN 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 等技术领域、聚焦云原生流行技术趋势、云原生大规模的落地实践,做最懂云原生开发者的技术圈。”

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Stella981 Stella981
2年前
Opencv中Mat矩阵相乘——点乘、dot、mul运算详解
Opencv中Mat矩阵相乘——点乘、dot、mul运算详解2016年09月02日00:00:36 \牧野(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fme.csdn.net%2Fdcrmg) 阅读数:59593
Stella981 Stella981
2年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Easter79 Easter79
2年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
2年前
Serverless 解惑——函数计算如何访问 Mongo 数据库
函数计算(FunctionCompute):函数计算(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fstatistics.functioncompute.com%2F%3Ftitle%3DServerless%2520%25E8%25A7%25A3%25E6%2583%259
Stella981 Stella981
2年前
Serverless 解惑——函数计算如何访问 SQL Server 数据库
函数计算(FunctionCompute):函数计算(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fstatistics.functioncompute.com%2F%3Ftitle%3DServerless%2520%25E8%25A7%25A3%25E6%2583%259
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这