#aws (2019-10)
Discussion related to Amazon Web Services (AWS)
Discussion related to Amazon Web Services (AWS)
Archive: https://archive.sweetops.com/aws/
2019-10-01
data:image/s3,"s3://crabby-images/07f2e/07f2eafab0c2dcfd20ae38a765d413a910e51db9" alt="Yusley Orea avatar"
Anyone have any recommendations for a tool for disaster recovery on AWS? especially for Aurora, DynamoDB and EBS.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
a tool ? as like something that could do what ?
data:image/s3,"s3://crabby-images/07f2e/07f2eafab0c2dcfd20ae38a765d413a910e51db9" alt="Yusley Orea avatar"
centralized cross regions backup for services or at least for RDS. I look for https://aws.amazon.com/backup but it’s region dependency.
AWS Backup is a fully managed backup service that makes it easy to centralize and automate the back up of data across AWS services in the cloud as well as on-premises using the AWS Storage Gateway.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I will just use global aurora cluster and backup the main region
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
or you can have read replica cluster in other regions/accounts or same account
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so instead of having snapshots you have replicas that can promote in very little time
2019-10-09
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Does anyone know the default duration of the session when using aws-vault?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
1h I think
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but that is not on aws-vault side
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
is aws side
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and you can change that with a policy
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
A vault for securely storing and accessing AWS credentials in development environments - 99designs/aws-vault
2019-10-10
data:image/s3,"s3://crabby-images/a1f9e/a1f9e81decf220a56c64df5037465cf0a8b9f857" alt="Fernando Torresan avatar"
I had been facing a problem when I tried to provision a cloudfront (estimate time 18 min) and using aws-vault to work properly I’ve needed to set this flag --assume-role-ttl=1h
, like:
aws-vault exec <profile-name> --assume-role-ttl=1h
data:image/s3,"s3://crabby-images/1e7fb/1e7fb012e9114db9a49ef4fb0140243909a277f1" alt="Matt Gowie avatar"
Hey folks – IAM Policy questions: What’s the standard operating procedure for dev teams on AWS and requiring MFA? I’ve created a policy to require MFA for all actions so users need to assign an MFA on first login and then on subsequent logins they need to provide MFA before they can do anything in the console, which is what I want. My problem with this is that I can’t distinguish between requiring MFA for console usage vs CLI usage. I’d like to empower devs to push to ECR or use certain CLI functionality without having them put their MFA in every morning.
I have a way to add IAM actions the user is allowed to do via the following policy statement:
{
"Sid": "DenyAllExceptListedIfNoMFA",
"Effect": "Deny",
"NotAction": [
// Bunch of management actions the user is allowed to do.
],
"Resource": "*",
"Condition": {
"BoolIfExists": {
"aws:MultiFactorAuthPresent": "false"
}
}
}
Should I just push all my CLI allowed actions into that NotAction
and manage it that way? Or is there a better way?
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
I recommend having the ability to change password and manage own MFA available by default, and everything else locked behind having MFA present. Providing all access through assumed roles, that means you only have to lock down role assumption, and the only thing an IAM user is allowed to do is manage their MFA and login
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
That said, the second half of your statement, (allowing certain actions via MFA) could easily just be added as allows, since everything is an implicit deny. To my brain “allowing if” is simpler than “denying unless…”
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
I don’t think there is a way in IAM to distinguish between API and console access, so you’d have to be okay with it being available in both places without MFA. I mean maybe you could do something with aws:UserAgent
but those are spoofable
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Also aws-vault in server mode can help reduce the frequency of entering MFA code
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Is every 12 hours really such a bad thing? :-)
data:image/s3,"s3://crabby-images/1e7fb/1e7fb012e9114db9a49ef4fb0140243909a277f1" alt="Matt Gowie avatar"
Got it — Thanks gents. Think I need to do some reading on role assumptions + aws-vault, but overall I think I’ll move forward with supplying explicit allows for things I don’t want to hinder this dev team with and I’ll try to just keep that list short.
data:image/s3,"s3://crabby-images/1e7fb/1e7fb012e9114db9a49ef4fb0140243909a277f1" alt="Matt Gowie avatar"
Is every 12 hours really such a bad thing? :-)
Haha I personally don’t think so… but since I’m consulting for a dev agency who is more cavalier about security I just don’t want to rub them the wrong way.
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
Hi guys, Is there anyone familiar with IAM role and Instance Profile ?> I have a case like this: I would like to create an Instance Profile with suitable policy to allow access to ECR repo ( include download image from ECR as well). Then I attach that Instance Profile for a Launch Configuration to spin up an instance. The reason why I mentioned Policy for ECR is that I would like to set aws-credential- helper on the instance to use with Docker (Cred-helper). when it launch, so that when that instance want to pull image from ECR, it wont need AWS credential on the host itself at first. All of that module, I would like to put in Terraform format as well. Any help would be appreciated so much.
2019-10-11
data:image/s3,"s3://crabby-images/cb2d6/cb2d66dbb64e02b756efce7bac43166185fba314" alt="mmarseglia avatar"
@Phuc i sort of do this with Elasticbeanstalk. I use the module https://github.com/cloudposse/terraform-aws-ecr.git and pass the elasticbeanstalk roles that get created.
Terraform Module to manage Docker Container Registries on AWS ECR - cloudposse/terraform-aws-ecr
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
Hi, If I use transit gw with multiple vpcs attached. Each VPC use its own private DNS zone in Route53. Traffic is working between VPC’s, but is there way to somehow delegate DNS resolving between VPCs?
2019-10-12
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
2019-10-14
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Nice one
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
definitely awesome stuff. It will allow me to connect on-prem solutions with AWS later on, and to use on-prem private dns server
2019-10-15
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/0852a/0852a26d0db22d4473e34053f68c5e143a6c7d6f" alt="attachment image"
Over my 17 years at Amazon, I have seen that my colleagues on the engineering team are never content to leave good-enough alone. They routinely re-evaluate every internal system to make sure that it is as scalable, efficient, performant, and secure as possible. When they find an avenue for improvement, they will use what they […]
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
imagine being the head project manager on this massive multi-year multi-team migration and closing that last ticket as this is posted. that’s gotta feel good.
data:image/s3,"s3://crabby-images/0852a/0852a26d0db22d4473e34053f68c5e143a6c7d6f" alt="attachment image"
Over my 17 years at Amazon, I have seen that my colleagues on the engineering team are never content to leave good-enough alone. They routinely re-evaluate every internal system to make sure that it is as scalable, efficient, performant, and secure as possible. When they find an avenue for improvement, they will use what they […]
2019-10-16
data:image/s3,"s3://crabby-images/3c547/3c54718d528a1cd5e01420b9e569bdf089661131" alt="roth.andy avatar"
data:image/s3,"s3://crabby-images/e545b/e545b032f7413b24f9f47fb376422767f7fdf9bd" alt="attachment image"
It’s my pleasure to announce that we’ve expanded the number of AWS services that customers can use to run sensitive and highly regulated workloads in the federal government space. This expansion of our FedRAMP program marks a 28.6% increase in our number of FedRAMP authorizations. Today, we’ve achieved FedRAMP authorizations for 6 services in our […]
2019-10-17
data:image/s3,"s3://crabby-images/b3020/b30209e95fc92badf2b1313a8b7b8094d7bdeac1" alt="IvanM avatar"
Guys I need a bit of help with AWS networking Issue - we have RDS instances running in private subnets in VPC. From our office network we want to be able to always ssh into these instances (without client VPN). How should we do that? I guess we need a site-to-site VPN connection from our local network to the VPC. However how to enable traffic only to the rds instances. I do not want all the Internet network to go via the VPC/VPN So the local network should still have internet connection as is, only that there should be a direct connection possible to the RDS instances in VPC only
data:image/s3,"s3://crabby-images/89947/899478cb8e24b246fe27ae7f7198354a1f971dcc" alt="Ognen Mitev avatar"
As far as I know you cannot directly SSH to RDS instance eq. ssh user@rdsinstance…
You can use:
- Bastion host and from there - mysql -h mysql–instance1.123456789012.us-east-1.rds.amazonaws.com -P 3306 -u mymasteruser -p
- Public access to the RDS filtered to your IPs… But you will need MySQL Client (workbench or sqlpro…)
- Maybe someone else knows anything else
I would do it via case 1. There are options how to do the Bastion host and so on…
data:image/s3,"s3://crabby-images/70bc7/70bc76aeb36c3c4f22d0a1b714f4b65caa416111" alt="Taras avatar"
+
for case 1
. There is no technical possibility(implementation) to SSH into RDS’s servers/instances. Only connect to DB using DB-client like mysql etc.
data:image/s3,"s3://crabby-images/b3020/b30209e95fc92badf2b1313a8b7b8094d7bdeac1" alt="IvanM avatar"
sorry, my bad Yeah what I meant is to be abel to connect to rds using a client Issue is that the RDS is in a private subnet and not accessible via Internet
data:image/s3,"s3://crabby-images/89947/899478cb8e24b246fe27ae7f7198354a1f971dcc" alt="Ognen Mitev avatar"
data:image/s3,"s3://crabby-images/bb99d/bb99dba41a90e5a58f494b1c27d5a37931cd1b36" alt="Sugananth T avatar"
I had a similar situation, we needed to connect to a server in different VPC and then connect to a Aurora MySQL RDS db with MYSQL connector - ie - like this - mysql -h <mysql–instance-name> -P 3306 -u mymasteruser -p <password>
data:image/s3,"s3://crabby-images/bb99d/bb99dba41a90e5a58f494b1c27d5a37931cd1b36" alt="Sugananth T avatar"
But connecting to a RDS managed DB server via putty or some other ssh or sftp client is not possible as far as i know
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
what’s the easiest way to clean up an aws account prior to account deletion?
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
AWS nuke
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
A tool for cleaning up your cloud accounts by nuking (deleting) all resources within it - gruntwork-io/cloud-nuke
Nuke a whole AWS account and delete all its resources. - rebuy-de/aws-nuke
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
last time i’ve checked nuke wasn’t supporting all of the services
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Automatically clean-up multiple AWS Accounts on a schedule - 1Strategy/automated-aws-multi-account-cleanup
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
but maybe i need to recheck
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Not personally used it, just no of it. Can’t comment
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
sure. i will try it on one of the test accounts which will be deleted
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
thanks for a tip
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
data:image/s3,"s3://crabby-images/99c46/99c4611ff6f742c58accefa99c700c29fc5a93c8" alt="attachment image"
Last year I told you that we were working to give you , with the goal of bringing many of the benefits of to your on-premises virtualized environments. These benefits include the ability to provision new on-premises databases in minutes, make backups, and restore to a point in time. You get automated management of your […]
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
I see AWS recommend VPC’s of /16 or smaller. Given a /16 is split into further subnets (at least by AZ but potentially further, eg: different app ASG’s, k8s, etc), I’m curious where the /16 recommendation comes from. Any ideas?
Hard follow or ignore?
https://docs.aws.amazon.com/vpc/latest/userguide/VPC_Subnets.html#vpc-sizing-ipv4
EDIT: The allowed block size is between a /28 netmask and /16 netmask.
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
So, the /16 is a technical limitation imposed by AWS on VPC size. Where the recommendation comes from, I don’t know, but giving your VPC the largest space possible allows you the most flexibility when it comes to making subnets and such.
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
Especially if you’re using EKS, it EATS IP address space fast as every pod is given an IP
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
Yeah, thanks Alex, Erik. Have been able to sort out our IPAM for AWS & EKS now.
2019-10-18
2019-10-20
data:image/s3,"s3://crabby-images/1aec2/1aec21fb3c3f7725243bdc66295d8cd717e80b4e" alt="Daniel Minella avatar"
Hello everyone, how do you manage ecs container logs? Example, now when a container dies I have to connect at EC2 that hosts ECS service and execute a docker logs xxxx. Which stack or strategy do you use to handle that?
data:image/s3,"s3://crabby-images/17ee2/17ee2a9c1147340bd90d17feda227e33c1d2f185" alt="Steven avatar"
You can send the logs to Cloudwatch on ecs/ec2 & fargate. On ec2, there are more logging options
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
Usually they go to CloudWatch and then either to 1) external log system, 2) Lambda function that triggers some action if something happened, or 3) nowhere cause they are fully ignored( observability in the application, tracing with exhaustive context sent to other systems so a bit similar to option 1)
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
Depends on the app and the company and the usecase
2019-10-21
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
you can also stream you logs to elasticsearch in AWS
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/23b28/23b28c0602f4807133ff3c28d38e37b698ca86c4" alt="attachment image"
When it comes to the exact cost cross-AZ data transfer, the AWS documentation is a bit ambiguous. So I ran a little experiment to figure out how much it costs to move data between availability zones in the same region.
2019-10-22
data:image/s3,"s3://crabby-images/e01e5/e01e53209fa3d34c6b88a234154e84b28c8836e5" alt="Karoline Pauls avatar"
There’s a limit of 10 policies per role. Am i doing something wrong if I hit this limit?
data:image/s3,"s3://crabby-images/e01e5/e01e53209fa3d34c6b88a234154e84b28c8836e5" alt="Karoline Pauls avatar"
I suppose I can concatenate policy statements and build one large JSON instead of defining one policy per statement, each with its own json…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we have a policy document aggregator to aggregate multiple policies into one https://github.com/cloudposse/terraform-aws-iam-policy-document-aggregator
Terraform module to aggregate multiple IAM policy documents into single policy document. - cloudposse/terraform-aws-iam-policy-document-aggregator
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Karoline Pauls ^
data:image/s3,"s3://crabby-images/e01e5/e01e53209fa3d34c6b88a234154e84b28c8836e5" alt="Karoline Pauls avatar"
i used locals, for
, and join
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
did you considered using groups?
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
with 10 groups per iam user/role and 10 policies attached to a group you can increase it to 100 policies per user
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
or you can create inline policies as long as you don’t exceed 10,240 chars in total aggregate policy size
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
so to answer your question. it depends
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
aws will never say that you’re doing something wrong. it may be suboptimal from their perspective but it may be perfectly fine from yours
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
What would be the go to way for allowing k8s ExternalDNS to change records on a different account to that of the cluster?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We don’t need that
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Basically you should have branded domains in one account
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Those then get cnamed or aliased to the infra domains
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This should almost never have to happen except for cold start
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We do this because we don’t want an errant deployment in staging for example to hijack the branded domain
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
cross account iam access to route53 or k8s zone delegation to the cluster account?
2019-10-24
data:image/s3,"s3://crabby-images/8799d/8799d7f7a17f687259c0e37cf20ea024600c1d5b" alt="Hasen Ahmad avatar"
hi all, im getting this error, using the ECR module, aws_ecr_repository_policy.default: InvalidParameterException: Invalid parameter at 'PolicyText' failed to satisfy constraint: 'Invalid repository policy provided'
is there a fix? do i need to provide the principals_full_access
field ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you don’t need to provide it. But if you do, make sure those principal ARNs are correct and exist
data:image/s3,"s3://crabby-images/8799d/8799d7f7a17f687259c0e37cf20ea024600c1d5b" alt="Hasen Ahmad avatar"
thanks
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
AWS Chatbot is an interactive agent that makes it easy to monitor and interact with your AWS resources from your team chat room. Learn more about the key benefits and how it works.
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
Yeah I checked that out a month or so ago when they first released it.
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
It’s promising but doesn’t do what I need for now
2019-10-27
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
Hey everyone, am working through our IP Addressing on a new AWS migration and would be great to hear some thoughts on how to structure public/private subnets please. Curious how others manage. I’m pretty fresh to AWS on a large scale.
Our setup:
- We have a mix of Kubernetes, VM and Managed Service (DB/Queuing/etc) workloads. There is communication between them.
- We are multi-AZ and are planning to minimise inter AZ traffic. ie: apps target other apps in same AZ via DNS.
- We are in multiple regions (identical setup, just different VPC’s with non-clashing addressing, not peered)
AWS subnetting option 1 (my proposal):
- VPC /16
- AZ /18 (one per AZ plus one /18 spare)
- Split an AZ in /20 per workload (assume even distribution, but not important for this chat). eg: /20 for public k8s/loadbalancers, /20 private k8s (nodes/pods), /20 VM’s, /20 managed services. Reality is different sizing but it’s still plenty addresses.
- Pros: AZ boundary very clear because /18 defines it - for troubleshooting/etc. Suspect we will have separate (k8s and vm) node pools per AZ. We have had odd hacky IP whitelist in current cloud due to lack of auth between apps.
- Cons: Overhead managing?
AWS subnetting option 2 (Partner proposed):
- VPC /16
- Public /17
- Private /17
- Pros: Don’t think about IP’s (micro manage). Based on EC2 metadata target az# service, use some selector mechanism in private loadbalancer/security group (We would do this above anyway).
- Cons: Troubleshooting traffic path will be non-obvious by endpoint name and require AZ membership lookup (potentially retrospectively) ? K8s node pool rebalancing (I’ve heard this is a thing)? Does this apply to ASG’s?
In both cases the Cloudposse named-subnets module looks like a great fit and we would pass in the subnets id in as required.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@kskewes will get back to you tomorrow
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
thanks heaps.
2019-10-28
data:image/s3,"s3://crabby-images/02a47/02a47a301522555fd984b36597a8f89d132a7f3a" alt="Ruan Arcega avatar"
Anyone using AWS MSK resource (Apache Kafka), with data (topics, kafka and zookeeper state) stored in bucket ?
data:image/s3,"s3://crabby-images/dd31b/dd31b079491f62daacb7cd9a04b1d8c7ea70fa52" alt="Cameron Boulton avatar"
@kskewes FWIW I’m doing /17 non-clashing per environment per region with 8 (4 public and 4 private) /19 subnets per region which allows for 4 AZs per region.
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
Thanks Cameron! So with a subnet per AZ you can avoid the ASG rebalancing. Put mixed workload types (k8s/vm/etc) into the same subnet, whether public/private?
data:image/s3,"s3://crabby-images/dd31b/dd31b079491f62daacb7cd9a04b1d8c7ea70fa52" alt="Cameron Boulton avatar"
Right. Generally we always default to using the Private subsets for security unless we have public access requirements: i.e. internet/public load balancers are in the Public subnets.
data:image/s3,"s3://crabby-images/dd31b/dd31b079491f62daacb7cd9a04b1d8c7ea70fa52" alt="Cameron Boulton avatar"
K8s, EC2/VMs, RDS, etc. are all in Private subnets
data:image/s3,"s3://crabby-images/dd31b/dd31b079491f62daacb7cd9a04b1d8c7ea70fa52" alt="Cameron Boulton avatar"
And ASG, RDS, etc. are configured to use all the subnet/AZs available in that region for greater availability
data:image/s3,"s3://crabby-images/dd31b/dd31b079491f62daacb7cd9a04b1d8c7ea70fa52" alt="Cameron Boulton avatar"
I know you said you are likely optimizing for inter-AZ traffic costs, but we do the opposite: optimize for AZ failure/high-availability
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
Thanks again. I think for RDS etc we would have all AZ subnets in. For VM and k8s though, ASG per AZ subnet. Ie, split workload into own subnet.
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
Outcome would be same (each ASG can scale) but we’d have more management overhead and clearer AZ boundaries.
data:image/s3,"s3://crabby-images/dd31b/dd31b079491f62daacb7cd9a04b1d8c7ea70fa52" alt="Cameron Boulton avatar"
Right
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yes, I agree with @Cameron Boulton. We follow a similar approach in our reference architectures.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Get up and running quickly with one of our reference architecture using our fully automated cold-start process. - cloudposse/reference-architectures
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
You’ll see our examples mostly use terraform-aws-dynamic-subnets
module
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(we have 3 modules for subnet strategies)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
GitHub is where people build software. More than 40 million people use GitHub to discover, fork, and contribute to over 100 million projects.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the terraform-aws-named-subnets came from a customer requirement we did a few years ago, but isn’t what we generally use.
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
Thanks heaps Erik.
Be nice if could use security groups in k8s NetworkPolicy
objects.
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
I think the fact I’m concerned about doing IP based policies is the big difference.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
For kubernetes, using a Mesh is the way to achieve greater network security
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
yeah, we are a wee way from that
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
Even Cillium CNI for L7 http path filtering
data:image/s3,"s3://crabby-images/dd31b/dd31b079491f62daacb7cd9a04b1d8c7ea70fa52" alt="Cameron Boulton avatar"
Not sure what your capacity planning looks like but that allows for 8,192 address per subnet or 32,768 per VPC
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/8339b/8339bf4a58e8a381081aa26ff3af8cecfe966368" alt="attachment image"
Looks like some security staff were asleep at the switch
data:image/s3,"s3://crabby-images/dd31b/dd31b079491f62daacb7cd9a04b1d8c7ea70fa52" alt="Cameron Boulton avatar"
Always at the mercy of your weakest link and in process automation, that weakest link is humans
data:image/s3,"s3://crabby-images/8339b/8339bf4a58e8a381081aa26ff3af8cecfe966368" alt="attachment image"
Looks like some security staff were asleep at the switch
data:image/s3,"s3://crabby-images/e01e5/e01e53209fa3d34c6b88a234154e84b28c8836e5" alt="Karoline Pauls avatar"
theregister is basically a tech tabloid
data:image/s3,"s3://crabby-images/e01e5/e01e53209fa3d34c6b88a234154e84b28c8836e5" alt="Karoline Pauls avatar"
anyone has a less sensational source?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Catch point maybe?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Cybersecurity has always been the Achilles heel of the digital world. Digital security protocols, firewalls, and advanced authentication methods have improved and tightened internet security, but even with all these measures in place, cyberattacks are inevitable. You can only mitigate the impact and prevent any major compromise before it turns…
2019-10-29
data:image/s3,"s3://crabby-images/02205/02205eda7629fd1a32066e466b5764002c29ec10" alt="Juan Cruz Diaz avatar"
Este jueves 31/10 tendrá lugar el 8vo capítulo en la serie de webinars de DinoCloud, “Desplegando entornos altamente disponibles en la nube”! En esta edición Nicolás Sánchez (COO) y Juan Diaz (Cloud Architect) comentarán sobre las mejores prácticas a la hora de planear un disaster recovery. Además sortearemos 2000 U$D en vivo!
Registrate gratis aquí: https://www.eventbrite.com.ar/e/desplegando-entornos-altamente-disponibles-en-la-nube-tickets-78054520171
Desplegando entornos altamente disponibles en la nube. Experiencias y mejores prácticas a la hora de planear un disaster recovery.
data:image/s3,"s3://crabby-images/de7fb/de7fb9146e44c772c992ecc234a51d54df387fb9" alt="Andy avatar"
GM everyone!
Has anyone used Beats Central Management
feature with ElasticCloud (Official Elastic hosted on cloud)?
I am getting add_cloud_metadata/add_cloud_metadata.go:87 add_cloud_metadata: hosting provider type not detected.
error message.
2019-10-30
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/dd31b/dd31b079491f62daacb7cd9a04b1d8c7ea70fa52" alt="Cameron Boulton avatar"
Interesting, thanks for sharing
2019-10-31
data:image/s3,"s3://crabby-images/1e7fb/1e7fb012e9114db9a49ef4fb0140243909a277f1" alt="Matt Gowie avatar"
Hey folks, Any suggestions for a alternative to beanstalk environment variables for managing environment variables? I still want my application to consume environment variables for config, but using terraform to manage those variables seems like it’s going to be painful.
Is AWS Parameter store solid? Is there an alternative that folks would suggest?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Chamber+SSM parameter Store
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and you can expose them directly in the Taskdef
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
cloudposse
have modules for chamber and SSM with examples
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
also, there are a few ways of doing that using elastic beanstalk:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- Store all the ENV vars in SSM (using
chamber
for example as @jose.amengual pointed out), then duringterraform apply
read them from the SSM and put them into https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/blob/master/main.tf#L778
Terraform module to provision an AWS Elastic Beanstalk Environment - cloudposse/terraform-aws-elastic-beanstalk-environment
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
In this case, EB will provide those ENV vars to your app automatically
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- Store the ENV vars in SSM and let the app read them from SSM using an AWS SDK (if you want to go this route)
data:image/s3,"s3://crabby-images/1e7fb/1e7fb012e9114db9a49ef4fb0140243909a277f1" alt="Matt Gowie avatar"
Huh, I’ll look into those. I’ve seen Chamber around before, but haven’t dug in too deeply. I like the idea of reading in at deploy time and then passing to EBS from TF. Good stuff. Thanks gents.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
also, in TF, when you create some resources like RDS, you can write all required variables (e.g. host, user, password) to SSM directly after you create the resources, e.g. https://github.com/cloudposse/terraform-root-modules/blob/master/aws/grafana-backing-services/aurora-mysql.tf#L194
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
in this case, you will have all secrets automatically saved in SSM, and then in EB you read them from SSM and populate ENV vars
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/1e7fb/1e7fb012e9114db9a49ef4fb0140243909a277f1" alt="Matt Gowie avatar"
@Andriy Knysh (Cloud Posse) Do you know of an example of reading in values from parameter store? Realize I can use the “aws_ssm_parameter” data source, but I’m wondering how I can read in all SSM parameters for a particular path /$PROJECT/$ENV/*
without having to pass all the names of the parameters I’m storing in as a var.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Matt Gowie when you read and use the params in terraform, aws_ssm_parameter
is the way to go
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if you want to read many params and use them in your app as ENV vars, you can use something like this https://github.com/cloudposse/geodesic/blob/master/rootfs/etc/init.d/atlantis.sh#L45
Geodesic is a cloud automation shell. It's the fastest way to get up and running with a rock solid, production grade cloud platform built on top of strictly Open Source tools. ★ this repo! h…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
read all params from a service (namespace) and export them into ENV vars
data:image/s3,"s3://crabby-images/1e7fb/1e7fb012e9114db9a49ef4fb0140243909a277f1" alt="Matt Gowie avatar"
Maybe that’s not possible though.
data:image/s3,"s3://crabby-images/1e7fb/1e7fb012e9114db9a49ef4fb0140243909a277f1" alt="Matt Gowie avatar"
Wouldn’t be too painful if it wasn’t really…