AWS Organizations
Hands-On
Demo
data:image/s3,"s3://crabby-images/b7740/b7740c8608ef1fe12a462c74bd807e532426d191" alt=""
In this Demo, we will:
- Create AWS Organization.
- Create Production and Development OUs.
- Create Development SCP (t2/t3 instances, region limits).
- Create Production SCP (encryption, deletion protection).
- Setup Development tags (Environment, Project).
- Setup Production tags (Environment, CostCenter, BusinessUnit).
- Enable tag policy reporting.
- Attach and test policies.
Agenda
data:image/s3,"s3://crabby-images/76b24/76b241adb25ecebcbab724bd4ab8a5c42a67f659" alt=""
Create an organization
data:image/s3,"s3://crabby-images/cd79a/cd79a4b58415012d455840f1aeab326a70d1ac9c" alt=""
data:image/s3,"s3://crabby-images/6663c/6663ca1cc0e2abb8e7eedfd449a380e5ff12f0ed" alt=""
Create 1st Organizational Unit (OU)
data:image/s3,"s3://crabby-images/ab605/ab6057085cd405f3acb66ba2291acb7239c10ba2" alt=""
Production
data:image/s3,"s3://crabby-images/482ea/482ea6476d02f91a3f6dac79ea254bdd58a47601" alt=""
Create 2nd OU - Development
data:image/s3,"s3://crabby-images/bf79f/bf79f76081c01d32efd9d56bcfc7523293508970" alt=""
Add 1st AWS account
data:image/s3,"s3://crabby-images/1507e/1507e7a9380d2dd96bd115b248e7e53757fd59f1" alt=""
prod-account
learnpde+prod@gmail.com
data:image/s3,"s3://crabby-images/e4055/e405553bc0cba1c25e0c956ab91eebdc6803299b" alt=""
Create AWS account
data:image/s3,"s3://crabby-images/80d15/80d15bb10158e5dda858b3d5362fc229dc582d6f" alt=""
data:image/s3,"s3://crabby-images/8d677/8d677dd5ecf98d0d85c86cdcbc5940eeb91a087e" alt=""
Create 2nd Account
data:image/s3,"s3://crabby-images/83a33/83a3381216ff7a47298995ecd82927256f1df273" alt=""
learnpde+dev@gmail.com
dev-account
data:image/s3,"s3://crabby-images/e2b12/e2b125f34f6d1605a623cf7ee7ec11b5dd59af88" alt=""
data:image/s3,"s3://crabby-images/10072/10072c20ac74291ffb9a7f6f98c8ce08089e5f77" alt=""
data:image/s3,"s3://crabby-images/7deee/7deeed589fa88ec4b9e1cc44d1a8bda6d64ab09c" alt=""
Move Prod
data:image/s3,"s3://crabby-images/952be/952bed06db3e48e2fc265f3503333ecaab56fc51" alt=""
data:image/s3,"s3://crabby-images/a6006/a6006fc0d7ed2c754918df293554e2d507b5a2a7" alt=""
Move Dev Account
data:image/s3,"s3://crabby-images/b9dfa/b9dfa15dff6ca66f8631d9c02f867b614bec98dc" alt=""
data:image/s3,"s3://crabby-images/67b23/67b23a8f1003e36ae5c50c73fa11fb57b91f28a4" alt=""
data:image/s3,"s3://crabby-images/47cf3/47cf37ce37937ca8bca60e05d3f3d9a649c7f702" alt=""
Policies
data:image/s3,"s3://crabby-images/a081f/a081f0a12bbac7f4cf3a022d8de06c2186278821" alt=""
data:image/s3,"s3://crabby-images/b523f/b523ff59a0ba1ba8cc08c4f5e4b37d4711fa5f57" alt=""
Enable Service control policies
data:image/s3,"s3://crabby-images/7c203/7c203ed043b00a383fc20124dc8eef767e652d8f" alt=""
Create new service control policy
Development-Service-Control-Policy
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "LimitEC2InstanceTypes",
"Effect": "Deny",
"Action": "ec2:RunInstances",
"Resource": "arn:aws:ec2:*:*:instance/*",
"Condition": {
"StringNotLike": {
"ec2:InstanceType": [
"t2.*",
"t3.*"
]
}
}
},
{
"Sid": "DenyNonApprovedRegions",
"Effect": "Deny",
"Action": "*",
"Resource": "*",
"Condition": {
"StringNotEquals": {
"aws:RequestedRegion": [
"us-east-1",
"us-west-2"
]
}
}
}
]
}
Development-Service-Control-Policy
data:image/s3,"s3://crabby-images/279a5/279a5a0fb56d89dc5e9230a5cb51305d16713860" alt=""
data:image/s3,"s3://crabby-images/505c0/505c0b27f357532d808d7df95ab5052cac9d9e72" alt=""
Attach policy to Development OU
data:image/s3,"s3://crabby-images/b9509/b9509b8d7edd654397ab7098be2dc71c595082ca" alt=""
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "EnforceProductionRegions",
"Effect": "Deny",
"Action": "*",
"Resource": "*",
"Condition": {
"StringNotEquals": {
"aws:RequestedRegion": [
"us-east-1",
"us-west-2"
]
}
}
},
{
"Sid": "RequireEncryptedEBSVolumes",
"Effect": "Deny",
"Action": [
"ec2:RunInstances",
"ec2:CreateVolume"
],
"Resource": [
"arn:aws:ec2:*:*:volume/*",
"arn:aws:ec2:*:*:instance/*"
],
"Condition": {
"Bool": {
"ec2:Encrypted": "false"
}
}
},
Production-Service-Control-Policy
{
"Sid": "DenyDeleteProductionTags",
"Effect": "Deny",
"Action": [
"ec2:DeleteTags",
"s3:DeleteObjectTagging",
"rds:RemoveTagsFromResource"
],
"Resource": "*",
"Condition": {
"StringEquals": {
"aws:ResourceTag/Environment": "Production"
}
}
},
{
"Sid": "RequireResourceTags",
"Effect": "Deny",
"Action": [
"ec2:RunInstances",
"rds:CreateDBInstance",
"s3:CreateBucket"
],
"Resource": "*",
"Condition": {
"Null": {
"aws:RequestTag/Environment": "true",
"aws:RequestTag/CostCenter": "true",
"aws:RequestTag/Project": "true"
}
}
}
]
}
Production-Service-Control-Policy
data:image/s3,"s3://crabby-images/35e04/35e046928506bf9c66f8220c9593e0e0a89e3cc3" alt=""
Attach Production Service Control Policy
data:image/s3,"s3://crabby-images/aff4e/aff4e0d81f8a300b79d558fbc14534bb989f68ab" alt=""
data:image/s3,"s3://crabby-images/bb2cf/bb2cfef5069839e3b02af6af31454c44060b1ecd" alt=""
Enable tag policies
data:image/s3,"s3://crabby-images/baa68/baa68dc3012a33d42f096b0da2ccdd1806ee1fd1" alt=""
Create Dev Tag Policy
data:image/s3,"s3://crabby-images/2614f/2614f75ef8cf18f88f0ef24f1a16b78a9c941164" alt=""
dev-tag-policy
{
"tags": {
"Environment": {
"tag_key": {
"@@assign": "Environment"
},
"tag_value": {
"@@assign": [
"dev"
]
},
"enforced_for": {
"@@assign": [
"ec2:instance",
"s3:bucket"
]
}
},
"Project": {
"tag_key": {
"@@assign": "Project"
},
"tag_value": {
"@@assign": [
"alpha",
"beta",
"demo"
]
},
"enforced_for": {
"@@assign": [
"ec2:instance",
"s3:bucket"
]
}
}
}
}
data:image/s3,"s3://crabby-images/77347/77347df455462f04e1b185e749b52e7f6b753b79" alt=""
data:image/s3,"s3://crabby-images/46a20/46a20893874065197bdc3f535db9b5d44cad0201" alt=""
data:image/s3,"s3://crabby-images/bce01/bce010aace496aca052df40370449f9334e4ce9e" alt=""
data:image/s3,"s3://crabby-images/cd8ce/cd8ced96f256383df0ae536d08ce68cd668e68b7" alt=""
prod-tag-policy
Create prod tag policy
{
"tags": {
"environment": {
"tag_key": {
"@@assign": "Environment"
},
"tag_value": {
"@@assign": [
"prod"
]
},
"enforced_for": {
"@@assign": [
"ec2:instance",
"s3:bucket"
]
}
},
"costcenter": {
"tag_key": {
"@@assign": "CostCenter"
},
"tag_value": {
"@@assign": [
"101",
"102",
"103"
]
},
"enforced_for": {
"@@assign": [
"ec2:instance",
"s3:bucket"
]
}
}
}
}
data:image/s3,"s3://crabby-images/17b67/17b67d45bf09b7b3c88ba2360a5f40a0490f2c28" alt=""
data:image/s3,"s3://crabby-images/b108c/b108cb341a9f5480040dd0fa9658f39a484d5cb6" alt=""
data:image/s3,"s3://crabby-images/9b539/9b5394ae6af37146f2380cfdf2852c9d8af7df5d" alt=""
Attach Dev tag policy to Dev OU
data:image/s3,"s3://crabby-images/9e7ab/9e7ab2f98d0d81d7270fd4ffba53e3e04921f566" alt=""
data:image/s3,"s3://crabby-images/66ba8/66ba8c574f67c62dabc7099d94d698a642d0f286" alt=""
Attach Prod tag policy to Prod OU
data:image/s3,"s3://crabby-images/765f9/765f9db6bd69a24f2af8a12dceb95dd68f3a5d68" alt=""
data:image/s3,"s3://crabby-images/76430/764307e174b3d3d24774bc22e0fbb7aff1712baf" alt=""
Login to Dev AWS Account
https://796973489092.signin.aws.amazon.com/console
data:image/s3,"s3://crabby-images/5aa36/5aa367cbc7618fcbc79eb9ad5a618bc13b957470" alt=""
Sign in and select Forgot Password
data:image/s3,"s3://crabby-images/ddcde/ddcde5f52a51f9a1cdb4c723d730b927e8b74e88" alt=""
Launch T2 Large
T2-Large
data:image/s3,"s3://crabby-images/f536b/f536b424e9ae68431aaa0ad92e5ad79f0b846ea9" alt=""
data:image/s3,"s3://crabby-images/db434/db434831b0652882ff30a3b40011aa7f8bf8945b" alt=""
data:image/s3,"s3://crabby-images/38013/38013baa46ff2c34e13feb0f686a74caf6d9459d" alt=""
Proceed without key pair
data:image/s3,"s3://crabby-images/64e5b/64e5bbd06cb8142f48143953da6bdf0142f2c4fe" alt=""
No Problem
data:image/s3,"s3://crabby-images/f5d1d/f5d1dc4b0b366e5908c19149c765b1416ff57683" alt=""
Launch M5 Large Instance
M5-Large
data:image/s3,"s3://crabby-images/123cd/123cd96bdb462543bf994d6e8f2955206605c419" alt=""
data:image/s3,"s3://crabby-images/4cfab/4cfab0fce33679469af233c55bc46f0385873c9f" alt=""
data:image/s3,"s3://crabby-images/1e18b/1e18bbe9fb7b8a16b90b5c92ff3a6a899036402d" alt=""
Proceed without key pair
data:image/s3,"s3://crabby-images/3d8fd/3d8fd7f16d34cd405c61ae8911b205417564fb33" alt=""
Launch Failed because of SCP
data:image/s3,"s3://crabby-images/9bdd7/9bdd7b3bbfc65d2fb49d6c63f32d8b95efbd9f72" alt=""
Run this command only if it shows as Not Enabled
aws organizations enable-aws-service-access --service-principal tagpolicies.tag.amazonaws.com
data:image/s3,"s3://crabby-images/0570f/0570feab1c983c0e9f599e4947f9cfa6d0d0f030" alt=""
AWS Resource Groups
data:image/s3,"s3://crabby-images/8be37/8be37967283b58154fe5ff5ace25cf000930154f" alt=""
AWS Resource Groups View
data:image/s3,"s3://crabby-images/775b1/775b1b244cc02bc0d6dbcf761008e5ccb1f1b61a" alt=""
Environment tag key must match tag values
wrongtag
purpose
experiment
Environment
notinlist
data:image/s3,"s3://crabby-images/41ba0/41ba002e305631e4f4ec3a085a7f951660740745" alt=""
Environment must match Tag Values
dev
data:image/s3,"s3://crabby-images/f6dc5/f6dc515858afa2a0386f7c1b90065db17d1331f5" alt=""
Other tag Keys are fine
myownkey
myownvalue
Enforce Tag Policy at Creation
Preventive Control - SCP
{
"Sid": "RequireMandatoryTags",
"Effect": "Deny",
"Action": [
"ec2:RunInstances"
],
"Resource": "arn:aws:ec2:*:*:instance/*",
"Condition": {
"Null": {
"aws:RequestTag/Environment": "true",
"aws:RequestTag/Project": "true"
}
}
},
{
"Sid": "EnforceTagValues",
"Effect": "Deny",
"Action": [
"ec2:RunInstances"
],
"Resource": "arn:aws:ec2:*:*:instance/*",
"Condition": {
"ForAnyValue:StringNotLike": {
"aws:RequestTag/Environment": [
"dev"
],
"aws:RequestTag/Project": [
"alpha",
"beta",
"demo"
]
}
}
}
Add this to Dev SCP
data:image/s3,"s3://crabby-images/8c338/8c338873f4b34e305320ec9dc92c429d2a8f6e9d" alt=""
Launch EC2 with no Tags
data:image/s3,"s3://crabby-images/843f9/843f9a244365ae6452d85c80877f4f0519b811d0" alt=""
Launch EC2 with all required tags
Environment
dev
project
alpha
Test-Tags
data:image/s3,"s3://crabby-images/b7d9c/b7d9c0f9aebc52d73442a12796b1def95dbb30bf" alt=""
data:image/s3,"s3://crabby-images/cda8e/cda8eea0dc3b6039e478961b93ba5d42f6c5e700" alt=""
data:image/s3,"s3://crabby-images/8449d/8449d385336baeefe93dcf33b0c3f6c3e4ddfef2" alt=""
🙏
Thanks
for
Watching
AWS Organizations - Hands-On Demo
By Deepak Dubey
AWS Organizations - Hands-On Demo
AWS Organizations - Hands-On Demo
- 163