首页 > 解决方案 > 如何修复 AWS lambda 中的“无法导入模块”错误

问题描述

我编写了一个脚本来帮助我自动创建新的微服务。它通过获取 bitbucket 存储库的 URI 和 AWS 凭证来工作。它克隆存储库,添加一个 bitbucket-pipelines.yml 文件。通过调用 CLI 创建一个新的 lambda 函数并使用模板 zip 作为基本代码。它还将 lambda 处理程序设置为main.lambda_handler. 然后它将必要的存储库变量添加到 bitbucket 并提交项目文件。然后管道运行并更新 lambda 上的代码。在我尝试运行 Lambda 之前,一切似乎都很好。

这是 bitbucket-pipelines.yml 文件

image: peteremil/zipaws

pipelines:
  default:
    - step:
        name: Deploy code to S3
        deployment: staging
        script:
          - mkdir packages
          - pip install -r requirements.txt --target=packages
          - chmod 777 -R *
          - zip -r $semver.zip .
          - aws s3 cp $semver.zip s3://{code_s3_bucket}/$staging_location/
          - aws lambda update-function-code --region $aws_region --function-name {function_name}-function --s3-bucket {code_s3_bucket} --s3-key $staging_location/$semver.zip

这是 main.py 文件

import json
import os
import sys
import requests

packages_path = os.path.join(os.path.split(__file__)[0], "packages")
sys.path.append(packages_path)


def main(local_id):
    return {
        "success" : local_id
    }


def lambda_handler(event, context):
    local_id = event["queryStringParameters"]["local_id"]
    response = main(local_id)
    return {
        "statusCode": 200,
        "headers": {"content-type": "application/json"},
        "body": json.dumps(response)
    }


if __name__ == '__main__':
    local_id = sys.argv[-1]
    response = main(local_id)
    print(response)

我创建了以下测试事件

{
    "queryStringParameters": {
        "local_id": "00000000"
    }
} 

我创建的事件的预期结果应该是

{
    "statusCode": 200,
    "headers" : {"content-type": "application/json"},
    "body" : {
        {
            "success" : "00000000"
    }
}

但相反,lambda 执行失败并给了我

{
    "errorMessage": "Unable to import module 'main'"
}

我尝试重命名处理程序,获取另一个工作 lambda 的设置(从控制台手动创建)并查看是否有任何差异,但我总是得到相同的错误。main.py 文件在内联代码编辑器中显示得很好。

更新 1import requests将这一行添加到 main.py,因为事实证明它导致了问题。我认为它是无害的,这就是为什么我没有将它包含在原始问题正文中。

标签: pythonamazon-web-servicesaws-lambdabitbucket-pipelines

解决方案


事实证明,在我的代码中,我在packages\文件夹中安装了一个库的导入,但我在将文件夹添加到之前导入了它,sys.path因此解决方案是import requests在将packages_path路径添加到sys.path.

main.py 现在开始是这样的

import json
import os
import sys

packages_path = os.path.join(os.path.split(__file__)[0], "packages")
sys.path.append(packages_path)

import requests #moved this line down after adding packages_path to sys.path

推荐阅读