Skip to content

JoshuaTyler-GitHub/CloudFormationTemplates

 
 

Repository files navigation

AWS MSK Kafka Cluster Cloud Formation

1) Deploy the CFT - (usually takes around 15 minutes to build)

2) Get the and other information about your cluster by entering the following code

$ aws kafka describe-cluster --region <Replace_With_us-east-1_or_us-west-2> --cluster-arn <Replace_With_Your_cluster-arn>

3) Get the by entering the following code provide your region & cluster ARN

$ aws kafka get-bootstrap-brokers --region <Replace_With_us-east-1_or_us-west-2> --cluster-arn <Replace_With_us-east-1_or_us-west-2>

4) Setup your SSL Truststore. Go to the bin folder (kafka/kafka_2.12-2.2.1/bin/) of the Apache Kafka installation on the client machine and setup your client.properties folder in the kafka/bin

4.1)    sudo touch client.properties
        sudo chmod 777 client.properties
        vim client.properties

4.2) client.properties content
    =======================
    security.protocol=SSL
    ssl.truststore.location=/tmp/kafka.client.truststore.jks
    =======================

4.3) copy your Java JVM JDK security cacerts to the tmp truststore location
    cp /usr/lib/jvm/<Java_JDK>/jre/lib/security/cacerts /tmp/kafka.client.truststore.jks
    (where <Java_JDK> looks like: java-1.8.0-openjdk-1.8.0.282.b08-1.amzn2.0.1.x86_64)

5) Create a Kafka Topic by providing the from step 3 (you should receive a confirmation message) (replication factor is the number of subnets you have clusters on):

$ ./kafka-topics.sh --create --zookeeper <Replace_With_Your_ZookeeperConnectString> --replication-factor 3 --partitions 1 --topic <Replace_With_Your_Desired_Topic_Name_String>

6) Test the end-to-end processes by producing and consuming messages to Amazon MSK. Complete the following steps:

10.1) Navigate to the kafka/kafka_2.12-2.2.1/bin directory and start the Kafka console consumer. See the following code:
        $ ./kafka-console-consumer.sh
            --bootstrap-server <Replace_With_Your_BootstrapserversConnectString>
            --consumer.config client.properties
            --topic <Replace_With_Your_Desired_Topic_Name_String>
            --from-beginning 

10.2) Open another terminal and navigate to the kafka/kafka_2.12-2.2.1/bin directory and start the Kafka console producer. See the following code:
        $ ./kafka-console-consumer.sh
            --bootstrap-server <Replace_With_Your_BootstrapserversConnectString>
            --consumer.config client.properties
            --topic <Replace_With_Your_Desired_Topic_Name_String>
            --from-beginning

7) Configure API Gateway

9.1) On the API Gateway console, choose Create API.
9.2) For API type, choose REST API.
9.3) Choose Build.
9.4) Choose New API.
9.5) For API Name, enter a name (for example, amazonmsk-restapi).
9.6) As an optional step, for Description, enter a brief description.
9.7) Choose Create API.The next step is to create a child resource.
9.8) Under Resources, choose a parent resource item.
9.9) Under Actions, choose Create Resource.The New Child Resource pane opens.
9.10) Select Configure as proxy resource.
9.11) For Resource Name, enter proxy.
9.12) For Resource Path, enter /{proxy+}.
9.13) Select Enable API Gateway CORS.
9.14) Choose Create Resource.
9.15) For Integration type, select HTTP Proxy.
9.16) For Endpoint URL, enter an HTTP backend resource URL (your Kafka Clien Amazont EC2 instance PublicDNS; for example, http://KafkaClientEC2InstancePublicDNS:8082/{proxy} or https://KafkaClientEC2InstancePublicDNS:8085/{proxy}).
9.17) Use the default settings for the remaining fields.
9.18) Choose Save.
9.19) For SSL, for Endpoint URL, use the HTTPS endpoint.
9.20) Choose the API you just created.
9.21) Under Actions, choose Deploy API.
9.22) For Deployment stage, choose New Stage.
9.23) For Stage name, enter the stage name (for example, dev, test, or prod).
9.24) Choose Deploy.
9.25) Record the Invoke URL after you have deployed the API.

8) Install the Kafka REST API of your choice

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published