【问题标题】:Is it possible to create a file in my S3 lambda function?是否可以在我的 S3 lambda 函数中创建文件?
【发布时间】:2017-08-26 00:51:11
【问题描述】:

我正在为 AWS Lambda 创建一个 java 函数,该函数从 AWS S3 引入一个文件,如下所示:

InputStream videoObjectStream = awsS3Video.getObjectContent();

我也在使用 FFmpegFrameGrabber,它要求我在创建新的 frameGrabber 时指定一个文件路径,即:FFmpegFrameGrabber frameGrabber = new FFmpegFrameGrabber(filePath)

我正在尝试将 InputStream 转换为我的 Lambda 函数中的临时文件,但它不允许我创建文件。这是我将videoObjectStream 转换为文件的代码:

byte[] inputBuffer = null;

        try {
            inputBuffer = IOUtils.toByteArray(videoObjectStream);
        } catch (IOException e1) {
            // TODO Auto-generated catch block
            e1.printStackTrace();
        }

        System.out.println("The length of the byte array is " + inputBuffer.length);


        try {
            FileOutputStream videoOS = new FileOutputStream(videoDetails.get("videoFileKey"), false);
            videoOS.write(inputBuffer);
            videoOS.close();
        } catch (FileNotFoundException e1) {
            // TODO Auto-generated catch block
            e1.printStackTrace();
        } catch (IOException ex) {
            ex.printStackTrace();
        }

        File tempVideoFile = new File(videoDetails.get("videoFileKey"));

        if (tempVideoFile.exists()) {
            System.out.println("The file exists");
        } else {
            System.out.println("The file does not exist");
        }

然后,我得到以下堆栈跟踪,说这是一个只读文件系统:

java.io.FileNotFoundException: currentPath1490660005410.mp4 (Read-only file system)
    at java.io.FileOutputStream.open0(Native Method)
    at java.io.FileOutputStream.open(FileOutputStream.java:270)
    at java.io.FileOutputStream.<init>(FileOutputStream.java:213)
    at java.io.FileOutputStream.<init>(FileOutputStream.java:133)
    at com.amazonaws.lambda.LambdaFunctionHandler.convertVideo(LambdaFunctionHandler.java:67)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at lambdainternal.EventHandlerLoader$PojoMethodRequestHandler.handleRequest(EventHandlerLoader.java:456)
    at lambdainternal.EventHandlerLoader$PojoHandlerAsStreamHandler.handleRequest(EventHandlerLoader.java:375)
    at lambdainternal.EventHandlerLoader$2.call(EventHandlerLoader.java:1139)
    at lambdainternal.AWSLambda$2.call(AWSLambda.java:94)
    at lambdainternal.AWSLambda.startRuntime(AWSLambda.java:290)
    at lambdainternal.AWSLambda.<clinit>(AWSLambda.java:57)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:348)
    at lambdainternal.LambdaRTEntry.main(LambdaRTEntry.java:94)

有没有办法解决这个问题?我需要操作视频数据,但必须先将其制成文件。欢迎任何建议。谢谢。

【问题讨论】:

    标签: java amazon-web-services amazon-s3 aws-lambda


    【解决方案1】:

    您必须在/tmp 中创建文件。这是您在 Lambda 环境中唯一可以写入的位置。

    【讨论】:

    • 是的,刚刚意识到这一点,使用以下代码行它可以工作:tempVideoFile = File.createTempFile(videoDetails.get("videoFileKey").substring(0, videoDetails.get("videoFileKey").length() - 4), ".mp4");
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2019-12-30
    • 1970-01-01
    • 1970-01-01
    • 2021-12-07
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多