gpt4 book ai didi

java - 是否可以在我的 S3 lambda 函数中创建文件?

转载 作者:搜寻专家 更新时间:2023-11-01 04:02:37 25 4
gpt4 key购买 nike

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

InputStream videoObjectStream = awsS3Video.getObjectContent();

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

我试图在我的 Lambda 函数中将 InputStream 转换为临时文件,但它不允许我创建文件。这是我将 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)

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

最佳答案

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

关于java - 是否可以在我的 S3 lambda 函数中创建文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43145934/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com