2017-03-31 28 views
0

我創建了AWS LAMBDA,在從AWS S3文件這樣帶來的一個java功能:是否可以在我的S3 lambda函數中創建一個文件?

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) 

有什麼辦法在這附近?我需要操作視頻數據,但是如果不先製作成文件,則無法操作。歡迎任何建議。謝謝。

回答

5

您必須在/tmp中創建文件。這是您允許在Lambda環境中寫入的唯一位置。

+0

是的只是意識到它,使用下面的代碼行,它的工作原理:。 'tempVideoFile = File.createTempFile(videoDetails.get( 「videoFileKey」)子串(0,videoDetails.get( 「videoFileKey」)長度() - 4),「.mp4」);' – hermt2

+1

嗨@ hermt2,如果這個或任何答案已經解決了你的問題,請考慮[接受它](http://meta.stackexchange.com/q/5234/179419)通過點擊複選標記。這向更廣泛的社區表明,您已經找到了解決方案,併爲答覆者和您自己提供了一些聲譽。沒有義務這樣做。 –

相關問題