【问题标题】:open no such file or directory打开没有这样的文件或目录
【发布时间】:2018-10-16 15:52:18
【问题描述】:

我正在尝试按照 AWS lambda go 和 s3 示例创建一个函数,该函数将从 s3 下载文件并调整其大小并上传回 s3。

当我构建函数并在本地机器上运行它时,一切正常,当我作为 lambda 运行它时,我得到“”open /tmp/images/users/original/5bba5c0f01e2f_dcadcc7139454bf6dba4cbd01a7c92f8.jpeg:没有这样的文件或目录“

这是我的代码

package main

import (
    "github.com/aws/aws-sdk-go/aws"
    "github.com/aws/aws-sdk-go/aws/session"
    "github.com/aws/aws-sdk-go/service/s3"
    "github.com/aws/aws-sdk-go/service/s3/s3manager"
    "github.com/aws/aws-lambda-go/lambda"
    "github.com/nfnt/resize"
    "image/jpeg"

    "fmt"
    "os"
)


func HandleRequest() (string, error) {
     return runResize("5bba5c0f01e2f_dcadcc7139454bf6dba4cbd01a7c92f8.jpeg"), nil
}

func main() {
        lambda.Start(HandleRequest)
}

func runResize(item_name string) {
    bucket := "bucket"
    folder_name := "images/users/original/"
    folder_name_220x220 := "images/users/220x220/"
    folder_name_250x250 := "images/users/250x250/"
    folder_name_500x500 := "images/users/500x500/"
    folder_name_large := "images/users/large/"

    createFolder(folder_name)
    createFolder(folder_name_220x220)
    createFolder(folder_name_250x250)
    createFolder(folder_name_500x500)
    createFolder(folder_name_large)

    item := folder_name + item_name

    fmt.Printf("Creating file %q \n", item)


    file, err :=  os.Create(item)
    if err != nil {
        exitErrorf("Unable to open file %q", err)
    }

    defer file.Close()

    sess, _ := session.NewSession(&aws.Config{
        Region: aws.String("us-east-1")},
    )

    downloader := s3manager.NewDownloader(sess)

    numBytes, err := downloader.Download(file,
        &s3.GetObjectInput{
            Bucket: aws.String(bucket),
            Key:    aws.String(item),
        })
    if err != nil {
        exitErrorf("Unable to download item %q, %v", item, err)
    }


    if err != nil {
        exitErrorf("Unable to download item %q, %v", item, err)
    }

    // decode jpeg into image.Image
    img, err := jpeg.Decode(file)
    if err != nil {
        exitErrorf("Unable to download item %q, %v", item, err)
    }
    file.Close()


    m := resize.Thumbnail(1500, 1500, img, resize.Lanczos3)
    out, err := os.OpenFile(folder_name_large + item_name, os.O_RDWR|os.O_CREATE, 0666)
    if err != nil {
        exitErrorf("Unable to resize item %q, %v", item, err)
    }
    defer out.Close()
    jpeg.Encode(out, m, nil)


    m = resize.Thumbnail(500, 500, img, resize.Lanczos3)
    out, err = os.OpenFile(folder_name_500x500 + item_name, os.O_RDWR|os.O_CREATE, 0666)
    if err != nil {
        exitErrorf("Unable to resize item %q, %v", item, err)
    }
    defer out.Close()
    jpeg.Encode(out, m, nil)

    m = resize.Thumbnail(250, 250, img, resize.Lanczos3)
    out, err = os.OpenFile(folder_name_250x250 + item_name, os.O_RDWR|os.O_CREATE, 0666)
    if err != nil {
        exitErrorf("Unable to resize item %q, %v", item, err)
    }
    defer out.Close()
    jpeg.Encode(out, m, nil)

    m = resize.Thumbnail(220, 220, img, resize.Lanczos3)
    out, err =  os.OpenFile(folder_name_220x220 + item_name, os.O_RDWR|os.O_CREATE, 0666)
    if err != nil {
        exitErrorf("Unable to resize item %q, %v", item, err)
    }
    defer out.Close()
    jpeg.Encode(out, m, nil)

    uploadFile(folder_name_220x220 + item_name, bucket)
    uploadFile(folder_name_250x250 + item_name, bucket)
    uploadFile(folder_name_500x500 + item_name, bucket)
    uploadFile(folder_name_large + item_name, bucket)


    fmt.Println("Processed", file.Name(), numBytes, "bytes")
}

func createFolder(folder_name string) {
    if _, err := os.Stat(folder_name); os.IsNotExist(err) {
        os.MkdirAll(folder_name, os.ModePerm)
        fmt.Printf("Folder created %q \n", folder_name)
    }
}

func uploadFile(filename string, bucket string){
    file, err := os.Open(filename)
    if err != nil {
        exitErrorf("Unable to open file %q, %v", err)
    }

    defer file.Close()
    sess, err := session.NewSession(&aws.Config{
        Region: aws.String("us-east-1")},
    )

    uploader := s3manager.NewUploader(sess)
    _, err = uploader.Upload(&s3manager.UploadInput{
        Bucket: aws.String(bucket),
        Key: aws.String(filename),
        Body: file,
        ACL:  aws.String("public-read"),
    })
    if err != nil {
        // Print the error and exit.
        exitErrorf("Unable to upload %q to %q, %v", filename, bucket, err)
    }

fmt.Printf("Successfully uploaded %q to %q\n", filename, bucket)
}


func exitErrorf(msg string, args ...interface{}) {
    fmt.Fprintf(os.Stderr, msg+"\n", args...)
    os.Exit(1)
}

这是我的构建方式

GOOS=linux go build -v -ldflags '-d -s -w' -a -tags netgo -installsuffix netgo -o resize && zip deployment.zip resize

当我在本地运行时,一切正常,但在 lambda get 上运行时,我得到错误

【问题讨论】:

  • 请确保上面显示的程序列表完全您正在运行并提供完全所有记录输出
  • 是一样的,我有两个版本,一个有tmp文件夹,一个没有,我已经删除了tmp,这样就不会那么混乱了。问题是代码在 aws 实例上运行良好,但不能作为 lambda 运行
  • 我注意到您没有在createFolder 中检查从os.MkdirAll 返回的错误。 - 这可能会失败,因此不会创建下载位置。此外,您提供的错误消息与您在代码中打印的任何错误消息都不匹配 - 您对所有错误的格式都不同,那么它来自哪里?

标签: amazon-web-services go aws-lambda


【解决方案1】:

好的,所以这段代码首先运行

folder_name := "images/users/original/"
folder_name_220x220 := "images/users/220x220/"
folder_name_250x250 := "images/users/250x250/"
folder_name_500x500 := "images/users/500x500/"
folder_name_large   := "images/users/large/"

createFolder(folder_name)

在程序当前所在的任何地方创建一个文件夹

然后它会这样做

 item := "/tmp"/folder_name + item_name

    fmt.Printf("Creating file %q \n", item)


    file, err :=  os.OpenFile(item, os.O_RDWR|os.O_CREATE, 0666)
    if err != nil {
        exitErrorf("Unable to open file %q", err)
    }

当你在本地运行它时,它会在你所在的任何目录中创建文件夹

大概在某个时候,您也在 /tmp 中创建了这些文件夹

在 lambda 中会发生同样的事情,但 lambda 函数必须在 /tmp 目录之外的其他地方运行

所以部分路径没有找到,程序失败

修复它

folder_name := "images/users/original/"

成为

folder_name := "/tmp/images/users/original/"

并删除 "/tmp" + 行

【讨论】:

  • 如果我在本地服务器上运行而不是 lambda,代码运行良好
  • 我尝试了本地路径和 tmp,两种情况都在 lambda 上失败,在 aws 服务器上运行良好
猜你喜欢
  • 1970-01-01
  • 2016-06-24
  • 1970-01-01
  • 1970-01-01
  • 2022-10-18
  • 2021-03-26
  • 2020-08-05
  • 2023-04-06
  • 2019-04-07
相关资源
最近更新 更多