Amazon Managed Streaming for Apache Kafka
Hands-On Demo
data:image/s3,"s3://crabby-images/b1041/b1041fc1fd2dd321158da3825847d4d90cb36d82" alt=""
In this demo, we will:
- Create an Amazon MSK cluster.
- Create IAM Policy and Role for the EC2 Instance to assume.
- Create an EC2 instance to interact with the MSK cluster.
- Create a Kafka topic.
- Produce and consume messages using the Kafka client.
- Test the setup.
- Clean up resources.
Agenda
data:image/s3,"s3://crabby-images/2e907/2e907312bb025e416ea7ec832a42a49b68b41468" alt=""
Demo Overview
Creata an Amazon MSK Cluster
data:image/s3,"s3://crabby-images/6e97a/6e97ab8614ea86172f78b0ebe65472c3ecc118fb" alt=""
data:image/s3,"s3://crabby-images/226c7/226c769647d2327b04da9496ffb6ded26bdfaa44" alt=""
msk-demo-cluster
Custom create
data:image/s3,"s3://crabby-images/fb5e3/fb5e3e39049a5b8447b849e96495cab306c4937e" alt=""
Cluster type
data:image/s3,"s3://crabby-images/deb46/deb46c70a6f492597a3a262ffc3bf221119b8025" alt=""
Brokers
data:image/s3,"s3://crabby-images/6d86b/6d86bb677436d95733af63d9785237ce0d4ef017" alt=""
Storage
data:image/s3,"s3://crabby-images/4cb40/4cb40269c44ee77ca9d97a9e226229d7a88f2c52" alt=""
Configuration
data:image/s3,"s3://crabby-images/ffb07/ffb07db7b9c5529535338e3f17dda10ddf64ac65" alt=""
data:image/s3,"s3://crabby-images/f3d02/f3d02100f23c436c6e9d821b59dd7c6d0116b467" alt=""
data:image/s3,"s3://crabby-images/d7750/d77502c116e3bcfb68492da33421bfc29c39929a" alt=""
Networking
data:image/s3,"s3://crabby-images/46ff7/46ff7cffa4c1e81688661d5ed3dc282e4d8a423c" alt=""
Security groups
data:image/s3,"s3://crabby-images/f8d5e/f8d5e770142bd69c1423a3987e82f654e4491b4f" alt=""
Access control methods
data:image/s3,"s3://crabby-images/6a8ca/6a8ca0fd5e0b4df99fde8fe342392983eece675e" alt=""
data:image/s3,"s3://crabby-images/c204e/c204e6ff2902f66796d4efc614161ea1115ca903" alt=""
Encryption
data:image/s3,"s3://crabby-images/5e53d/5e53db548addaefee55a089de65c2f92400c4d39" alt=""
Monitoring and tags
data:image/s3,"s3://crabby-images/83fbc/83fbc17e7774bdc11cf9058b0cc6e9380d573070" alt=""
Open monitoring with Prometheus
data:image/s3,"s3://crabby-images/ef593/ef593dda620438fbe0a34487bcfe53e3360212bb" alt=""
Cluster tags
data:image/s3,"s3://crabby-images/a4b0d/a4b0d5bbb5618e146bec55f19492954654fbe599" alt=""
Review and create
data:image/s3,"s3://crabby-images/7ff78/7ff787c7d34eb3439ec57873ad26987064466d9c" alt=""
data:image/s3,"s3://crabby-images/8b772/8b7729c22122fc8301656ba96e98361ada0b2584" alt=""
data:image/s3,"s3://crabby-images/3f49a/3f49ad2301b774cfe5fa0445b5859d80a2b464f8" alt=""
data:image/s3,"s3://crabby-images/f0a99/f0a997a636899f65d8c03ff7b14342e62c3ba5e2" alt=""
data:image/s3,"s3://crabby-images/f4183/f41834f65a12cdfbfaa60e998846562de7a546f5" alt=""
Create IAM Policy and IAM Role
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"kafka-cluster:Connect",
"kafka-cluster:AlterCluster",
"kafka-cluster:DescribeCluster"
],
"Resource": [
"arn:aws:kafka:us-east-1:651623850282:cluster/msk-demo-cluster/*"
]
},
{
"Effect": "Allow",
"Action": [
"kafka-cluster:*Topic*",
"kafka-cluster:WriteData",
"kafka-cluster:ReadData"
],
"Resource": [
"arn:aws:kafka:us-east-1:651623850282:topic/msk-demo-cluster/*"
]
},
{
"Effect": "Allow",
"Action": [
"kafka-cluster:AlterGroup",
"kafka-cluster:DescribeGroup"
],
"Resource": [
"arn:aws:kafka:us-east-1:651623850282:group/msk-demo-cluster/*"
]
}
]
}
data:image/s3,"s3://crabby-images/a1213/a1213070c37efea0f21b4bec3ffafe361d4fd6d8" alt=""
Create policy
data:image/s3,"s3://crabby-images/da85b/da85bf09229404187e90d14bc44840e619eb8daf" alt=""
msk-iam-policy
data:image/s3,"s3://crabby-images/ca2a5/ca2a5fe9d83bae683764d0515f6bd10190f1da33" alt=""
Create role
data:image/s3,"s3://crabby-images/c8275/c8275583b80e690743afebc9b2d9596aed5cdb30" alt=""
msk-iam-policy
Add permissions
data:image/s3,"s3://crabby-images/08d5e/08d5e2425ac86e849104f5fef28312f80fa0c596" alt=""
msk-iam-role
Name, review, and create
data:image/s3,"s3://crabby-images/e8a92/e8a92f3980d2c2427a5cd479f960843f9814dd37" alt=""
data:image/s3,"s3://crabby-images/58aa8/58aa8083c72bd75fa36ccb28f4fa6bd23db65730" alt=""
Create an EC2 Instance
data:image/s3,"s3://crabby-images/80ca5/80ca5a67f44fb0a8169d7236fa1b8fdc737eea7d" alt=""
MSK-Demo-Client
Launch an instance
data:image/s3,"s3://crabby-images/31717/317179dc0e8fa82e769f87cbcb2ee5aa47b2d129" alt=""
data:image/s3,"s3://crabby-images/08608/08608eca470c9c7629e1ac26575d75659d4924ae" alt=""
data:image/s3,"s3://crabby-images/36e08/36e08beb9f7064836f691e01be3c22ff703ea66f" alt=""
Instance type
data:image/s3,"s3://crabby-images/1a966/1a966b250afd6aef19b48761f1685be9258ed331" alt=""
Create key pair
msk-demo-key-pair
data:image/s3,"s3://crabby-images/3fa20/3fa20678b1a76e1cdeadc8ae80ea11d464f036b4" alt=""
Key pair (login)
data:image/s3,"s3://crabby-images/f8c34/f8c342dcc9eadf2a9705199d9efed381b0b391c4" alt=""
Network settings
data:image/s3,"s3://crabby-images/7f078/7f0780396c2cbc43676f78881298dbfefc23fd41" alt=""
Configure storage
data:image/s3,"s3://crabby-images/fe9e5/fe9e5b93b6a36d9fd803341a2d9f6b0b6757a1c4" alt=""
Attach IAM Role to EC2 IAM Instance Profile
data:image/s3,"s3://crabby-images/372cc/372ccd72d92bd86967517cf7e35323853695c6b4" alt=""
Launch instance
data:image/s3,"s3://crabby-images/473e7/473e73171bf5e8aad9265898aaf696bcc19558b7" alt=""
Allow Traffic from EC2 Instance Security Group to MSK Security Group
Launch-Wizard-1 Security Group ---> Default Security Group
Final Setting Look Like
data:image/s3,"s3://crabby-images/b9622/b962235d643cddf2de0f3c92527d097e08718d2a" alt=""
data:image/s3,"s3://crabby-images/90ece/90eceb7dd2ca688c097499f88e7c65aaa74e3e22" alt=""
data:image/s3,"s3://crabby-images/c1f63/c1f637a698782d006a9fc5aa3f1b2b1823495fd8" alt=""
data:image/s3,"s3://crabby-images/1b3d3/1b3d316d065dfd035e5a97365e4fccedd2946118" alt=""
Create a Topic in Amazon MSK Cluster
data:image/s3,"s3://crabby-images/2ce9d/2ce9dd347e512519a802eaacd7d30059b6b7809e" alt=""
EC2 Instance Connect
sudo yum -y install java-11
wget https://archive.apache.org/dist/kafka/3.5.1/kafka_2.13-3.5.1.tgz
tar -xzf kafka_2.13-3.5.1.tgz
cd kafka_2.13-3.5.1/libs/
wget https://github.com/aws/aws-msk-iam-auth/releases/download/v1.1.1/aws-msk-iam-auth-1.1.1-all.jar
ls aws-msk-iam-auth-1.1.1-all.jar
cd ../bin
Install Java and Kafka
pwd
export PLAIN="
./kafka-topics.sh --create \
--bootstrap-server $PLAIN \
--replication-factor 2 \
--partitions 1 \
--topic msk-demo-topic
Plaintext Connection
export SSL="
./kafka-topics.sh --create \
--bootstrap-server $SSL \
--command-config client.properties \
--replication-factor 2 \
--partitions 1 \
--topic msk-demo-topic-2
cat << EOF > client.properties
security.protocol=SSL
ssl.truststore.location=/usr/lib/jvm/java-11-amazon-corretto/lib/security/cacerts
ssl.truststore.password=changeit
EOF
cat client.properties
SSL Based Connection
Open a Kafka
Consumer Client
cd kafka_2.13-3.5.1/bin
export SSL="
./kafka-console-consumer.sh \
--bootstrap-server $SSL \
--consumer.config client.properties \
--topic msk-demo-topic --from-beginning
Consumer
Producer
export SSL="
./kafka-console-producer.sh \
--broker-list $SSL \
--producer.config client.properties \
--topic msk-demo-topic
hi, how are you
i am good
what a lovely way to exchange messages
i will continue to send messages
and this will be picked up when the consumer comes online
great
Shutdown the consumer for testing
Clean Up
data:image/s3,"s3://crabby-images/b3b66/b3b66d762aa0e18684bcf3fe03ebd5bab2f80cf3" alt=""
Delete msk-demo-cluster
data:image/s3,"s3://crabby-images/bc189/bc1894f09a3b045ffbe327397b928a57db26598a" alt=""
data:image/s3,"s3://crabby-images/58b3b/58b3b145194723f190a92ed03d82503510654653" alt=""
Terminate (delete) instance
data:image/s3,"s3://crabby-images/ce0c1/ce0c1624b37cd577e8a37cff93a02f8dd99e01fe" alt=""
data:image/s3,"s3://crabby-images/eddb8/eddb8f1d1a396e08d8111f0a996f0e214b8fa49a" alt=""
Delete IAM Policy
data:image/s3,"s3://crabby-images/aa259/aa2596aaf51b43d68e171ccc032a43f772308e9a" alt=""
data:image/s3,"s3://crabby-images/34124/34124404a0a64107a855bbe564b3baad61e0350a" alt=""
Delete IAM Role
data:image/s3,"s3://crabby-images/bfdeb/bfdebef5bc69e8fd7aa58f541a7d3c9683db3c0a" alt=""
data:image/s3,"s3://crabby-images/e95cc/e95ccba96a100bfd31b37eee90a512436a5c002a" alt=""
Delete Key Pair
Remove Inbound Rule from Default Security Group
data:image/s3,"s3://crabby-images/4b274/4b274039183d97b017bb56b216e699fe3e1cd118" alt=""
data:image/s3,"s3://crabby-images/0afcb/0afcb438a191f251e454b8c12cad5a11412ec22d" alt=""
Delete launch-wizard-1 Security Group
data:image/s3,"s3://crabby-images/fae52/fae52def288e05980b568b6234778d261ee48e0a" alt=""
🙏
Thanks
for
Watching
Amazon Managed Streaming for Apache Kafka - Hands-On Demo
By Deepak Dubey
Amazon Managed Streaming for Apache Kafka - Hands-On Demo
Amazon Managed Streaming for Apache Kafka - Hands-On Demo
- 196