AWSMSK上可以使用Kafka的KRaft模式吗?
创始人
2024-09-26 15:30:17
0

是的,AWS MSK支持Kafka的KRaft模式。

以下是使用AWS SDK for Java v2实现Kafka KRaft模式在AWS MSK上交互的示例代码:

import software.amazon.awssdk.services.kafka.KafkaClient;
import software.amazon.awssdk.services.kafka.model.*; 

public class KafkaClientApp {
  public static void main(String[] args) {
    String bootstrapBrokers = "BROKER_1:9092,BROKER_2:9092";
    String topicName = "my-kafka-topic";

    KafkaClient kafkaClient = KafkaClient.builder().build();

    // 创建Kafka主题
    CreateTopicRequest createTopicRequest = CreateTopicRequest.builder()
      .name(topicName)
      .numberOfPartitions(3)
      .replicationFactor(2)
      .build();
    CreateTopicResponse createTopicResponse = kafkaClient.createTopic(createTopicRequest);

    // 获取Kafka主题的ARNS
    DescribeClusterRequest describeClusterRequest = DescribeClusterRequest.builder()
      .clusterArn(clusterArn)
      .build();
    DescribeClusterResponse describeClusterResponse = kafkaClient.describeCluster(describeClusterRequest);
    String clusterArn = describeClusterResponse.clusterInfo().clusterArn();
    String topicArn = String.format("%s/topics/%s", clusterArn, topicName);

    // 创建Kafka KRaft集群
    CreateClusterRequest createClusterRequest = CreateClusterRequest.builder()
      .brokerNodeGroupInfo(nodeGroupInfo)
      .clusterName("my-kafka-krat-cluster")
      .kafkaVersion("2.7.0")
      .numberOfBrokerNodes(2)
      .enhancedMonitoring(EnhancedMonitoring.PER_BROKER)
      .openMonitoring(openMonitoringInfo)
      .encryptionInfo(encryptionInfo)
      .clientAuthentication(clientAuthentication)
      .build();
    CreateClusterResponse createClusterResponse = kafkaClient.createCluster(createClusterRequest);
    String clusterArn = createClusterResponse.clusterArn();

    // 更新Kafka主题以在KRaft模式下运行
    UpdateBrokerStorageRequest updateBrokerStorageRequest = UpdateBrokerStorageRequest.builder()
      .clusterArn(clusterArn)
      .targetBrokerEBSVolumeInfo(targetBrokerEBSVolumes)
      .build();
    UpdateBrokerStorageResponse updateBrokerStorageResponse = kafkaClient.updateBrokerStorage(updateBrokerStorageRequest);

    UpdateBrokerTypeRequest updateBrokerTypeRequest = UpdateBrokerTypeRequest.builder()
      .clusterArn(clusterArn)
      .brokerIds(Arrays.asList("0", "1"))
      .currentVersion(kafkaVersion)
      .targetInstanceType(targetInstanceType)
      .engineVersion(engineVersion)
      .build();
    UpdateBrokerTypeResponse updateBrokerTypeResponse = kafkaClient.updateBrokerType(updateBrokerTypeRequest);

    UpdateClusterKafkaVersionRequest updateClusterKafkaVersionRequest = UpdateClusterKafkaVersionRequest.builder()
      .clusterArn(clusterArn)
      .configurationInfo(kafkaConfigurationInfo)
      .kafkaVersion(kafkaVersion)
      .build();
    UpdateClusterKafkaVersionResponse updateClusterKafkaVersionResponse = kafkaClient.updateClusterKafkaVersion(updateClusterKafkaVersionRequest);

    UpdateClusterConfigurationRequest updateClusterConfigurationRequest = UpdateClusterConfigurationRequest.builder()
      .clusterArn(clusterArn)
      .configurationInfo(kafkaConfigurationInfo)
      .build();
    UpdateClusterConfigurationResponse updateClusterConfigurationResponse = kafkaClient.updateClusterConfiguration(updateClusterConfigurationRequest);

    // 删除Kafka集群
    DeleteClusterRequest deleteClusterRequest = DeleteClusterRequest.builder()
      .clusterArn(clusterArn)
      .currentVersion(kafkaVersion)
      .build();
    DeleteClusterResponse deleteClusterResponse = kafkaClient.deleteCluster(deleteCluster

相关内容

热门资讯

经调查!微乐游戏公众号辅助器,... 经调查!微乐游戏公众号辅助器,随意玩聚乐部辅助,教材教程(了解有挂)-哔哩哔哩亲,关键说明,微乐游戏...
透视透视!德普之星透视,德普之... 透视透视!德普之星透视,德普之星怎么设置埋牌(透视)一贯真的是有挂(发现有挂)-哔哩哔哩小薇(辅助器...
据通报!微乐家乡app辅助器,... 据通报!微乐家乡app辅助器,新道游辅助器,教材教程(的确有挂)-哔哩哔哩该软件可以轻松地帮助玩家将...
透视真的!德普辅助器怎么用,德... 透视真的!德普辅助器怎么用,德扑之心免费透视(透视)竟然存在有挂(有挂讲解)-哔哩哔哩亲,关键说明,...
长期以来!新九游辅助软件,微乐... 长期以来!新九游辅助软件,微乐小程序黑科技,大纲教程(有挂透明挂)-哔哩哔哩1、用户打开应用后不用登...
透视ai代打!德扑圈透视挂,德... 透视ai代打!德扑圈透视挂,德普之星透视辅助软件是真的吗(透视)其实有挂(有挂秘笈)-哔哩哔哩1、每...
为切实保障!枫叶辅助官网地址,... 为切实保障!枫叶辅助官网地址,wpk显示有辅助,技法教程(有挂秘诀)-哔哩哔哩1、实时枫叶辅助官网地...
透视科技!德普辅助器怎么用,德... 透视科技!德普辅助器怎么用,德普之星辅助软件(透视)本来是真的挂(有挂分享)-哔哩哔哩1)德普之星辅...
今天下午!wepoker透视方... 今天下午!wepoker透视方法,如何下载微信小程序雀神挂件,模块教程(有挂存在)-哔哩哔哩1、下载...
透视讲解!德普之星怎么开辅助,... 透视讲解!德普之星怎么开辅助,德普之星辅助软件(透视)都是是真的挂(新版有挂)-哔哩哔哩1、打开软件...