【发布时间】:2020-09-07 11:33:39
【问题描述】:
我正在开发一个微服务来分析上传到 S3 AWS 存储桶的图像。我正在使用无服务器框架。我正在使用 virtualenv 通过 PIP 和 serverless-python-requirements 插件安装依赖项,以将这些依赖项部署到 Lambda 函数。
但是,由于缺少 .so 文件,我在部署微服务时遇到了错误。我得到的错误是
无法导入模块“handlers.image”:libgthread-2.0.so.0:无法打开共享对象文件:没有这样的文件
我的 serverless.yml 文件是
service: sls-covid
provider:
name: aws
runtime: python3.8
profile: testuser
stage: ${opt:stage, 'staging'}
environment: ${file(environment.yml):${self:provider.stage}}
region: ${self:provider.environment.REGION}
iamRoleStatements:
# para poder leer y escribir en el bucket
- Effect: "Allow"
Action:
- "s3:*"
Resource: "*"
custom:
pythonRequirements:
dockerizePip: non-linux
package:
individually: true
exclude:
- node_modules/**
- env/**
- package.json
- package-lock.json
functions:
analyzeImage:
# para analizar la imagen cuando se almacena en S3
handler: handlers.image.analyze
events:
- s3:
bucket: ${self:service}-${self:provider.stage}-images
event: s3:ObjectCreated:*
rules:
- prefix: uploads/
plugins:
- serverless-python-requirements
相关代码为:
import json
import logging
import boto3
from pydicom import dcmread
import numpy as np
# here the code stops working
import cv2
from pydicom.filebase import DicomBytesIO
logger = logging.getLogger()
logger.setLevel(logging.INFO)
s3 = boto3.client('s3')
def analyze(event, context):
print("=== event: ", event)
# code to read uploaded image from bucket and create a ds object
# code below is never executed since the error appears when the cv2 library is loaded
img = cv2.resize(ds.pixel_array, (224, 224))
而我的requirements.txt内容如下:
numpy==1.18.4
opencv-python==4.2.0.34
pandas==1.0.3
pydicom==1.4.2
python-dateutil==2.8.1
pytz==2018.7
six==1.14.0
我的问题是。如何使用插件将 opencv 依赖项正确上传到我的 lambda 函数?我应该以其他方式执行此操作吗?
谢谢!
【问题讨论】:
-
你能概括一下这个过程吗?
标签: python amazon-web-services opencv aws-lambda serverless