![](/img/trans.png)
[英]How to zip file in .gz format in s3 bucket using java,aws-lamda
[英]Writing parquet files to S3 using AWS java lamda
我正在編寫從Lambda讀取Kinesis的protobuf對象的AWS Lambda,並希望將它們作為木地板文件寫入s3。
我看到有一個用於protobuf的ParquetWriter實現,稱為ProtoParquetWriter,很好。 我的問題是ProtoParquetWriter期望在其構造函數中使用Path。
假設我根本不使用文件系統,那么在不將內容另存為拼花文件的情況下正確的做法是什么?
如果要寫入S3,可以將路徑設置為Path("s3a://<bucketName>/<s3Key>")
。 並且不要忘記在配置中設置S3憑據:
conf.set("fs.s3a.access.key", "<s3AccessKey");
conf.set("fs.s3a.secret.key", "<s3SecretKey");
假設您有一個列表(可以是任何復雜的對象),請使用示例代碼讀取/寫入protobuf S3實木復合地板
public class SimpleS3ParquetUtilities implements S3Utilities {
final Logger logger;
String PATH_SCHEMA = "s3a";
CompressionCodecName compressionCodecName;
public SimpleS3ParquetUtilities(Logger logger) {
this.logger = logger;
this.compressionCodecName = CompressionCodecName.UNCOMPRESSED;
}
public SimpleS3ParquetUtilities(Logger logger, CompressionCodecName compressionCodecName) {
this.logger = logger;
this.compressionCodecName = compressionCodecName;
}
@Override
public String writeTransactions(String bucket, String objectKey, List<Transaction> transactions)
throws Exception {
if (objectKey.charAt(0) != '/')
objectKey = "/" + objectKey;
Path file = new Path(PATH_SCHEMA, bucket, objectKey);
Stopwatch sw = Stopwatch.createStarted();
// convert the list into protobuf
List<TransactionProtos.Transaction> protoTransactions = Convertor.toProtoBuf(transactions);
try (ProtoParquetWriter<TransactionProtos.Transaction> writer = new ProtoParquetWriter<TransactionProtos.Transaction>(
file, TransactionProtos.Transaction.class, this.compressionCodecName,
ProtoParquetWriter.DEFAULT_BLOCK_SIZE, ProtoParquetWriter.DEFAULT_PAGE_SIZE)) {
for (TransactionProtos.Transaction transaction : protoTransactions) {
writer.write(transaction);
}
}
logger.info("Parquet write elapse:[{}{}] Time:{}ms items:{}", bucket, objectKey,
sw.elapsed(TimeUnit.MILLISECONDS), transactions.size());
return "";
}
@Override
public List<Transaction> readTransactions(String bucket, String pathWithFileName)
throws Exception {
if (pathWithFileName.charAt(0) != '/')
pathWithFileName = "/" + pathWithFileName;
Path file = new Path(PATH_SCHEMA, bucket, pathWithFileName);
Stopwatch sw = Stopwatch.createStarted();
try (ParquetReader<TransactionProtos.Transaction.Builder> reader = ProtoParquetReader.<TransactionProtos.Transaction.Builder>builder(
file).build()) {
List<TransactionProtos.Transaction> transactions = new ArrayList<TransactionProtos.Transaction>();
TransactionProtos.Transaction.Builder builder = reader.read();
while (builder != null) {
TransactionProtos.Transaction transaction = builder.build();
transactions.add(transaction);
builder = reader.read();
}
logger.info("Parquet read elapsed:[{}{}] Time:{}ms items:{}", bucket, pathWithFileName,
sw.elapsed(TimeUnit.MILLISECONDS), transactions.size());
return Convertor.fromProtoBuf(transactions);
}
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.