使用AWS SAM CLI安装PyODBC进行本地调试时出现问题

时间:2019-05-17 16:36:30

标签: python aws-lambda pyodbc aws-sam-cli

我正在用Python开发lambda函数。该函数使用pyodbc库访问RDS数据库。为了使用库,我正在使用图层。我的SAM模板看起来像这样,并且在部署到AWS时一切正常。

Resources:

    # ODBC Lambda Layer
    PyODBCLayer:
      Type: AWS::Serverless::LayerVersion
      Properties:
        ContentUri: pyodbc_layer.zip

    # Lambda function
    TaskIDFunction:
        Type: AWS::Serverless::Function
        Properties:
            CodeUri: taskid/
            Handler: app.lambda_handler
            Layers:
              - !Ref PyODBCLayer
            Role: !GetAtt TaskIDFunctionIamRole.Arn
            Runtime: python3.6
            Environment:
              Variables:
                ODBCINI: /opt/bin/odbcinst.ini
                ODBCSYSINI: /opt/bin
            Events:
              SendTaskID:
                Type: Api 
                Properties:
                      Path: /task/{id}
                      Method: get

当我尝试使用sam build && sam local invoke -d 5890 TaskIDFunction --event myEvent.json

在本地运行此问题时,问题就开始了

我收到我理解的错误消息Unable to import module 'app': No module named 'pyodbc',通常的解决方案是将pyodbc添加到requiremens.txt文件中以进行本地调试。

但是,这样做之后,sam build命令失败,并显示以下消息

Build Failed
Error: PythonPipBuilder:ResolveDependencies - {pyodbc==4.0.26(wheel)}

我可以pip install pyodbc没问题,但是由于某种原因,sam build失败了。

我尝试了各种组合,包括从模板中删除该层并手动安装PyODBC,以使其在本地运行,但没有成功。

1 个答案:

答案 0 :(得分:-1)

对于本地调试,您需要提取zip文件的内容并引用该层的文件路径。

我创建了一个名为lambda-layers的文件夹,并提取了该文件夹内的zip文件内容

enter image description here

提供template.yaml文件中的文件夹路径

将template.yaml文件修改为

enter image description here