1. 首页
  2. IT资讯

快速搭建 Serverless 人脸识别离线服务

简介

首先介绍下在本文出现的几个比较重要的概念:

函数计算(Function Compute):函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。函数计算准备计算资源,并以弹性伸缩的方式运行用户代码,而用户只需根据实际代码运行所消耗的资源进行付费。函数计算更多信息 参考

函数工作流(Function Flow):函数工作流是一个用来协调多个分布式任务执行的全托管云服务。用户可以用顺序,分支,并行等方式来编排分布式任务,FnF 会按照设定好的步骤可靠地协调任务执行,跟踪每个任务的状态转换,并在必要时执行用户定义的重试逻辑,以确保工作流顺利完成。函数工作流更多信息 参考

本文将重点介绍如何快速地通过函数计算与函数工作流部署一个定时离线批量处理图片文件并标注出人脸的服务。

开通服务

  1. 免费开通函数计算,按量付费,函数计算有很大的免费额度。
  2. 免费开通函数工作流,按量付费,目前该产品在公测阶段,可以免费使用。
  3. 免费开通对象存储,按量付费。

解决方案

快速搭建 Serverless 人脸识别离线服务

流程如下:

  1. 设定定时触发器,定时触发函数计算中的函数。
  2. 函数被触发后,调用一次函数工作流中的流程。
  3. 函数工作流中的流程被执行:

    1. 调用函数计算中的函数,列举出 OSS Bucket 根路径下的图片文件列表。
    2. 对于步骤1中列出的文件列表,对每个文件:

      • 调用函数计算中的函数处理,进行人脸识别并标注。将标注后的文件存入 OSS,最后将处理过的文件进行转移。
    3. 判断当前 OSS 根路径下是否有更多的文件

      • 如是,继续步骤1
      • 如否,结束流程

快速开始

  1. Clone 工程到本地

  2. 替换项目目录下 template.yml 文件中的 YOUR_BUCKET_NAME 为在杭州区域的 OSS Bucket (可以不是杭州区域的,需要同步修改 OSS_ENDPOINT)
  ROSTemplateFormatVersion: '2015-09-01'  Transform: 'Aliyun::Serverless-2018-04-03'  Resources:    face-recognition:      Type: 'Aliyun::Serverless::Service'      Properties:        Policies:          - Version: '1'            Statement:              - Effect: Allow                Action:                  - 'oss:ListObjects'                  - 'oss:GetObject'                  - 'oss:PutObject'                  - 'oss:DeleteObject'                  - 'fnf:*'                Resource: '*'      listObjects:        Type: 'Aliyun::Serverless::Function'        Properties:          Handler: index.handler          Runtime: python3          Timeout: 60          MemorySize: 128          CodeUri: functions/listobjects          EnvironmentVariables:            OSS_ENDPOINT: 'https://oss-cn-hangzhou-internal.aliyuncs.com'      detectFaces:        Type: 'Aliyun::Serverless::Function'        Properties:          Handler: index.handler          Runtime: python3          Timeout: 60          MemorySize: 512          CodeUri: functions/detectfaces          EnvironmentVariables:            OSS_ENDPOINT: 'https://oss-cn-hangzhou-internal.aliyuncs.com'      timer:        Type: 'Aliyun::Serverless::Function'        Properties:          Handler: index.handler          Runtime: python3          Timeout: 60          MemorySize: 512          CodeUri: functions/timer        Events:          timeTrigger:            Type: Timer            Properties:              CronExpression: '0 * * * * *'              Enable: true               # replace YOUR_BUCKET_NAME to your oss bucket name              Payload: '{"flowName": "oss-batch-process", "input": "{"bucket": "YOUR_BUCKET_NAME","prefix":""}"}'    oss-batch-process:      Type: 'Aliyun::Serverless::Flow'      Properties:        Description: batch process flow        DefinitionUri: flows/index.flow.yml        Policies:          - AliyunFCInvocationAccess  
  1. 一键部署函数计算和函数工作流资源至云端

    • 安装最新版本的 Fun
    • 在项目根目录下执行 fun deploy

效果验证

  1. 在 OSS Bucket 的根目录下放置图片

快速搭建 Serverless 人脸识别离线服务

  1. 等待一分钟后,定时触发器触发函数执行函数工作流。

快速搭建 Serverless 人脸识别离线服务

  1. 工作流执行完成后,查看 OSS Bucket

快速搭建 Serverless 人脸识别离线服务

总结

通过 函数计算 + 函数工作流,搭建了一个定时批量处理图片进行人脸识别的服务。该服务因为使用了函数工作流的流程,将任务分为了多个步骤,只需要确保每个步骤的函数能够在函数计算限制时间(10分钟)内完成即可。
通过 Fun 工具,一键部署 函数计算 + 函数工作流,免去去多平台进行操作的步骤。

相关参考

  1. 函数计算
  2. 函数工作流
  3. Aliyun Serverless VSCode 插件
  4. Fun

参考示例

  1. serverless-face-recognition
  2. oss-batch-process

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

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/69953029/viewspace-2669997/,如需转载,请注明出处,否则将追究法律责任。

主题测试文章,只做测试使用。发布者:深沉的少年,转转请注明出处:http://www.cxybcw.com/182675.html

联系我们

13687733322

在线咨询:点击这里给我发消息

邮件:1877088071@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

QR code