-1

我正在尝试将一些数据放入我的 AWS Firehose Stream,但遇到了一些困难。我还收到一个错误,即找不到我的流名称,即使它确实以该名称存在。我还尝试了另一个活动流,我遇到了同样的问题。我不确定此错误是否与不推荐使用构造函数时遇到的错误有关。

在帐户 xxxxxxxxxxx 下找不到 Firehose 项目流。(服务:AmazonKinesisFirehose;状态代码:400;错误代码:ResourceNotFoundException;请求 ID:xxxxxxxxxxxxxxxxxxxxxxxx

在我第一次尝试捕获后尝试创建“firehoseClient”时出现以下错误:

构造函数 AmazonKinesisFirehoseClient(AWSCredentials) 已弃用

我试图查看 AWS 的 API,但找不到有效的构造函数。

package com.amazonaws.samples;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.nio.ByteBuffer;
import java.util.Collection;

import com.amazonaws.*;
import com.amazonaws.AmazonClientException;
import com.amazonaws.auth.AWSCredentials;
import com.amazonaws.auth.AWSCredentialsProvider;
import com.amazonaws.auth.AWSStaticCredentialsProvider;
import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.kinesisfirehose.model.PutRecordRequest;
import com.amazonaws.services.kinesisfirehose.AmazonKinesisFirehoseClient;
import com.amazonaws.services.kinesisfirehose.model.Record;
import com.amazonaws.services.kinesisfirehose.AmazonKinesisFirehoseClient;
import com.amazonaws.services.kinesisfirehose.*;

public class FirehoseExample {

    public static void main(String[] args) {
        AWSCredentials credentials = null;

        try {
            credentials = new ProfileCredentialsProvider().getCredentials();
        }

        catch (Exception e) {
            throw new AmazonClientException("Cannot load the credentials from the credential profiles file. "
                    + "Please make sure that your credentials file is at the correct "
                    + "location (/Users/elybenari/.aws/credentials), and is in valid format.", e);
        }

        AmazonKinesisFirehoseClient firehoseClient = new AmazonKinesisFirehoseClient(credentials);
        PutRecordRequest request = new PutRecordRequest();

        request.setDeliveryStreamName("project-stream");

        Record record = new Record();

        for (int i = 0; i < 10*60; i++){
            try {
                URL url = new URL("https://www.google.com/finance/info?q=NASDAQ:AMZN");
                HttpURLConnection conn = (HttpURLConnection) url.openConnection();
                BufferedReader reader = new BufferedReader(new InputStreamReader(conn.getInputStream()));
                StringBuilder response = new StringBuilder();
                String line;

                while ((line = reader.readLine()) != null) {
                    response.append(line);  
                }
                reader.close();

                System.out.println(response.toString().replace("\n", "").replaceAll(" ", ""));
                System.out.println("****\n");

                ByteBuffer buff = ByteBuffer.wrap(response.toString().replace("\n", "").replaceAll(" ", "").getBytes());
                record.setData(buff);

                request.setRecord(record);
                firehoseClient.putRecord(request);
                Thread.sleep(2000);


            }
            catch(Exception e){
                e.printStackTrace();
            }
        }   
    }
}
4

1 回答 1

1

使用静态 builder() 方法而不是弃用的构造函数。

javadoc 文档建议使用这种方法,而不是使用已弃用的构造函数:

AmazonKinesisFirehoseClient client = AmazonKinesisFirehoseClientBuilder.standard().withCredentials(new AWSStaticCredentialsProvider(awsCredentials)).build();
// You can now use the client as you normally would...
client.putRecord(xyz);

请参阅:http ://docs.aws.amazon.com/AWSJavaSDK/latest/javadoc/com/amazonaws/services/kinesisfirehose/AmazonKinesisFirehoseClient.html#AmazonKinesisFirehoseClient-com.amazonaws.auth.AWSCredentials-

于 2017-04-05T19:40:45.553 回答