aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--terraform/.terraform.tfstate.lock.info1
-rw-r--r--terraform/ami.tf10
-rw-r--r--terraform/asg.tf52
-rw-r--r--terraform/config_map_aws_auth.yaml15
-rw-r--r--terraform/kubeconfig.tf58
-rw-r--r--terraform/terraform.tfstate.backup689
6 files changed, 821 insertions, 4 deletions
diff --git a/terraform/.terraform.tfstate.lock.info b/terraform/.terraform.tfstate.lock.info
new file mode 100644
index 0000000..de6813e
--- /dev/null
+++ b/terraform/.terraform.tfstate.lock.info
@@ -0,0 +1 @@
+{"ID":"e347799f-fa96-ed03-5663-aae5487d44e6","Operation":"OperationTypeApply","Info":"","Who":"hen3ry@Hen3ry-Desktop","Version":"0.11.11","Created":"2019-05-09T14:04:09.175346174Z","Path":"terraform.tfstate"} \ No newline at end of file
diff --git a/terraform/ami.tf b/terraform/ami.tf
new file mode 100644
index 0000000..47dc01f
--- /dev/null
+++ b/terraform/ami.tf
@@ -0,0 +1,10 @@
+data "aws_ami" "eks-worker" {
+ filter {
+ name = "name"
+ values = ["amazon-eks-node-${aws_eks_cluster.sensyne_demo_cluster.version}-v*"]
+ }
+
+ most_recent = true
+ owners = ["602401143452"] # Amazon EKS AMI Account ID
+}
+
diff --git a/terraform/asg.tf b/terraform/asg.tf
new file mode 100644
index 0000000..8c6e7a0
--- /dev/null
+++ b/terraform/asg.tf
@@ -0,0 +1,52 @@
+# This data source is included for ease of sample architecture deployment
+# and can be swapped out as necessary.
+data "aws_region" "current" {}
+
+# EKS currently documents this required userdata for EKS worker nodes to
+# properly configure Kubernetes applications on the EC2 instance.
+# We utilize a Terraform local here to simplify Base64 encoding this
+# information into the AutoScaling Launch Configuration.
+# More information: https://docs.aws.amazon.com/eks/latest/userguide/launch-workers.html
+locals {
+ demo-node-userdata = <<USERDATA
+#!/bin/bash
+set -o xtrace
+/etc/eks/bootstrap.sh --apiserver-endpoint '${aws_eks_cluster.sensyne_demo_cluster.endpoint}' --b64-cluster-ca '${aws_eks_cluster.sensyne_demo_cluster.certificate_authority.0.data}' '${var.cluster_name}'
+USERDATA
+}
+
+resource "aws_launch_configuration" "sensyne_demo_alc" {
+ associate_public_ip_address = true
+ iam_instance_profile = "${aws_iam_instance_profile.sensyne_demo_node.name}"
+ image_id = "${data.aws_ami.eks-worker.id}"
+ instance_type = "m4.large"
+ name_prefix = "sensyne_demo_alc"
+ security_groups = ["${aws_security_group.sensyne_demo_node.id}"]
+ user_data_base64 = "${base64encode(local.demo-node-userdata)}"
+
+ lifecycle {
+ create_before_destroy = true
+ }
+}
+
+resource "aws_autoscaling_group" "sensyne_demo_asg" {
+ desired_capacity = 2
+ launch_configuration = "${aws_launch_configuration.sensyne_demo_alc.id}"
+ max_size = 2
+ min_size = 1
+ name = "sensyne_demo_asg"
+ vpc_zone_identifier = ["${aws_subnet.sensyne_demo_subnet.*.id}"]
+
+ tag {
+ key = "Name"
+ value = "sensyne_demo_asg_worker"
+ propagate_at_launch = true
+ }
+
+ tag {
+ key = "kubernetes.io/cluster/${var.cluster_name}"
+ value = "owned"
+ propagate_at_launch = true
+ }
+}
+
diff --git a/terraform/config_map_aws_auth.yaml b/terraform/config_map_aws_auth.yaml
new file mode 100644
index 0000000..bab8bf9
--- /dev/null
+++ b/terraform/config_map_aws_auth.yaml
@@ -0,0 +1,15 @@
+
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: aws-auth
+ namespace: kube-system
+data:
+ mapRoles: |
+ - rolearn: arn:aws:iam::375964158157:role/sensyne_demo_node
+ username: system:node:{{EC2PrivateDNSName}}
+ groups:
+ - system:bootstrappers
+ - system:nodes
+
diff --git a/terraform/kubeconfig.tf b/terraform/kubeconfig.tf
new file mode 100644
index 0000000..7a923b6
--- /dev/null
+++ b/terraform/kubeconfig.tf
@@ -0,0 +1,58 @@
+locals {
+ kubeconfig = <<KUBECONFIG
+
+
+apiVersion: v1
+clusters:
+- cluster:
+ server: ${aws_eks_cluster.sensyne_demo_cluster.endpoint}
+ certificate-authority-data: ${aws_eks_cluster.sensyne_demo_cluster.certificate_authority.0.data}
+ name: kubernetes
+contexts:
+- context:
+ cluster: kubernetes
+ user: aws
+ name: aws
+current-context: aws
+kind: Config
+preferences: {}
+users:
+- name: aws
+ user:
+ exec:
+ apiVersion: client.authentication.k8s.io/v1alpha1
+ command: aws-iam-authenticator
+ args:
+ - "token"
+ - "-i"
+ - "${var.cluster_name}"
+KUBECONFIG
+}
+
+output "kubeconfig" {
+ value = "${local.kubeconfig}"
+}
+
+locals {
+ config_map_aws_auth = <<CONFIGMAPAWSAUTH
+
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: aws-auth
+ namespace: kube-system
+data:
+ mapRoles: |
+ - rolearn: ${aws_iam_role.sensyne_demo_node.arn}
+ username: system:node:{{EC2PrivateDNSName}}
+ groups:
+ - system:bootstrappers
+ - system:nodes
+CONFIGMAPAWSAUTH
+}
+
+output "config_map_aws_auth" {
+ value = "${local.config_map_aws_auth}"
+}
+
diff --git a/terraform/terraform.tfstate.backup b/terraform/terraform.tfstate.backup
index b756843..863eefb 100644
--- a/terraform/terraform.tfstate.backup
+++ b/terraform/terraform.tfstate.backup
@@ -1,15 +1,292 @@
{
"version": 3,
"terraform_version": "0.11.11",
- "serial": 2,
+ "serial": 7,
"lineage": "a27a1d66-bd98-5e4e-cfad-cd96f3f3dabc",
"modules": [
{
"path": [
"root"
],
- "outputs": {},
+ "outputs": {
+ "config_map_aws_auth": {
+ "sensitive": false,
+ "type": "string",
+ "value": "\n\napiVersion: v1\nkind: ConfigMap\nmetadata:\n name: aws-auth\n namespace: kube-system\ndata:\n mapRoles: |\n - rolearn: arn:aws:iam::375964158157:role/sensyne_demo_node\n username: system:node:{{EC2PrivateDNSName}}\n groups:\n - system:bootstrappers\n - system:nodes\n"
+ },
+ "kubeconfig": {
+ "sensitive": false,
+ "type": "string",
+ "value": "\n\napiVersion: v1\nclusters:\n- cluster:\n server: https://6730A6C56BEDCF6C18C9E0985D183A4B.yl4.eu-west-2.eks.amazonaws.com\n certificate-authority-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUN5RENDQWJDZ0F3SUJBZ0lCQURBTkJna3Foa2lHOXcwQkFRc0ZBREFWTVJNd0VRWURWUVFERXdwcmRXSmwKY201bGRHVnpNQjRYRFRFNU1EVXdPVEV6TWpVeE9Gb1hEVEk1TURVd05qRXpNalV4T0Zvd0ZURVRNQkVHQTFVRQpBeE1LYTNWaVpYSnVaWFJsY3pDQ0FTSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnRVBBRENDQVFvQ2dnRUJBS1pWCldwTWFLdFRkdWpqUFR4blpOOGNrbzNOQUZtdXJLTTRQaXpIdk9qL2Q2aWF5UVVJb01jZUZxSHNVLzFmWFQ5dzgKTkY5ZmFwZzk2eFd3SnlKWWMrUVFZKzVVaEl5OUJrbXg5NUZ4TTNWZlZLUDRVWGxpYkhmN1ZVbktIQ1grS0NjMApQWmVZUHVJSXNscWE0WmJ2clE4bW55T1VFTkJ2dDJ1ajQrWjZYNTBuSjVSeVZuSU84bGhwLytyV2V5L3RPaGszClBCOGtTSTRJSEQzejhSc2lwMWR1bkU4MmNQQWdsMXVZMVJlWmxQZkxKMUFra1RhWS9vRFNZTG91b3FPWWJxblUKOXluQ1JEZ2diSnUzYW1VTUp5K0NkYzlsc0I2Ryt5RXBkOUp3Y2ZyNUVrbU1VZE1CK2tuUTVhWUFma3NOM3FZRQpOU3QvTXZvRzk1aVNJQmFHOTlFQ0F3RUFBYU1qTUNFd0RnWURWUjBQQVFIL0JBUURBZ0trTUE4R0ExVWRFd0VCCi93UUZNQU1CQWY4d0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dFQkFDYlFTc213eE40ZjBMNXUvakd4aVU4SGV6QWgKQW5EQUowYzg5UlpncnlFVXhrWmw4RVJyVExUaHg4VzRpbmJPYS9TWDAyYjJsdk1IZGpCbFZSYWJtR1diQ3RGdwpFdXVwVkExL0NEbUM0c2NZbXduWmJpZGE5QmNCbDcvUXhKeEc0cTYrVGZJUmZXVEw0YTVVM0RrTzgwNXVnYXVKCkVEekE4SXc5OGNnbzJrM1BUbEdqSXVpNmxWc0ZOeVhaVGg4K3J0cjNKNVhhcVE1NlhXMVV4MXdkeUh5akJmdXUKNFllUmVjaEFMbmNzbTZjbnE5UTE0WW5KSWZFcStmaU5rTVN5cTFSaEJFVFBQNEkvdTYwMmRNV1BsNGgrNHR4agovUnNwYjl1ZTE1T082bUcxOThIK2JiOU1XYWdId0hkclc3S1A5MCtkVmpzanlUSUlEZk1iMDc3MG9sQT0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo=\n name: kubernetes\ncontexts:\n- context:\n cluster: kubernetes\n user: aws\n name: aws\ncurrent-context: aws\nkind: Config\npreferences: {}\nusers:\n- name: aws\n user:\n exec:\n apiVersion: client.authentication.k8s.io/v1alpha1\n command: aws-iam-authenticator\n args:\n - \"token\"\n - \"-i\"\n - \"sensyne_demo_cluster\"\n"
+ }
+ },
"resources": {
+ "aws_autoscaling_group.sensyne_demo_asg": {
+ "type": "aws_autoscaling_group",
+ "depends_on": [
+ "aws_launch_configuration.sensyne_demo_alc",
+ "aws_subnet.sensyne_demo_subnet.*"
+ ],
+ "primary": {
+ "id": "sensyne_demo_asg",
+ "attributes": {
+ "arn": "arn:aws:autoscaling:eu-west-2:375964158157:autoScalingGroup:c7d9a162-5785-40d2-83e0-8c65201829b4:autoScalingGroupName/sensyne_demo_asg",
+ "availability_zones.#": "3",
+ "availability_zones.1501760113": "eu-west-2b",
+ "availability_zones.3230292939": "eu-west-2a",
+ "availability_zones.780417767": "eu-west-2c",
+ "default_cooldown": "300",
+ "desired_capacity": "2",
+ "enabled_metrics.#": "0",
+ "force_delete": "false",
+ "health_check_grace_period": "300",
+ "health_check_type": "EC2",
+ "id": "sensyne_demo_asg",
+ "launch_configuration": "sensyne_demo_alc20190509133810964000000001",
+ "launch_template.#": "0",
+ "load_balancers.#": "0",
+ "max_size": "2",
+ "metrics_granularity": "1Minute",
+ "min_size": "1",
+ "mixed_instances_policy.#": "0",
+ "name": "sensyne_demo_asg",
+ "placement_group": "",
+ "protect_from_scale_in": "false",
+ "service_linked_role_arn": "arn:aws:iam::375964158157:role/aws-service-role/autoscaling.amazonaws.com/AWSServiceRoleForAutoScaling",
+ "suspended_processes.#": "0",
+ "tag.#": "2",
+ "tag.1082171745.key": "Name",
+ "tag.1082171745.propagate_at_launch": "true",
+ "tag.1082171745.value": "sensyne_demo_asg_worker",
+ "tag.352595521.key": "kubernetes.io/cluster/sensyne_demo_cluster",
+ "tag.352595521.propagate_at_launch": "true",
+ "tag.352595521.value": "owned",
+ "target_group_arns.#": "0",
+ "termination_policies.#": "0",
+ "vpc_zone_identifier.#": "3",
+ "vpc_zone_identifier.2341586835": "subnet-092000fedec469965",
+ "vpc_zone_identifier.2654009030": "subnet-04686c4f0f94f9fa9",
+ "vpc_zone_identifier.3288980443": "subnet-0b3918beebbd8cb29",
+ "wait_for_capacity_timeout": "10m"
+ },
+ "meta": {
+ "e2bfb730-ecaa-11e6-8f88-34363bc7c4c0": {
+ "delete": 600000000000
+ }
+ },
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
+ "aws_eks_cluster.sensyne_demo_cluster": {
+ "type": "aws_eks_cluster",
+ "depends_on": [
+ "aws_iam_role.sensyne_demo_cluster",
+ "aws_iam_role_policy_attachment.demo_cluster_AmazonEKSClusterPolicy",
+ "aws_iam_role_policy_attachment.demo_cluster_AmazonEKSServicePolicy",
+ "aws_security_group.sensyne_demo_cluster",
+ "aws_subnet.sensyne_demo_subnet.*"
+ ],
+ "primary": {
+ "id": "sensyne_demo_cluster",
+ "attributes": {
+ "arn": "arn:aws:eks:eu-west-2:375964158157:cluster/sensyne_demo_cluster",
+ "certificate_authority.#": "1",
+ "certificate_authority.0.data": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUN5RENDQWJDZ0F3SUJBZ0lCQURBTkJna3Foa2lHOXcwQkFRc0ZBREFWTVJNd0VRWURWUVFERXdwcmRXSmwKY201bGRHVnpNQjRYRFRFNU1EVXdPVEV6TWpVeE9Gb1hEVEk1TURVd05qRXpNalV4T0Zvd0ZURVRNQkVHQTFVRQpBeE1LYTNWaVpYSnVaWFJsY3pDQ0FTSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnRVBBRENDQVFvQ2dnRUJBS1pWCldwTWFLdFRkdWpqUFR4blpOOGNrbzNOQUZtdXJLTTRQaXpIdk9qL2Q2aWF5UVVJb01jZUZxSHNVLzFmWFQ5dzgKTkY5ZmFwZzk2eFd3SnlKWWMrUVFZKzVVaEl5OUJrbXg5NUZ4TTNWZlZLUDRVWGxpYkhmN1ZVbktIQ1grS0NjMApQWmVZUHVJSXNscWE0WmJ2clE4bW55T1VFTkJ2dDJ1ajQrWjZYNTBuSjVSeVZuSU84bGhwLytyV2V5L3RPaGszClBCOGtTSTRJSEQzejhSc2lwMWR1bkU4MmNQQWdsMXVZMVJlWmxQZkxKMUFra1RhWS9vRFNZTG91b3FPWWJxblUKOXluQ1JEZ2diSnUzYW1VTUp5K0NkYzlsc0I2Ryt5RXBkOUp3Y2ZyNUVrbU1VZE1CK2tuUTVhWUFma3NOM3FZRQpOU3QvTXZvRzk1aVNJQmFHOTlFQ0F3RUFBYU1qTUNFd0RnWURWUjBQQVFIL0JBUURBZ0trTUE4R0ExVWRFd0VCCi93UUZNQU1CQWY4d0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dFQkFDYlFTc213eE40ZjBMNXUvakd4aVU4SGV6QWgKQW5EQUowYzg5UlpncnlFVXhrWmw4RVJyVExUaHg4VzRpbmJPYS9TWDAyYjJsdk1IZGpCbFZSYWJtR1diQ3RGdwpFdXVwVkExL0NEbUM0c2NZbXduWmJpZGE5QmNCbDcvUXhKeEc0cTYrVGZJUmZXVEw0YTVVM0RrTzgwNXVnYXVKCkVEekE4SXc5OGNnbzJrM1BUbEdqSXVpNmxWc0ZOeVhaVGg4K3J0cjNKNVhhcVE1NlhXMVV4MXdkeUh5akJmdXUKNFllUmVjaEFMbmNzbTZjbnE5UTE0WW5KSWZFcStmaU5rTVN5cTFSaEJFVFBQNEkvdTYwMmRNV1BsNGgrNHR4agovUnNwYjl1ZTE1T082bUcxOThIK2JiOU1XYWdId0hkclc3S1A5MCtkVmpzanlUSUlEZk1iMDc3MG9sQT0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo=",
+ "created_at": "2019-05-09 13:18:58 +0000 UTC",
+ "enabled_cluster_log_types.#": "0",
+ "endpoint": "https://6730A6C56BEDCF6C18C9E0985D183A4B.yl4.eu-west-2.eks.amazonaws.com",
+ "id": "sensyne_demo_cluster",
+ "name": "sensyne_demo_cluster",
+ "platform_version": "eks.1",
+ "role_arn": "arn:aws:iam::375964158157:role/sensyne_demo_eks_cluster",
+ "version": "1.12",
+ "vpc_config.#": "1",
+ "vpc_config.0.endpoint_private_access": "false",
+ "vpc_config.0.endpoint_public_access": "true",
+ "vpc_config.0.security_group_ids.#": "1",
+ "vpc_config.0.security_group_ids.1476661699": "sg-00421196f71dc6480",
+ "vpc_config.0.subnet_ids.#": "3",
+ "vpc_config.0.subnet_ids.176444816": "subnet-092000fedec469965",
+ "vpc_config.0.subnet_ids.1925973038": "subnet-0b3918beebbd8cb29",
+ "vpc_config.0.subnet_ids.294670810": "subnet-04686c4f0f94f9fa9",
+ "vpc_config.0.vpc_id": "vpc-04518d2c0e2421366"
+ },
+ "meta": {
+ "e2bfb730-ecaa-11e6-8f88-34363bc7c4c0": {
+ "create": 900000000000,
+ "delete": 900000000000,
+ "update": 3600000000000
+ }
+ },
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
+ "aws_iam_instance_profile.sensyne_demo_node": {
+ "type": "aws_iam_instance_profile",
+ "depends_on": [
+ "aws_iam_role.sensyne_demo_node"
+ ],
+ "primary": {
+ "id": "sensyne_demo_profile",
+ "attributes": {
+ "arn": "arn:aws:iam::375964158157:instance-profile/sensyne_demo_profile",
+ "create_date": "2019-05-09T13:18:39Z",
+ "id": "sensyne_demo_profile",
+ "name": "sensyne_demo_profile",
+ "path": "/",
+ "role": "sensyne_demo_node",
+ "roles.#": "1",
+ "roles.2235256968": "sensyne_demo_node",
+ "unique_id": "AIPAVPCJVZDGX7GF3IRAP"
+ },
+ "meta": {},
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
+ "aws_iam_role.sensyne_demo_cluster": {
+ "type": "aws_iam_role",
+ "depends_on": [],
+ "primary": {
+ "id": "sensyne_demo_eks_cluster",
+ "attributes": {
+ "arn": "arn:aws:iam::375964158157:role/sensyne_demo_eks_cluster",
+ "assume_role_policy": "{\"Version\":\"2012-10-17\",\"Statement\":[{\"Effect\":\"Allow\",\"Principal\":{\"Service\":\"eks.amazonaws.com\"},\"Action\":\"sts:AssumeRole\"}]}",
+ "create_date": "2019-05-09T13:18:38Z",
+ "description": "",
+ "force_detach_policies": "false",
+ "id": "sensyne_demo_eks_cluster",
+ "max_session_duration": "3600",
+ "name": "sensyne_demo_eks_cluster",
+ "path": "/",
+ "tags.%": "0",
+ "unique_id": "AROAVPCJVZDGSDJKU6SSV"
+ },
+ "meta": {},
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
+ "aws_iam_role.sensyne_demo_node": {
+ "type": "aws_iam_role",
+ "depends_on": [],
+ "primary": {
+ "id": "sensyne_demo_node",
+ "attributes": {
+ "arn": "arn:aws:iam::375964158157:role/sensyne_demo_node",
+ "assume_role_policy": "{\"Version\":\"2012-10-17\",\"Statement\":[{\"Effect\":\"Allow\",\"Principal\":{\"Service\":\"ec2.amazonaws.com\"},\"Action\":\"sts:AssumeRole\"}]}",
+ "create_date": "2019-05-09T13:18:38Z",
+ "description": "",
+ "force_detach_policies": "false",
+ "id": "sensyne_demo_node",
+ "max_session_duration": "3600",
+ "name": "sensyne_demo_node",
+ "path": "/",
+ "tags.%": "0",
+ "unique_id": "AROAVPCJVZDG5C5RE7JNZ"
+ },
+ "meta": {},
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
+ "aws_iam_role_policy_attachment.demo_cluster_AmazonEKSClusterPolicy": {
+ "type": "aws_iam_role_policy_attachment",
+ "depends_on": [
+ "aws_iam_role.sensyne_demo_cluster"
+ ],
+ "primary": {
+ "id": "sensyne_demo_eks_cluster-20190509131839229900000003",
+ "attributes": {
+ "id": "sensyne_demo_eks_cluster-20190509131839229900000003",
+ "policy_arn": "arn:aws:iam::aws:policy/AmazonEKSClusterPolicy",
+ "role": "sensyne_demo_eks_cluster"
+ },
+ "meta": {},
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
+ "aws_iam_role_policy_attachment.demo_cluster_AmazonEKSServicePolicy": {
+ "type": "aws_iam_role_policy_attachment",
+ "depends_on": [
+ "aws_iam_role.sensyne_demo_cluster"
+ ],
+ "primary": {
+ "id": "sensyne_demo_eks_cluster-20190509131839239800000004",
+ "attributes": {
+ "id": "sensyne_demo_eks_cluster-20190509131839239800000004",
+ "policy_arn": "arn:aws:iam::aws:policy/AmazonEKSServicePolicy",
+ "role": "sensyne_demo_eks_cluster"
+ },
+ "meta": {},
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
+ "aws_iam_role_policy_attachment.demo_node_AmazonEC2ContainerRegistryReadOnly": {
+ "type": "aws_iam_role_policy_attachment",
+ "depends_on": [
+ "aws_iam_role.sensyne_demo_node"
+ ],
+ "primary": {
+ "id": "sensyne_demo_node-20190509131839188000000001",
+ "attributes": {
+ "id": "sensyne_demo_node-20190509131839188000000001",
+ "policy_arn": "arn:aws:iam::aws:policy/AmazonEC2ContainerRegistryReadOnly",
+ "role": "sensyne_demo_node"
+ },
+ "meta": {},
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
+ "aws_iam_role_policy_attachment.demo_node_AmazonEKSWorkerNodePolicy": {
+ "type": "aws_iam_role_policy_attachment",
+ "depends_on": [
+ "aws_iam_role.sensyne_demo_node"
+ ],
+ "primary": {
+ "id": "sensyne_demo_node-20190509131839227300000002",
+ "attributes": {
+ "id": "sensyne_demo_node-20190509131839227300000002",
+ "policy_arn": "arn:aws:iam::aws:policy/AmazonEKSWorkerNodePolicy",
+ "role": "sensyne_demo_node"
+ },
+ "meta": {},
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
+ "aws_iam_role_policy_attachment.demo_node_AmazonEKS_CNI_Policy": {
+ "type": "aws_iam_role_policy_attachment",
+ "depends_on": [
+ "aws_iam_role.sensyne_demo_node"
+ ],
+ "primary": {
+ "id": "sensyne_demo_node-20190509131839240900000005",
+ "attributes": {
+ "id": "sensyne_demo_node-20190509131839240900000005",
+ "policy_arn": "arn:aws:iam::aws:policy/AmazonEKS_CNI_Policy",
+ "role": "sensyne_demo_node"
+ },
+ "meta": {},
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
"aws_internet_gateway.sensyne_demo_aws_igw": {
"type": "aws_internet_gateway",
"depends_on": [
@@ -30,6 +307,43 @@
"deposed": [],
"provider": "provider.aws"
},
+ "aws_launch_configuration.sensyne_demo_alc": {
+ "type": "aws_launch_configuration",
+ "depends_on": [
+ "aws_iam_instance_profile.sensyne_demo_node",
+ "aws_security_group.sensyne_demo_node",
+ "data.aws_ami.eks-worker",
+ "local.demo-node-userdata"
+ ],
+ "primary": {
+ "id": "sensyne_demo_alc20190509133810964000000001",
+ "attributes": {
+ "associate_public_ip_address": "true",
+ "ebs_block_device.#": "0",
+ "ebs_optimized": "false",
+ "enable_monitoring": "true",
+ "ephemeral_block_device.#": "0",
+ "iam_instance_profile": "sensyne_demo_profile",
+ "id": "sensyne_demo_alc20190509133810964000000001",
+ "image_id": "ami-0c7388116d474ee10",
+ "instance_type": "m4.large",
+ "key_name": "",
+ "name": "sensyne_demo_alc20190509133810964000000001",
+ "name_prefix": "sensyne_demo_alc",
+ "root_block_device.#": "0",
+ "security_groups.#": "1",
+ "security_groups.1175658005": "sg-00d546af67ae50f58",
+ "spot_price": "",
+ "user_data_base64": "IyEvYmluL2Jhc2gKc2V0IC1vIHh0cmFjZQovZXRjL2Vrcy9ib290c3RyYXAuc2ggLS1hcGlzZXJ2ZXItZW5kcG9pbnQgJ2h0dHBzOi8vNjczMEE2QzU2QkVEQ0Y2QzE4QzlFMDk4NUQxODNBNEIueWw0LmV1LXdlc3QtMi5la3MuYW1hem9uYXdzLmNvbScgLS1iNjQtY2x1c3Rlci1jYSAnTFMwdExTMUNSVWRKVGlCRFJWSlVTVVpKUTBGVVJTMHRMUzB0Q2sxSlNVTjVSRU5EUVdKRFowRjNTVUpCWjBsQ1FVUkJUa0puYTNGb2EybEhPWGN3UWtGUmMwWkJSRUZXVFZKTmQwVlJXVVJXVVZGRVJYZHdjbVJYU213S1kyMDFiR1JIVm5wTlFqUllSRlJGTlUxRVZYZFBWRVY2VFdwVmVFOUdiMWhFVkVrMVRVUlZkMDVxUlhwTmFsVjRUMFp2ZDBaVVJWUk5Ra1ZIUVRGVlJRcEJlRTFMWVROV2FWcFlTblZhV0ZKc1kzcERRMEZUU1hkRVVWbEtTMjlhU1doMlkwNUJVVVZDUWxGQlJHZG5SVkJCUkVORFFWRnZRMmRuUlVKQlMxcFdDbGR3VFdGTGRGUmtkV3BxVUZSNGJscE9PR05yYnpOT1FVWnRkWEpMVFRSUWFYcElkazlxTDJRMmFXRjVVVlZKYjAxalpVWnhTSE5WTHpGbVdGUTVkemdLVGtZNVptRndaemsyZUZkM1NubEtXV01yVVZGWkt6VlZhRWw1T1VKcmJYZzVOVVo0VFROV1psWkxVRFJWV0d4cFlraG1OMVpWYmt0SVExZ3JTME5qTUFwUVdtVlpVSFZKU1hOc2NXRTBXbUoyY2xFNGJXNTVUMVZGVGtKMmRESjFhalFyV2paWU5UQnVTalZTZVZadVNVODRiR2h3THl0eVYyVjVMM1JQYUdzekNsQkNPR3RUU1RSSlNFUXplamhTYzJsd01XUjFia1U0TW1OUVFXZHNNWFZaTVZKbFdteFFaa3hLTVVGcmExUmhXUzl2UkZOWlRHOTFiM0ZQV1dKeGJsVUtPWGx1UTFKRVoyZGlTblV6WVcxVlRVcDVLME5rWXpsc2MwSTJSeXQ1UlhCa09VcDNZMlp5TlVWcmJVMVZaRTFDSzJ0dVVUVmhXVUZtYTNOT00zRlpSUXBPVTNRdlRYWnZSemsxYVZOSlFtRkhPVGxGUTBGM1JVRkJZVTFxVFVORmQwUm5XVVJXVWpCUVFWRklMMEpCVVVSQlowdHJUVUU0UjBFeFZXUkZkMFZDQ2k5M1VVWk5RVTFDUVdZNGQwUlJXVXBMYjFwSmFIWmpUa0ZSUlV4Q1VVRkVaMmRGUWtGRFlsRlRjMjEzZUU0MFpqQk1OWFV2YWtkNGFWVTRTR1Y2UVdnS1FXNUVRVW93WXpnNVVscG5jbmxGVlhocldtdzRSVkp5VkV4VWFIZzRWelJwYm1KUFlTOVRXREF5WWpKc2RrMUlaR3BDYkZaU1lXSnRSMWRpUTNSR2R3cEZkWFZ3VmtFeEwwTkViVU0wYzJOWmJYZHVXbUpwWkdFNVFtTkNiRGN2VVhoS2VFYzBjVFlyVkdaSlVtWlhWRXcwWVRWVk0wUnJUemd3TlhWbllYVktDa1ZFZWtFNFNYYzVPR05uYnpKck0xQlViRWRxU1hWcE5teFdjMFpPZVZoYVZHZzRLM0owY2pOS05WaGhjVkUxTmxoWE1WVjRNWGRrZVVoNWFrSm1kWFVLTkZsbFVtVmphRUZNYm1OemJUWmpibkU1VVRFMFdXNUtTV1pGY1N0bWFVNXJUVk41Y1RGU2FFSkZWRkJRTkVrdmRUWXdNbVJOVjFCc05HZ3JOSFI0YWdvdlVuTndZamwxWlRFMVQwODJiVWN4T1RoSUsySmlPVTFYWVdkSWQwaGtjbGMzUzFBNU1DdGtWbXB6YW5sVVNVbEVaazFpTURjM01HOXNRVDBLTFMwdExTMUZUa1FnUTBWU1ZFbEdTVU5CVkVVdExTMHRMUW89JyAnc2Vuc3luZV9kZW1vX2NsdXN0ZXInCg==",
+ "vpc_classic_link_id": "",
+ "vpc_classic_link_security_groups.#": "0"
+ },
+ "meta": {},
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
"aws_route_table.sensyne_demo_route_table": {
"type": "aws_route_table",
"depends_on": [
@@ -99,6 +413,266 @@
"deposed": [],
"provider": "provider.aws"
},
+ "aws_route_table_association.sensyne_demo_route_table_ass.2": {
+ "type": "aws_route_table_association",
+ "depends_on": [
+ "aws_route_table.sensyne_demo_route_table",
+ "aws_subnet.sensyne_demo_subnet.*"
+ ],
+ "primary": {
+ "id": "rtbassoc-0ebacb44e7b5ef454",
+ "attributes": {
+ "id": "rtbassoc-0ebacb44e7b5ef454",
+ "route_table_id": "rtb-0c828921b2d4d85c0",
+ "subnet_id": "subnet-0b3918beebbd8cb29"
+ },
+ "meta": {},
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
+ "aws_security_group.sensyne_demo_cluster": {
+ "type": "aws_security_group",
+ "depends_on": [
+ "aws_vpc.sensyne_demo_vpc"
+ ],
+ "primary": {
+ "id": "sg-00421196f71dc6480",
+ "attributes": {
+ "arn": "arn:aws:ec2:eu-west-2:375964158157:security-group/sg-00421196f71dc6480",
+ "description": "Cluster communication with worker nodes",
+ "egress.#": "1",
+ "egress.482069346.cidr_blocks.#": "1",
+ "egress.482069346.cidr_blocks.0": "0.0.0.0/0",
+ "egress.482069346.description": "",
+ "egress.482069346.from_port": "0",
+ "egress.482069346.ipv6_cidr_blocks.#": "0",
+ "egress.482069346.prefix_list_ids.#": "0",
+ "egress.482069346.protocol": "-1",
+ "egress.482069346.security_groups.#": "0",
+ "egress.482069346.self": "false",
+ "egress.482069346.to_port": "0",
+ "id": "sg-00421196f71dc6480",
+ "ingress.#": "2",
+ "ingress.3021715561.cidr_blocks.#": "0",
+ "ingress.3021715561.description": "Allow pods to communicate with the cluster API Server",
+ "ingress.3021715561.from_port": "443",
+ "ingress.3021715561.ipv6_cidr_blocks.#": "0",
+ "ingress.3021715561.prefix_list_ids.#": "0",
+ "ingress.3021715561.protocol": "tcp",
+ "ingress.3021715561.security_groups.#": "1",
+ "ingress.3021715561.security_groups.1175658005": "sg-00d546af67ae50f58",
+ "ingress.3021715561.self": "false",
+ "ingress.3021715561.to_port": "443",
+ "ingress.3278662766.cidr_blocks.#": "1",
+ "ingress.3278662766.cidr_blocks.0": "81.187.12.210/32",
+ "ingress.3278662766.description": "Allow external comms with cluster",
+ "ingress.3278662766.from_port": "443",
+ "ingress.3278662766.ipv6_cidr_blocks.#": "0",
+ "ingress.3278662766.prefix_list_ids.#": "0",
+ "ingress.3278662766.protocol": "tcp",
+ "ingress.3278662766.security_groups.#": "0",
+ "ingress.3278662766.self": "false",
+ "ingress.3278662766.to_port": "443",
+ "name": "sensyne-demo-cluster-sg",
+ "owner_id": "375964158157",
+ "revoke_rules_on_delete": "false",
+ "tags.%": "1",
+ "tags.Name": "sensyne_demo_cluster_sg",
+ "vpc_id": "vpc-04518d2c0e2421366"
+ },
+ "meta": {
+ "e2bfb730-ecaa-11e6-8f88-34363bc7c4c0": {
+ "create": 600000000000,
+ "delete": 600000000000
+ },
+ "schema_version": "1"
+ },
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
+ "aws_security_group.sensyne_demo_node": {
+ "type": "aws_security_group",
+ "depends_on": [
+ "aws_vpc.sensyne_demo_vpc"
+ ],
+ "primary": {
+ "id": "sg-00d546af67ae50f58",
+ "attributes": {
+ "arn": "arn:aws:ec2:eu-west-2:375964158157:security-group/sg-00d546af67ae50f58",
+ "description": "Security group for all nodes in the cluster",
+ "egress.#": "1",
+ "egress.482069346.cidr_blocks.#": "1",
+ "egress.482069346.cidr_blocks.0": "0.0.0.0/0",
+ "egress.482069346.description": "",
+ "egress.482069346.from_port": "0",
+ "egress.482069346.ipv6_cidr_blocks.#": "0",
+ "egress.482069346.prefix_list_ids.#": "0",
+ "egress.482069346.protocol": "-1",
+ "egress.482069346.security_groups.#": "0",
+ "egress.482069346.self": "false",
+ "egress.482069346.to_port": "0",
+ "id": "sg-00d546af67ae50f58",
+ "ingress.#": "2",
+ "ingress.2278689831.cidr_blocks.#": "0",
+ "ingress.2278689831.description": "Allow node to communicate with each other",
+ "ingress.2278689831.from_port": "0",
+ "ingress.2278689831.ipv6_cidr_blocks.#": "0",
+ "ingress.2278689831.prefix_list_ids.#": "0",
+ "ingress.2278689831.protocol": "-1",
+ "ingress.2278689831.security_groups.#": "0",
+ "ingress.2278689831.self": "true",
+ "ingress.2278689831.to_port": "0",
+ "ingress.3172124372.cidr_blocks.#": "0",
+ "ingress.3172124372.description": "Allow worker Kubelets and pods to receive communication from the cluster control plane",
+ "ingress.3172124372.from_port": "1025",
+ "ingress.3172124372.ipv6_cidr_blocks.#": "0",
+ "ingress.3172124372.prefix_list_ids.#": "0",
+ "ingress.3172124372.protocol": "tcp",
+ "ingress.3172124372.security_groups.#": "1",
+ "ingress.3172124372.security_groups.1664590368": "sg-00421196f71dc6480",
+ "ingress.3172124372.self": "false",
+ "ingress.3172124372.to_port": "65535",
+ "name": "sensyne_demo_node",
+ "owner_id": "375964158157",
+ "revoke_rules_on_delete": "false",
+ "tags.%": "1",
+ "tags.Name": "sensyne-demo-worker-node",
+ "vpc_id": "vpc-04518d2c0e2421366"
+ },
+ "meta": {
+ "e2bfb730-ecaa-11e6-8f88-34363bc7c4c0": {
+ "create": 600000000000,
+ "delete": 600000000000
+ },
+ "schema_version": "1"
+ },
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
+ "aws_security_group_rule.sensyne_demo_cluster_ingress_node_https": {
+ "type": "aws_security_group_rule",
+ "depends_on": [
+ "aws_security_group.sensyne_demo_cluster",
+ "aws_security_group.sensyne_demo_node"
+ ],
+ "primary": {
+ "id": "sgrule-2494997055",
+ "attributes": {
+ "cidr_blocks.#": "0",
+ "description": "Allow pods to communicate with the cluster API Server",
+ "from_port": "443",
+ "id": "sgrule-2494997055",
+ "ipv6_cidr_blocks.#": "0",
+ "prefix_list_ids.#": "0",
+ "protocol": "tcp",
+ "security_group_id": "sg-00421196f71dc6480",
+ "self": "false",
+ "source_security_group_id": "sg-00d546af67ae50f58",
+ "to_port": "443",
+ "type": "ingress"
+ },
+ "meta": {
+ "schema_version": "2"
+ },
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
+ "aws_security_group_rule.sensyne_demo_cluster_remote_access": {
+ "type": "aws_security_group_rule",
+ "depends_on": [
+ "aws_security_group.sensyne_demo_cluster"
+ ],
+ "primary": {
+ "id": "sgrule-3914968742",
+ "attributes": {
+ "cidr_blocks.#": "1",
+ "cidr_blocks.0": "81.187.12.210/32",
+ "description": "Allow external comms with cluster",
+ "from_port": "443",
+ "id": "sgrule-3914968742",
+ "ipv6_cidr_blocks.#": "0",
+ "prefix_list_ids.#": "0",
+ "protocol": "tcp",
+ "security_group_id": "sg-00421196f71dc6480",
+ "self": "false",
+ "to_port": "443",
+ "type": "ingress"
+ },
+ "meta": {
+ "schema_version": "2"
+ },
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
+ "aws_security_group_rule.sensyne_demo_node_ingress_cluster": {
+ "type": "aws_security_group_rule",
+ "depends_on": [
+ "aws_security_group.sensyne_demo_cluster",
+ "aws_security_group.sensyne_demo_node"
+ ],
+ "primary": {
+ "id": "sgrule-256439334",
+ "attributes": {
+ "cidr_blocks.#": "0",
+ "description": "Allow worker Kubelets and pods to receive communication from the cluster control plane",
+ "from_port": "1025",
+ "id": "sgrule-256439334",
+ "ipv6_cidr_blocks.#": "0",
+ "prefix_list_ids.#": "0",
+ "protocol": "tcp",
+ "security_group_id": "sg-00d546af67ae50f58",
+ "self": "false",
+ "source_security_group_id": "sg-00421196f71dc6480",
+ "to_port": "65535",
+ "type": "ingress"
+ },
+ "meta": {
+ "schema_version": "2"
+ },
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
+ "aws_security_group_rule.sensyne_demo_node_ingress_self": {
+ "type": "aws_security_group_rule",
+ "depends_on": [
+ "aws_security_group.sensyne_demo_node"
+ ],
+ "primary": {
+ "id": "sgrule-868716314",
+ "attributes": {
+ "cidr_blocks.#": "0",
+ "description": "Allow node to communicate with each other",
+ "from_port": "0",
+ "id": "sgrule-868716314",
+ "ipv6_cidr_blocks.#": "0",
+ "prefix_list_ids.#": "0",
+ "protocol": "-1",
+ "security_group_id": "sg-00d546af67ae50f58",
+ "self": "false",
+ "source_security_group_id": "sg-00d546af67ae50f58",
+ "to_port": "0",
+ "type": "ingress"
+ },
+ "meta": {
+ "schema_version": "2"
+ },
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
"aws_subnet.sensyne_demo_subnet.0": {
"type": "aws_subnet",
"depends_on": [
@@ -169,6 +743,41 @@
"deposed": [],
"provider": "provider.aws"
},
+ "aws_subnet.sensyne_demo_subnet.2": {
+ "type": "aws_subnet",
+ "depends_on": [
+ "aws_vpc.sensyne_demo_vpc",
+ "data.aws_availability_zones.available"
+ ],
+ "primary": {
+ "id": "subnet-0b3918beebbd8cb29",
+ "attributes": {
+ "arn": "arn:aws:ec2:eu-west-2:375964158157:subnet/subnet-0b3918beebbd8cb29",
+ "assign_ipv6_address_on_creation": "false",
+ "availability_zone": "eu-west-2c",
+ "availability_zone_id": "euw2-az1",
+ "cidr_block": "10.0.2.0/24",
+ "id": "subnet-0b3918beebbd8cb29",
+ "ipv6_cidr_block": "",
+ "ipv6_cidr_block_association_id": "",
+ "map_public_ip_on_launch": "false",
+ "owner_id": "375964158157",
+ "tags.%": "1",
+ "tags.Name": "sensyne_demo_subnet",
+ "vpc_id": "vpc-04518d2c0e2421366"
+ },
+ "meta": {
+ "e2bfb730-ecaa-11e6-8f88-34363bc7c4c0": {
+ "create": 600000000000,
+ "delete": 600000000000
+ },
+ "schema_version": "1"
+ },
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
"aws_vpc.sensyne_demo_vpc": {
"type": "aws_vpc",
"depends_on": [],
@@ -201,13 +810,68 @@
"deposed": [],
"provider": "provider.aws"
},
+ "data.aws_ami.eks-worker": {
+ "type": "aws_ami",
+ "depends_on": [
+ "aws_eks_cluster.sensyne_demo_cluster"
+ ],
+ "primary": {
+ "id": "ami-0c7388116d474ee10",
+ "attributes": {
+ "architecture": "x86_64",
+ "block_device_mappings.#": "1",
+ "block_device_mappings.3798922657.device_name": "/dev/xvda",
+ "block_device_mappings.3798922657.ebs.%": "6",
+ "block_device_mappings.3798922657.ebs.delete_on_termination": "true",
+ "block_device_mappings.3798922657.ebs.encrypted": "false",
+ "block_device_mappings.3798922657.ebs.iops": "0",
+ "block_device_mappings.3798922657.ebs.snapshot_id": "snap-0cace1e28d114ad5b",
+ "block_device_mappings.3798922657.ebs.volume_size": "20",
+ "block_device_mappings.3798922657.ebs.volume_type": "gp2",
+ "block_device_mappings.3798922657.no_device": "",
+ "block_device_mappings.3798922657.virtual_name": "",
+ "creation_date": "2019-03-30T00:33:04.000Z",
+ "description": "EKS Kubernetes Worker AMI with AmazonLinux2 image (k8s: 1.12.7/2019-03-27/bin/linux/amd64, docker:18.06)",
+ "filter.#": "1",
+ "filter.3458727952.name": "name",
+ "filter.3458727952.values.#": "1",
+ "filter.3458727952.values.0": "amazon-eks-node-1.12-v*",
+ "hypervisor": "xen",
+ "id": "ami-0c7388116d474ee10",
+ "image_id": "ami-0c7388116d474ee10",
+ "image_location": "602401143452/amazon-eks-node-1.12-v20190329",
+ "image_type": "machine",
+ "most_recent": "true",
+ "name": "amazon-eks-node-1.12-v20190329",
+ "owner_id": "602401143452",
+ "owners.#": "1",
+ "owners.0": "602401143452",
+ "product_codes.#": "0",
+ "public": "true",
+ "root_device_name": "/dev/xvda",
+ "root_device_type": "ebs",
+ "root_snapshot_id": "snap-0cace1e28d114ad5b",
+ "sriov_net_support": "simple",
+ "state": "available",
+ "state_reason.%": "2",
+ "state_reason.code": "UNSET",
+ "state_reason.message": "UNSET",
+ "tags.%": "0",
+ "virtualization_type": "hvm"
+ },
+ "meta": {},
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
+ },
"data.aws_availability_zones.available": {
"type": "aws_availability_zones",
"depends_on": [],
"primary": {
- "id": "2019-05-09 09:43:34.620858829 +0000 UTC",
+ "id": "2019-05-09 13:48:30.300835061 +0000 UTC",
"attributes": {
- "id": "2019-05-09 09:43:34.620858829 +0000 UTC",
+ "id": "2019-05-09 13:48:30.300835061 +0000 UTC",
"names.#": "3",
"names.0": "eu-west-2a",
"names.1": "eu-west-2b",
@@ -222,6 +886,23 @@
},
"deposed": [],
"provider": "provider.aws"
+ },
+ "data.aws_region.current": {
+ "type": "aws_region",
+ "depends_on": [],
+ "primary": {
+ "id": "eu-west-2",
+ "attributes": {
+ "description": "EU (London)",
+ "endpoint": "ec2.eu-west-2.amazonaws.com",
+ "id": "eu-west-2",
+ "name": "eu-west-2"
+ },
+ "meta": {},
+ "tainted": false
+ },
+ "deposed": [],
+ "provider": "provider.aws"
}
},
"depends_on": []