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

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

工作机制

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

配置与函数编写

公共配置

创建专有网络VPC

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

创建安全组

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

创建与配置 Redis 实例

  1. 创建适合业务需求的云数据库 Redis 版实例可以参考 云数据库 Redis 版。
  2. 创建成功后,在实例信息页面左侧的导航栏中单击白名单设置
  3. 单击 default 区域框右侧的修改
  1. 在弹出的对话框中,将 函数计算所在的 VPC 网络的网段地址配置在白名单输入框中。

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

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

函数计算配置 VPC

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

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

函数编写与调试

下面演示 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: http://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 http://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 等技术领域、聚焦云原生流行技术趋势、云原生大规模的落地实践,做最懂云原生开发者的技术圈。”

redis的那种目录结构能新建么_Serverless 解惑——函数计算如何访问 Redis 数据库...相关推荐

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

    函数计算(Function Compute):函数计算 是事件驱动的全托管计算服务.使用函数计算,您无需采购与管理服务器等基础设施,只需编写并上传代码.函数计算为您准备好计算资源,弹性地可靠地运行任务 ...

  2. [工具类] 系列二 Lettuce 访问Redis 工具类 RedisUtil

    最近公司Redis集群启用了ssl和密码校验,使用Jedis访问Redis Cluster的时候,支持不太好.看到spring-data-redis 2.x开始使用Lettuce访问Redis,于是开 ...

  3. Redis 系统学习目录

    Redis 系统学习目录 1.redis是什么 2.redis的作者何许人也 3.谁在使用redis 4.学会安装redis 5.学会启动redis 6.使用redis客户端 7.redis数据结构 ...

  4. redis没有bin目录_分布式缓存 Redis 集群搭建,这里一次性帮你搞定!

    作者:Esofar cnblogs.com/esofar/p/10486621.html Redis 集群简介 Redis Cluster 即 Redis 集群,是 Redis 官方在 3.0 版本推 ...

  5. 在/tmp目录下,新建目录director新建三个txt文件,分别为file1.txt,file2.txt,file3.txt,用vi编辑器分别在三个文件中输入内容。

    用vi空格加文件名 按回车之后让你编辑 然后按i 输入内容 esc退出编辑模式 :wq 保存并退出 2.将file1.file2,file3三个文件中内容合并到一个文件中命名为filetest.txt ...

  6. Springboot2.0访问Redis集群

    Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作高性能的key-value数据库.缓存和消息中间件,掌握它是程序员的必备技能,下面是一个springboot访问redis的 ...

  7. 【狂神说Java】Redis最新超详细版教程通俗易懂1 2020-04-01:NoSQL分类,Redis Windows和Linux安装,性能测试,String,List,Set,Hash,Zset

    要讲的知识 nosql讲解 阿里巴巴架构演进 nosql数据模型· Nosql 四大分类. CAP BASE Redis 入门 Redis安装(Window & Linux服务器) 五大基本数 ...

  8. windows下vs2013使用C++访问redis

    刚开始在windows下使用c++访问reids各种报错,经过网上到处搜方案,终于可以在windows下访问redis了, 特将注意事项记录下来: 1.获取redis Window下的开发库源码,从g ...

  9. redis三种架构:主从Cluster哨兵+整合Springboot访问redis

    文章目录 概要:redis集群方案 主从架构 部署主从示例: Redis主从工作原理 Sentinel(哨兵)模式 哨兵的Jedis连接代码: springboot访问哨兵结点 Cluster模式 R ...

最新文章

  1. COLLATE 函数
  2. nginx重新编译安装mysql_Centos 6.5编译安装Nginx+php+Mysql
  3. 旷视《人工智能应用准则》全文公布 提倡善用AI技术
  4. 某县百姓百事110便民服务管理系统(1)——项目总结
  5. 阿里云服务器ssh连接经常断开
  6. html页面锁屏,锁屏页面.html
  7. allergro音乐术语什么意思_「8D音乐」里的 8 是什么意思?
  8. 7.RabbitMQ实战 --- warren和Shovel:故障转移和复制
  9. vue2.0配置 https://github.com/wike933/vuebook
  10. 重装系统后电脑主机前面音频输出没用暨Realtek高清晰音频管理器
  11. POI设置excel格式为文本格式
  12. 居家旅行杀人越货必备 开发主板的另类功能
  13. 怎么把回收站里的计算机放到桌面,如何在桌面上添加回收站
  14. 你连HTTPS 原理都不懂,还给我讲“中间人攻击”
  15. MYSQL 千万数据速度以及极限测试InnoDb--INSERT 拼接极限(一)
  16. Elasticsearch集群的脑裂问题
  17. Excel速度问题探讨.
  18. AIX 下lsnrctl start 错误
  19. homebrew 下载软件包失败,使用手动下载
  20. “AV终结者”预防方法

热门文章

  1. matlab读取指定路径excel文件,MATLAB读取Excel文件
  2. rpm如何卸载mysql_Linux下卸载和安装MySQL[rpm包]
  3. JKS 密钥库使用专用格式。建议使用 “keytool -importkeystore XXX “迁移到行业标准格式?
  4. springboot 建readme_经验分享:给项目创建和编写README.md文件的步骤
  5. python工程技巧_python 19个值得学习的编程技巧
  6. OSG模拟鼠标事件影响操纵器
  7. 华为mate9 android p,安卓手机为什么越用越卡?华为Mate9搭载EMUI 5.0告别卡顿
  8. legend2---开发日志16
  9. php 实现同一个账号同时只能一个人登录
  10. 转载,关于缓存穿透、缓存并发、缓存雪崩那些事