#aws (2020-01)
Discussion related to Amazon Web Services (AWS)
Discussion related to Amazon Web Services (AWS)
Archive: https://archive.sweetops.com/aws/
2020-01-02
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
Does anyone know how to make an internal ALB with private hosted zone use DNS cert validation ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
also, for clarification, you want a public certificate for a private zone?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(because I think private certificates address this - https://docs.aws.amazon.com/acm/latest/userguide/gs-acm-request-private.html)
Request an ACM PCA private certificate.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
cheaper to buy a domain with route53 and use public certs with a public zone than ACM Private CA
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Definitely cheaper
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
we are using route53 private hosted zone, create a cname and attach internal alb endpoint to it
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
can do the same with a public zone instead. very easy. to answer the question, i think DNS cert validation will require a public zone, since the service needs to be able to perform a DNS lookup to validate the records ¯_(ツ)_/¯
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
that’s what i thought, was checking if it was possible to do public DNS with my current setup
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
the service does not have network access to your private zone to perform the DNS validation, i don’t think. not sure how that would work, would be some black magic involved…
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
does the public DNS need to resolve to something ?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
ACM will provide you with the DNS records that you need to enter. you are proving that you own the zone associated with the ACM cert request. so the zone (or zones, can be plural) needs to match all the cert names you provide to ACM
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
if you can’t get there, then the ACM PCA feature that @Erik Osterman (Cloud Posse) linked ought to work. it’s just expensive to run an ACM PCA ($400/month for the PCA, plus a charge per issued cert)
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
@loren thanks. I will check it out
data:image/s3,"s3://crabby-images/0a2bf/0a2bf0d25c639983c8f57b1607f0889dcba41eb1" alt="Eamon Keane avatar"
When using nginx-ingress
(installed via helmfile provider), is there a good way to get the load balancer CNAME
into terraform for use with populating dns (e.g. [a92da7dd42d9c11ea9d19028a775bee0-865849920.us-east-2.elb.amazonaws.com](http://a92da7dd42d9c11ea9d19028a775bee0-865849920.us-east-2.elb.amazonaws.com)
)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Do not use terraform for that. Instead use the external-dns controller.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This is where the power of Kubernetes controllers really shines
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
E.g. use the cert-manager controller to automatically generate certificates
data:image/s3,"s3://crabby-images/0a2bf/0a2bf0d25c639983c8f57b1607f0889dcba41eb1" alt="Eamon Keane avatar"
oh yea good point, I was getting confused (I do use external-dns and cert-manager). What I actually was driving at was gcp lets you assign a static ip to a load-balancer which can be passed in as a variable to helmfile
and remain constant if for some reason the cluster had to be recreated (useful if passing this ip to a third party domain you don’t control). On AWS, I don’t think there’s an ability to control the CNAME
so it will change between cluster creations, is that right?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
On AWS to get a static IP and attach it to load balancer, you can use https://aws.amazon.com/global-accelerator/
data:image/s3,"s3://crabby-images/0a2bf/0a2bf0d25c639983c8f57b1607f0889dcba41eb1" alt="Eamon Keane avatar"
thanks @Andriy Knysh (Cloud Posse) I’ll give that a shot.
data:image/s3,"s3://crabby-images/0a2bf/0a2bf0d25c639983c8f57b1607f0889dcba41eb1" alt="Eamon Keane avatar"
hmm, so global accelerator gives multiple static ip addresses, but looks like nginx-ingress is only set up for one load-balancer ip address…. though I guess just choosing one might work with some loss of HA.
https://github.com/helm/charts/blob/master/stable/nginx-ingress/values.yaml#L243
Curated applications for Kubernetes. Contribute to helm/charts development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
Does anyone here use RDS IAM authentication feature ?
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
I am trying to figure out if we would still have to generate token and use it in place of password when RDS IAM authentication is enabled
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
If my app is running on ec2, can i just attach iam policy and can get rid of using password as a whole ?
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
The documentation also says that the “The authentication token has a limited lifetime of 15 mins”, does that mean once the token is generated we have to use it with in 15 mins to make a connection
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes you app will have to use the mariadb driver to deal with the token expiry
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so it will need to request a token every 15 min
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
once a connection is made to the database, why does the app have to make connection every 15 mins using a new token ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
because the token expires
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
is like the password was changed
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
the doc detail how to do it with some code examples
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and once you are using mariadb driver you can just delete all the other user not using the driver
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
is a specific mysql driver that get installed in the mysql aurora server
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and you create the user in a specific way
2020-01-03
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
I have an ACM question, are the following certs the same? (I’m trying to understand what ‘additional names’ are for) cert a:
domain name: test.domain.com
additional name: *.test.domain.com
cert b:
domain name: *.test.domain.com
additional name: -
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
cert b will not cover [test.domain.com](http://test.domain.com)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
just all subdomains
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
so for example, cert b will not cover test.domain.com but aaa.test.domain.com ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Yes
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
so its more ideal to go with cert a?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
essentially cert a will cover [test.domain.com](http://test.domain.com)
and all subdomains?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yes, create it exactly as cert a
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
since you use star for subdomains (all of them) and if you use DNS validation, ACM will generate two exactly similar records to put into DNS zone
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and since the records are the same, you can add just one of them and all will work
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but, if you request a cert for test.domain.com and just for www.test.domain.com, then ACM will generate two different records, and you will need to put both of them into DNS
2020-01-07
data:image/s3,"s3://crabby-images/0a2bf/0a2bf0d25c639983c8f57b1607f0889dcba41eb1" alt="Eamon Keane avatar"
has anyone used Iam Roles for Service-Accounts with EKS and a cluster of just Managed Node Groups with the cluster-autoscaler (v1.14.7)?
The role has the required permissions and it is getting injected into autoscaler pod.
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
Aren’t the details (role Arn) added as annotations to the service account (metadata)? Away from computer (on leave)..
data:image/s3,"s3://crabby-images/0a2bf/0a2bf0d25c639983c8f57b1607f0889dcba41eb1" alt="Eamon Keane avatar"
yes, I added it there. That gets picked up and then AWS have a mutating admission controller which injects the role and tokenfile to the pod.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we tested IAM roles for service accounts for EKS using managed Node Group https://github.com/cloudposse/terraform-aws-eks-node-group. Worked great. Maybe this will help:
Terraform module to provision an EKS Node Group. Contribute to cloudposse/terraform-aws-eks-node-group development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Here is the Role for external-dns
:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
locals {
eks_cluster_identity_oidc_issuer = replace(data.aws_ssm_parameter.eks_cluster_identity_oidc_issuer_url.value, "https://", "")
}
module "label" {
source = "git::<https://github.com/cloudposse/terraform-null-label.git?ref=tags/0.16.0>"
namespace = var.namespace
name = var.name
stage = var.stage
delimiter = var.delimiter
attributes = compact(concat(var.attributes, list("external-dns")))
tags = var.tags
}
resource "aws_iam_role" "default" {
name = module.label.id
description = "Role that can be assumed by external-dns"
assume_role_policy = data.aws_iam_policy_document.assume_role.json
lifecycle {
create_before_destroy = true
}
}
data "aws_iam_policy_document" "assume_role" {
statement {
actions = [
"sts:AssumeRoleWithWebIdentity"
]
effect = "Allow"
principals {
type = "Federated"
identifiers = [format("arn:aws:iam::%s:oidc-provider/%s", var.aws_account_id, local.eks_cluster_identity_oidc_issuer)]
}
condition {
test = "StringEquals"
values = [format("system:serviceaccount:%s:%s", var.kubernetes_service_account_namespace, var.kubernetes_service_account_name)]
variable = format("%s:sub", local.eks_cluster_identity_oidc_issuer)
}
}
}
resource "aws_iam_role_policy_attachment" "default" {
role = aws_iam_role.default.name
policy_arn = aws_iam_policy.default.arn
lifecycle {
create_before_destroy = true
}
}
resource "aws_iam_policy" "default" {
name = module.label.id
description = "Grant permissions for external-dns"
policy = data.aws_iam_policy_document.default.json
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and here is how external-dns
service account was annotated with that Role: https://github.com/cloudposse/helmfiles/pull/207/files#diff-40daec15ea9ebdc2aed4f62abba406c3R63
what Add helmfile for EKS external-dns Activate RBAC Use Service Account for external-dns why Provision external-dns for EKS cluster (which is different from external-dns for kops) Use IAM Role …
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
after all of that was deployed and EKS started a few instances from Node Group, external-dns
was able to assume the role and add records to Route53 for other services
data:image/s3,"s3://crabby-images/0a2bf/0a2bf0d25c639983c8f57b1607f0889dcba41eb1" alt="Eamon Keane avatar"
thanks, I’ll give that a try to see what I have different
data:image/s3,"s3://crabby-images/0a2bf/0a2bf0d25c639983c8f57b1607f0889dcba41eb1" alt="Eamon Keane avatar"
ugh.. needed to include fullnameOverride: "cluster-autoscaler"
in helmfile - it autogenerates a different sa name, works now.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/8077a/8077ac89d84c7090180a2675996314ce2aaf8f24" alt="attachment image"
You may have already received an email or seen a console notification, but I don’t want you to be taken by surprise! Rotate Now If you are using Amazon Aurora, Amazon Relational Database Service (RDS), or Amazon DocumentDB and are taking advantage of SSL/TLS certificate validation when you connect to your database instances, you need […]
2020-01-08
data:image/s3,"s3://crabby-images/3507f/3507ffec4fde840500f2ea75b9cb5debf0932191" alt="Nick V avatar"
Anyone know how I can skip text when using parse
on Cloudwatch Insights? I have parse message '* src="*" dst="*" msg="*" note="*" user="*" devID="*" cat="*"*' as _, src, dst, msg, note, user, devID, cat, other
but I’d like to discard everything before src=
data:image/s3,"s3://crabby-images/3507f/3507ffec4fde840500f2ea75b9cb5debf0932191" alt="Nick V avatar"
apparently there’s | display field1, field2
that filters out what fields insights diplays
data:image/s3,"s3://crabby-images/3507f/3507ffec4fde840500f2ea75b9cb5debf0932191" alt="Nick V avatar"
(and it works on ephemeral fields created by parse
)
2020-01-09
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
I don’t see the Opt-In option for new ARN format in ECS
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Has anyone come across that before?
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
I am getting “The new ARN and resource ID format must be enabled to add tags to the service. Opt in to the new format and try again.” from TF, but not sure how to resolve
data:image/s3,"s3://crabby-images/ce289/ce289e18479f1b5efe01da5d8f068e27d4a84a9f" alt="Joe Hosteny avatar"
Just hit this same thing this morning. Solved with: aws ecs put-account-setting-default --name serviceLongArnFormat --value enabled
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Thanks
data:image/s3,"s3://crabby-images/ad5d8/ad5d87ce6f97ff74c79a584a011d9ff3354470d0" alt="Bernhard Lenz avatar"
I’m getting below error. Is this the right forum to ask for help?
terraform init
Initializing modules...
Downloading cloudposse/ecs-container-definition/aws 0.21.0 for ecs-container-definition...
Error: Failed to download module
Could not download module "ecs-container-definition" (ecs.tf:106) source code
from
"<https://api.github.com/repos/cloudposse/terraform-aws-ecs-container-definition/tarball/0.21.0//*?archive=tar.gz>":
Error opening a gzip reader for
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we have no control over those tarball URLs
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that’s the correct one provided by github
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
perhaps share your terraform code?
data:image/s3,"s3://crabby-images/16bc3/16bc395c4353d07f00573cdb8d968eb3b6dd811a" alt="chrism avatar"
Just started to get the same oddly
source = "terraform-aws-modules/autoscaling/aws"
version = "~> 3.0"
odd
data:image/s3,"s3://crabby-images/16bc3/16bc395c4353d07f00573cdb8d968eb3b6dd811a" alt="chrism avatar"
in my case updating terraform from .16 to .19 seemed to correct it so maybe a blip or maybe something broke. Hard to tell
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
On a serious note, I wonder how GitHub feels about all the terraformers downloading tarballs of modules. Can you imagine the thousands and thousands of tarballs being requested per second!
data:image/s3,"s3://crabby-images/16bc3/16bc395c4353d07f00573cdb8d968eb3b6dd811a" alt="chrism avatar"
Microsoft can afford the bandwidth
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Bernhard Lenz better to use #terraform
data:image/s3,"s3://crabby-images/ad5d8/ad5d87ce6f97ff74c79a584a011d9ff3354470d0" alt="Bernhard Lenz avatar"
Tx
2020-01-10
data:image/s3,"s3://crabby-images/3507f/3507ffec4fde840500f2ea75b9cb5debf0932191" alt="Nick V avatar"
Anyone have experience with how much overhead RDS postgres multi-az adds? I was doing some testing on tiny instances and the added replication seemed to add a decent amount (20-30% CPU) but that was a tiny t3.small instance
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
don’t use tiny instances.
data:image/s3,"s3://crabby-images/3507f/3507ffec4fde840500f2ea75b9cb5debf0932191" alt="Nick V avatar"
We don’t, but I haven’t tried every instance type to see if that impact was only because it was so small or whether replication actually adds a decent bit of overhead
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Smaller instance types of anything aren’t going to give you an accurate impact assessment. How about you try using the instance types you are currently using in production.
data:image/s3,"s3://crabby-images/3507f/3507ffec4fde840500f2ea75b9cb5debf0932191" alt="Nick V avatar"
The point of the question was to see if someone’s already done this
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I don’t have an answer, but it seems a common complaint, explained in more detail: https://stackoverflow.com/questions/47162231/rds-multi-az-bottlenecking-write-performance/50441734#50441734
We are using an RDS MySQL 5.6 instance (db.m3.2xlarge) on sa-east-1 region and during write intensive operations we are seeing (on CloudWatch) that both our Write Throughput and the Network Transmit
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I suppose the amount of overhead would depend on many many factors: amount of data written, size of data written, randomness, io characteristics of the instance. The t3 class will probably be worst to use as a reference instance since they are burstable.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
multi-AZ will always have (some) performance impact since Aurora does replication synchronously
data:image/s3,"s3://crabby-images/67e68/67e683361c271c4e26e156c64a1a2d27db2b053d" alt="David avatar"
Say I upload to files to an S3 bucket for a website multiple times per day: index.html
and some_file.some_cache_busting_string.js
, and that the new version of index.html
that is uploaded will always reference the most recent js
file.
index.html
is a much smaller file than the js
file, so when I upload these files the html file will typically complete its upload first.
If someone visits my site during the time after the HTML is uploaded, but before the js finishes uploading, the page will fail to load.
I’m guessing I’m not the first person to experience this, so how do you all handle this?
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
Do you have versioning enabled ?
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
AFAIK, it would serve old version of js file if replacing js file is not completed
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
sounds like a good puzzle to solve :slightly_smiling_face: could be done by uploading files to S3 sequentially or using this in index.html (in onerror
, try to load the old file) https://javascript.info/onload-onerror
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
Hey team, am running a Hugo static site with the cloudposse CDN module with great results. Site is converted from a lamp stack minus the deprecated CMS. Looking to replace the phpmailer email form and came across this module. https://github.com/cloudposse/terraform-aws-ses-lambda-forwarder Wonder if I could stitch this and AWS API Gateway together to handle the form POST per a few blogs? Preferably in terraform but haven’t used these services before. Will need to find a way to avoid spam usage.
This is a terraform module that creates an email forwarder using a combination of AWS SES and Lambda running the aws-lambda-ses-forwarder NPM module. - cloudposse/terraform-aws-ses-lambda-forwarder
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I would recommend a js embed to replace the forms
This is a terraform module that creates an email forwarder using a combination of AWS SES and Lambda running the aws-lambda-ses-forwarder NPM module. - cloudposse/terraform-aws-ses-lambda-forwarder
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We use HubSpot
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
And outgrow
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
Thanks Erik, been looking at formtree but looks like plenty about. Indeed seems a lot simpler.
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
2020-01-11
2020-01-12
data:image/s3,"s3://crabby-images/0acb4/0acb44db988a214b8e198fe6942a734ac2a097ee" alt="s2504s avatar"
Hi guys! I faced issue with ALB’ hard limit that is 1000 Targets per ALB. I tried to get targets that are belong to ALB using aws cli, but I did not found such option there. Did someone face this issue or make work around for it?
2020-01-13
data:image/s3,"s3://crabby-images/d593f/d593fb633541525ba68d89fab148a8ee508f62c0" alt="Maxim Tishchenko avatar"
Hi guys, I have a question about EKS: You pay 0,20 USD per hour for each Amazon EKS cluster that you create (from https://aws.amazon.com/eks/pricing/) Is it apply for any type of eks confirmation (ec2, fargate ) ? Do you know why is it so expensive ? it is almost 144$/month. is it price for k8s service containers ?
data:image/s3,"s3://crabby-images/6a5fa/6a5fa2c54dc53015cb3683b145a51ad9ee88466f" alt="TBeijen avatar"
That’s the price for ‘just’ the control plane. Not cheap. Otoh, setting up a HA control plane on EC2 will likely set you back for something similar or higher.
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
factor in the number hours that you’ll spend setting it up and keeping it running it’s inexpensive IMO
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
Maybe try EKS on Fargate, looks like you’re only charged for EKS as long as your pod is running
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
But yeah, that actually seems cheap to me too
data:image/s3,"s3://crabby-images/d593f/d593fb633541525ba68d89fab148a8ee508f62c0" alt="Maxim Tishchenko avatar"
does this (HA control plane on EC2) mean that I have to remove eks and deploy my own k8s into EC2s?
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
that being said, I don’t use EKS…my team is only running two containers (currently) so we’re using Fargate/ECS
data:image/s3,"s3://crabby-images/6a5fa/6a5fa2c54dc53015cb3683b145a51ad9ee88466f" alt="TBeijen avatar"
That would be the alternative, yes (e.g. using Kops). But e.g. 3 m5.large instances will be as expensive. And you’ll not be able to use EKS managed nodes or EKS Fargate.
data:image/s3,"s3://crabby-images/d593f/d593fb633541525ba68d89fab148a8ee508f62c0" alt="Maxim Tishchenko avatar"
I’m using ECS as well, but I was starting to look into k8s, and I was unpleasantly surprised about price
data:image/s3,"s3://crabby-images/d593f/d593fb633541525ba68d89fab148a8ee508f62c0" alt="Maxim Tishchenko avatar"
@TBeijen thank you.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
data:image/s3,"s3://crabby-images/d593f/d593fb633541525ba68d89fab148a8ee508f62c0" alt="Maxim Tishchenko avatar"
2020-01-14
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
Hi guys Have anyone experience with EMR auto scaling related to Presto app? We have errors in Presto when downscaling EMR, it looks like EMR does not support graceful shutdown for Presto because it is not managed by YARN. Is there any workaround? Are we doing something wrong?
data:image/s3,"s3://crabby-images/630a7/630a7f0780198b8272b506eeb159644c5951a0f4" alt="Michael Coffey avatar"
Does anyone know where I can find an example of using terraform to add a trigger to a lambda function? I found aws_lambda_event_source_mapping but it seems to only support event streaming from Kinesis, DynamoDB, and SQS. I want to add a trigger for changes in an S3 object.
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
Manages a S3 Bucket Notification Configuration
data:image/s3,"s3://crabby-images/630a7/630a7f0780198b8272b506eeb159644c5951a0f4" alt="Michael Coffey avatar"
Thanks Joe!!
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
No worries. How are you finding deploying lambda functions with Terraform?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
Love deploying lambda with terraform. It’s phenomenal. Especially when using the claranet/terraform-aws-lambda module
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
I shall look into that, thanks @loren. Have been looking for alternatives to the Serverless framework.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
If you use api gateway extensively, then terraform is rather more involved to get working than serverless. But for basic lambda and integrating with other aws services, terraform is way better. And you can do api gateway also, you just need to really learn some of the complexities where serverless makes a lot of choices for you to simplify the basic interface
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
That’s been my takeaway from using both
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
Thank you for that. Current project involves kinesis stream consumers so it could work well.
2020-01-15
data:image/s3,"s3://crabby-images/ce289/ce289e18479f1b5efe01da5d8f068e27d4a84a9f" alt="Joe Hosteny avatar"
Has anyone tried using the reference architecture with a .ai domain? You cannot register .ai domains in AWS. I am wondering if this would work if, after provisioning, the SOA record in the apex domain’s hosted zone were deleted, and name servers at the registrar pointed to the name servers in that same zone?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Joe Hosteny haven’t tried… but don’t see why not? ref arch does not register TLD. it just creates the zones.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so if you can create the zones, then it’s fine.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
after provisioning, the SOA record in the apex domain’s hosted zone were deleted, and name servers at the registrar pointed to the name servers in that same zone?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
please share context (also lets use #geodesic)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
office hours starting in 10m: https://cloudposse.com/office-hours
Public “Office Hours” with Cloud Posse
2020-01-17
data:image/s3,"s3://crabby-images/8df3b/8df3b7c19f12d2950e1367766349d2336c94f737" alt="Saichovsky avatar"
Hey peeps
data:image/s3,"s3://crabby-images/8df3b/8df3b7c19f12d2950e1367766349d2336c94f737" alt="Saichovsky avatar"
I am trying to add a config rule to Landing Zone so it can be created across accounts
data:image/s3,"s3://crabby-images/8df3b/8df3b7c19f12d2950e1367766349d2336c94f737" alt="Saichovsky avatar"
There’s very few (if any) tutorials on LZ - all I see are videos and articles on why LZ is good and what it does and its advantages, but barely any meaningful examples
data:image/s3,"s3://crabby-images/8df3b/8df3b7c19f12d2950e1367766349d2336c94f737" alt="Saichovsky avatar"
so my CodePipieline pipelines are passing after adding the custom config rule to some template
data:image/s3,"s3://crabby-images/8df3b/8df3b7c19f12d2950e1367766349d2336c94f737" alt="Saichovsky avatar"
I have also added the lambda that should get invoked (both source code and definition in the template) as well as the permissions required to execute the lambda
data:image/s3,"s3://crabby-images/8df3b/8df3b7c19f12d2950e1367766349d2336c94f737" alt="Saichovsky avatar"
After the pipeline executes successfully (which takes forever to complete), the resources are still not created and at this point, I am not sure what it is that I need to understand between cloudformation and LZ
data:image/s3,"s3://crabby-images/8df3b/8df3b7c19f12d2950e1367766349d2336c94f737" alt="Saichovsky avatar"
It’s hard to troubleshoot when everything is passing
data:image/s3,"s3://crabby-images/8df3b/8df3b7c19f12d2950e1367766349d2336c94f737" alt="Saichovsky avatar"
Any pointers to some resource which can help me understand LZ like a 5 year old?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Mike Crowe any resources you found helpful?
data:image/s3,"s3://crabby-images/8df3b/8df3b7c19f12d2950e1367766349d2336c94f737" alt="Saichovsky avatar"
@Erik Osterman (Cloud Posse) not really, just some assistance from a friend who explained the manifest file. Still learning the ropes - info seems scanty on it
data:image/s3,"s3://crabby-images/6ef30/6ef3026a1f532a8f803d5d809ea13643eb693548" alt="Michael Warkentin avatar"
Nice little extension from a coworker: https://addons.mozilla.org/en-US/firefox/addon/amazon-web-search/
Lets you create a shortcut to open up the AWS console service list / search bar - and most importantly lets you hit esc
to close it
data:image/s3,"s3://crabby-images/ce69e/ce69ef494d41d05f937591856c1e7d542e4dc260" alt="attachment image"
Download Amazon Web Search for Firefox. Hotkey for opening AWS search.
data:image/s3,"s3://crabby-images/bbd3f/bbd3f09b354407c903274f1a0220c56c80a89869" alt="Mike Crowe avatar"
@Mike Crowe has joined the channel
2020-01-18
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Mike Crowe sound familiar?
data:image/s3,"s3://crabby-images/bbd3f/bbd3f09b354407c903274f1a0220c56c80a89869" alt="Mike Crowe avatar"
Ha ha btdt
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
AWS NAT gateways are stupidly expensive for what they do
data:image/s3,"s3://crabby-images/bbd3f/bbd3f09b354407c903274f1a0220c56c80a89869" alt="Mike Crowe avatar"
And not documented in control tower
2020-01-19
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
i have to think that they’re just spinning up multiple ec2 instances to do NAT or something like that - for the price that you pay it would have to be something supper inefficient
data:image/s3,"s3://crabby-images/49247/4924735130c3558e142e6b840faa2585ac6c3000" alt="mfridh avatar"
Was thinking about this the other day… at least modifying my terraform so that the “spoke” VPCs just get a solo NAT gateway instead of 3x… but then I guess you start paying cross-AZ for 2 thirds of egress traffic anyway so I dunno
2020-01-20
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
can also use transit gateway to route egress traffic through one vpc, and just pay for one set of nat gateways
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
EC2 instances doing NAT i think
2020-01-21
2020-01-22
data:image/s3,"s3://crabby-images/f45ee/f45eef3d6288e2ea0683bb6f37c32e4f596a2278" alt="Abel Luck avatar"
hey folks, a client of mine is using the AWS SSO to manage all access creds. I’m having some trouble finding a nice solution for using this with terraform.
data:image/s3,"s3://crabby-images/f45ee/f45eef3d6288e2ea0683bb6f37c32e4f596a2278" alt="Abel Luck avatar"
Currently I am logging into the aws sso page, choosing the aws account, clicking “Command line or programmatic access” and copy pasting the provided env vars into my shell.
data:image/s3,"s3://crabby-images/f45ee/f45eef3d6288e2ea0683bb6f37c32e4f596a2278" alt="Abel Luck avatar"
I have to do this every hour
data:image/s3,"s3://crabby-images/f45ee/f45eef3d6288e2ea0683bb6f37c32e4f596a2278" alt="Abel Luck avatar"
Both aws-vault and terraform have tickets open about AWS SSO, but has anyone come up with a decent workaround?
data:image/s3,"s3://crabby-images/d9e92/d9e928c8072ef23aa67baffdbbb70f322a3aa65e" alt="Dzhuneyt avatar"
AWS recommends that we give access/secret keys only to physical users. Machines or systems should instead assume IAM roles (e.g. an EC2 instance should never use access keys passed as environment variables).
However, how does this best practice work in real life when the system that communicates with AWS is a third party one (e.g. GitHub actions). Can I make a GitHub Actions CI pipeline communicate with AWS APIs without creating an IAM user for it? After all, GitHub is a machine, not a human. It should use IAM roles, right?
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
AWS means to do that in AWS eco-system. If you have a custom github runner in aws you can use IAM role
data:image/s3,"s3://crabby-images/d9e92/d9e928c8072ef23aa67baffdbbb70f322a3aa65e" alt="Dzhuneyt avatar"
So if I use a real third party solution like Jenkins, GitHub actions, CircleCI - I have no other option but to resort to IAM users and secret keys per provider?
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
Yes
data:image/s3,"s3://crabby-images/c8934/c893460846f34e2e99dff467d5edba93d5582035" alt="vFondevilla avatar"
Yup
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
did you try aws-cli v2, and its new integration with aws sso? login with that to get the creds for the profile, then run terraform? https://docs.aws.amazon.com/cli/latest/userguide/cli-configure-sso.html
If your organization uses AWS Single Sign-On (AWS SSO), your users can sign in to Active Directory, a built-in AWS SSO directory, or another iDP connected to AWS SSO and get mapped to an AWS Identity and Access Management (IAM) role that enables you to run AWS CLI commands. Regardless of which iDP you use, AWS SSO abstracts those distinctions away, and they all work with the AWS CLI as described below. For example, you can connect Microsoft Azure AD as described in the blog article
data:image/s3,"s3://crabby-images/f45ee/f45eef3d6288e2ea0683bb6f37c32e4f596a2278" alt="Abel Luck avatar"
I ended up using aws cli v2 with a little wrapper https://github.com/linaro-its/aws2-wrap
Replaces aws-vault in my normal setup
Simple script to export current AWS SSO credentials or run a sub-process with them - linaro-its/aws2-wrap
data:image/s3,"s3://crabby-images/ce289/ce289e18479f1b5efe01da5d8f068e27d4a84a9f" alt="Joe Hosteny avatar"
Depending on your integration, one thing you can also consider is having some privileged task inside your infra deliver STS credentials to the third party service.
data:image/s3,"s3://crabby-images/ce289/ce289e18479f1b5efe01da5d8f068e27d4a84a9f" alt="Joe Hosteny avatar"
That means your infra code has to have creds to the service, but that may be more palatable
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
may be able to use the credential_process
feature of the aws shared config file to retrieve temporary creds, if the integration is running in something that gives you that kind of access, https://docs.aws.amazon.com/cli/latest/userguide/cli-configure-sourcing-external.html
If you have a method to generate or look up credentials that isn’t directly supported by the AWS CLI, you can configure the CLI to use it by configuring the credential_process setting in the config file.
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
what is the best way to implement API authentication for REST API built in nodejs (not AWS Gateway) ?
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
Most people use passport.js
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
yeah i noticed that
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
Little background - our apps are deployed in AWS but the APIs are not deployed to AWS gateway
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
so all our apps need to talk to our APIs
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
Passport is the right choice for api authentication in node
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
currently we have these APIs sitting in private layer
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
what do you mean by private layer?
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
private subnet
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
how does your web app JS access them?
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
so the app is deployed in public subnet and it has access to the APIs sitting in private subnet
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
using security groups
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
I think you’re referring to server-to-server API calls?
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
yes
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
Passport is still fine. The passport-localapikey
strategy is a simple option.
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
thanks for your suggestion
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
i would like to also understand how complex would it be to use AWS API gateway
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
With the new HTTP API feature (in beta though) it’s not too bad but your API will still need to generate JWT’s
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
If you use REST API you could require an API key on certain methods or use a custom authoriser or require a certain request header. There are lots of options. It just depends on your needs.
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
yeah i was looking at HTTP API
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
any ideas and thoughts are appreciated
2020-01-23
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
https://awsapichanges.info/ - not sure if anyone else posted it earlier
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
data:image/s3,"s3://crabby-images/2b8a0/2b8a0c40a19f9d473e21aeb0f843bd0fed2032ab" alt="attachment image"
Security is a top priority in AWS, and in our service team we naturally focus on container security. In order to better assess where we stand, we conducted an anonymous survey in late 2019 amongst container users on AWS. Overall, we got 68 responses from a variety of roles, from ops folks and SREs to […]
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
am i nuts or is cloudwatch synthetics really really expensive
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
i’m calculating $73.44/month for a single per 1 minute check
data:image/s3,"s3://crabby-images/84113/841130a9e9dba5e0420e9e51bccd12f7afe6bc71" alt="Rob Rose avatar"
Looks like it’s just really expensive. Checkout Example 10 on https://aws.amazon.com/cloudwatch/pricing/
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
That seems really uncompetitive. There are so many options in this space
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
for some of our micro services we’d be looking at spending 4x for checks than we do for running the service!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
In general, cloudwatch is expensive.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Even metrics cost something like $0.30/metric
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
when you combine that with k8s, with has like 10,000 metrics, it’s easy to spend more on the monitoring than you would for a small cluster.
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
Yeah our Prometheus metrics in cloud watch would be like be 100k month.
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
@ $0.0017 per canary run
data:image/s3,"s3://crabby-images/67e68/67e683361c271c4e26e156c64a1a2d27db2b053d" alt="David avatar"
Just found an SES rule that was sending to an s3 bucket that used to exist, but no longer does. Is there any way to retrieve the emails it missed in the meantime?
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
depending on your aws support level you may try to ask aws uspport and maybe they will be able to help. I wouldn’t bet they are but there’s always a chance
2020-01-24
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Has anybody run to issues with Internal DNS not resolving correctly for ECS Service Discovery? I can see the correct IP in Route53 with TTL of 60, but it’s not being picked up
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
You application doesn’t pick it up?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
What is your zones SOA TTL?
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
My application doesn’t, but I also tried pinging it elsewhere, and it’s also giving me the wrong ip
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
SOA TTL is 900
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So I would cut SOA to 30 just in general
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Because that acts like a negative cache
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So if the record is queried before it exists and the response is not found, that negative response will be cached for for SOA TTL
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
But what you are describing sounds like it could be something else.
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
AWS Cloud Map service is magically supposed to manage these mappings
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Since you are getting an IP back but the wrong one, it doesn’t have to do with the SOA
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
First time I ran into an issue with it
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I don’t have experience with that service so someone else here might know more like @maarten
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Bah, just noticed Route53 operational issue alert in the AWS console
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Been going on for over 2 hours too. SMH. Please tell me this almost never happens.
2020-01-27
data:image/s3,"s3://crabby-images/8977b/8977bab0dcedc1ac146f85ce4bb236c508ea8b3f" alt="caretak3r avatar"
#aws anyone have experience dealing with aws state machines? specifically, a missing state machine after a cloudformation (landing-zone) update, and my avm (vending machine) plays fail.
2020-01-28
data:image/s3,"s3://crabby-images/7a040/7a04089498df3fe2f8c83e9e0e04b8b3fc890bc2" alt="Michel avatar"
hello, anyone using private aws gateway api with custom host header? Thanks
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
no but have you thought of using an ALB with lambda hooks instead ?
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
@Michel I think we may be doing that right now. We’re doing cross VPC and cross account access with a R53 private zone to a private ALB to a private API gateway. The ALB is required for cross account access otherwise the API Gateway could be shared cross VPC (same account) with just a VPC Endpoint.
2020-01-29
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
data:image/s3,"s3://crabby-images/58038/58038b05d79ca7db6a1153a61ed5d38847b32b23" alt="Blaise Pabon avatar"
Since VPCs are limited in my environment, I naively thought I could just kops cluster create
a new cluster inside my existing VPC. (with this snippet).
Then it blew up because of subnet conflicts and I could see where this was going.
Most of the TF vpc
modules I see expect to create a new one….
Should I:
• terraform import
the VPC resource,
• manually replace vpc.vpc_id
with something in var.vpc_id
• stop overthinking this and use some kops
flag I don’t yet know about
?
data:image/s3,"s3://crabby-images/a8218/a8218a4d8f64a246eb7c4827c76f3d9f17ba8285" alt="grv avatar"
Usual approach I follow with KOPS is to create VPC and other aws reosurces using terraform and then use kops
to create the actual cluster (just like you are doing). I however split the subnets cidr’s accordingly when creating the VPC from tf. In your case, I guess if you are planning to use the vpc, terraform import might help. Not sure if this helps you though
data:image/s3,"s3://crabby-images/58038/58038b05d79ca7db6a1153a61ed5d38847b32b23" alt="Blaise Pabon avatar"
@grv Thanks for the validation, I’m more confident now. So I guess could maybe run TF against the existing VPC and have it carve out the subnets, security-groups, etc, then run kops
to stich them together into a cluster.
data:image/s3,"s3://crabby-images/a8218/a8218a4d8f64a246eb7c4827c76f3d9f17ba8285" alt="grv avatar"
That would make sense, but I have a feeling you might run into some kind of trouble while trying to play around existing cloud resources using tf. Again, saying maybe
data:image/s3,"s3://crabby-images/8f593/8f59375c84cdfbf34fb0776b18e8b900c3c18350" alt="Alejandro Rivera avatar"
Hi, has anyone deployed EKS on me-south-1 and successfully interacted with the cluster via kubectl
getting credentials using aws sts assume-role
?
2020-01-30
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Yes, same as other regions…
data:image/s3,"s3://crabby-images/f9284/f9284a413dd37970df022308f1ed26d8dea2147e" alt="GFox)(AWSDevSecOps avatar"
Looking for simple condition to set in EC2 instance template with ALB, that will hold the 2nd (HA instance being deployed) so I can get the first up with some manual config running then remove condition to lauch the instanceB
2020-01-31
data:image/s3,"s3://crabby-images/c6612/c66122b7e7868b201b94044e6e56c27c698b1db3" alt="dan841 avatar"
Hello, I’ve used the AWS landing zone pattern for a while but just wondering how others use the shared account for things like Vault? I.e put Vault in here or separate account? Also usage pattern - 1 Vault for dev/prod or 2 separate installations…Just wondering what others have done…cheers
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
I’ve always gone with a Vault cluster per environment
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Deployed into the same account unless it is a break-glass type scenario
data:image/s3,"s3://crabby-images/c6612/c66122b7e7868b201b94044e6e56c27c698b1db3" alt="dan841 avatar"
That’s an option, I was thinking we will have multiple prod accounts so a shared prod Vault cluster would be another way
data:image/s3,"s3://crabby-images/8df3b/8df3b7c19f12d2950e1367766349d2336c94f737" alt="Saichovsky avatar"
Hey people
data:image/s3,"s3://crabby-images/8df3b/8df3b7c19f12d2950e1367766349d2336c94f737" alt="Saichovsky avatar"
I have a question for AWS gurus
data:image/s3,"s3://crabby-images/8df3b/8df3b7c19f12d2950e1367766349d2336c94f737" alt="Saichovsky avatar"
How do I use the PutOrganizationConfigRule
API in Landing Zone to create an organization config rule?
https://docs.aws.amazon.com/config/latest/APIReference/API_PutOrganizationConfigRule.html
Adds or updates organization config rule for your entire organization evaluating whether your AWS resources comply with your desired configurations. Only a master account can create or update an organization config rule.
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Going to try this channel as well. Does anyone know if ECS provides an SNS topic to subscribe to events like updating service, tasks starting/stopping, autoscaling events?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
I don’t believe so
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Does https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs_cwet.html get you what you need?
In this tutorial, you set up a simple AWS Lambda function that listens for Amazon ECS task events and writes them out to a CloudWatch Logs log stream.
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
I guess, if that’s the only option. Thanks
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Looks like it only gives you “ECS Task State Change”, “ECS Container Instance State Change” triggers
data:image/s3,"s3://crabby-images/17ee2/17ee2a9c1147340bd90d17feda227e33c1d2f185" alt="Steven avatar"
Unless they’ve adding something since I last looked. You subscribe a lambda to the event. The lambda needs to parse to figure out what the change was, then run your logic for that change type.
data:image/s3,"s3://crabby-images/17ee2/17ee2a9c1147340bd90d17feda227e33c1d2f185" alt="Steven avatar"
At that point whether you send to SNS or do anything else is up to you
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Thanks @joshmyers @Steven
data:image/s3,"s3://crabby-images/17ee2/17ee2a9c1147340bd90d17feda227e33c1d2f185" alt="Steven avatar"
Not great. It needs finer events
data:image/s3,"s3://crabby-images/2dd60/2dd604fa6fff150f1b0f4c0d148234610a67081b" alt="timduhenchanter avatar"
How are people dealing with upgrading minor versions of Kubernetes in EKS in large clusters?