#aws (2024-01)
Discussion related to Amazon Web Services (AWS)
Discussion related to Amazon Web Services (AWS)
Archive: https://archive.sweetops.com/aws/
2024-01-05
data:image/s3,"s3://crabby-images/36b0b/36b0b350cf153b8d3aeb9a6ec52f70b1167bac8d" alt="Juan Pablo Lorier avatar"
Hi, I’ve being using the ECS module but I’m getting weird error now in a clean account:
Error: updating ECS Cluster Capacity Providers (XXXXXX): InvalidParameterException: Unable to assume the service linked role. Please verify that the ECS service linked role exists.
The role is not a requirement of the module, so not sure why this is failing, any hints?
data:image/s3,"s3://crabby-images/36b0b/36b0b350cf153b8d3aeb9a6ec52f70b1167bac8d" alt="Juan Pablo Lorier avatar"
I found the issue. In fact, it was an AWS issue. In a bare new account, the role AWSServiceRoleForECS is created when you create a cluster for the first time. It was not created and thus, it failed to allow creating the capacity provider. I found that information and just recreated the cluster.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we usually have a separate component to provision all service-linked roles that an account needs
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and do it from just one place so it’s clear what roles are provisioned and in what account
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and also, if a role already exists, you can’t provision it with TF (it will throw error). So the whole config is complicated, w/o a central place to manage all service-liked roles it’s not possible to know if a role was already provisioned, by ClickOps, by AWS (e.g. AWS will create a bunch of service-linked roles automatically when you first create EKS and ECS clusters, but only from the AWS console), or by terraform
data:image/s3,"s3://crabby-images/36b0b/36b0b350cf153b8d3aeb9a6ec52f70b1167bac8d" alt="Juan Pablo Lorier avatar"
thanks so much
2024-01-10
data:image/s3,"s3://crabby-images/c3d43/c3d43fe223e822c9c4cd5f54f475e34b15bcfa66" alt="Dexter Cariño avatar"
Hey Guys any inputs about on this ?
Hello Artisans,
I want to integrate ElastiCache Serverless Redis. I’ve updated the Redis configurations and it works fine.
I’m facing an issue with the Horizon queue:
Predis\Response\ServerException CROSSSLOT Keys in request don't hash to the same slot
/var/www/html/vendor/predis/predis/src/Client.php 370
Sometimes, I’m experiencing these issues too:
Predis\Connection\ConnectionException Error while reading line from the server.
[tcp://****.serverless.use2.cache.amazonaws.com:6379]
/var/www/html/vendor/predis/predis/src/Connection/AbstractConnection.php 155
Illuminate\View\ViewException Error while reading line from the server.
[tcp://***.serverless.use2.cache.amazonaws.com:6379] (View:
/var/www/html/resources/views/frontend/errors/500.blade.php)
/var/www/html/vendor/predis/predis/src/Connection/AbstractConnection.php 155
The config
config/database.php
'redis' => [
'client' => env('REDIS_CLIENT', 'predis'),
'options' => [
'cluster' => env('REDIS_CLUSTER', 'redis'),
'prefix' => env('REDIS_PREFIX', Str::slug(env('APP_NAME', 'laravel'), '_').'_database_'),
],
'clusters' => [
'default' => [
[
'scheme' => env('REDIS_SCHEME', 'tcp'),
'host' => env('REDIS_HOST', '127.0.0.1'),
'password' => env('REDIS_PASSWORD', null),
'port' => env('REDIS_PORT', 6379),
'database' => 0,
],
],
'cache' => [
[
'scheme' => env('REDIS_SCHEME', 'tcp'),
'host' => env('REDIS_HOST', '127.0.0.1'),
'password' => env('REDIS_PASSWORD', null),
'port' => env('REDIS_PORT', 6379),
'database' => 0,
],
],
],
],
.env
REDIS_SCHEME=tls
REDIS_HOST=*****.serverless.use2.cache.amazonaws.com
REDIS_PORT=6379
Please help me sort out the issues. Thanks in advance.
2024-01-11
data:image/s3,"s3://crabby-images/737f1/737f1792eca6fff0a2ec82888d0d447c8acd991f" alt="Pavel avatar"
hey all, was hoping to get a quick answer for this WAF config i need to override:
module "waf" {
source = "cloudposse/waf/aws"
name = "${local.app_env_name}-wafv2"
version = "1.0.0"
scope = "REGIONAL"
default_action = "allow"
visibility_config = {
cloudwatch_metrics_enabled = false
metric_name = "rules-default-metric"
sampled_requests_enabled = true
}
managed_rule_group_statement_rules = [
{
name = "rule-20"
priority = 20
statement = {
name = "AWSManagedRulesCommonRuleSet"
vendor_name = "AWS"
}
visibility_config = {
cloudwatch_metrics_enabled = true
sampled_requests_enabled = true
metric_name = "rule-20-metric"
}
},
{
name = "rule-30"
priority = 30
statement = {
name = "AWSManagedRulesAmazonIpReputationList"
vendor_name = "AWS"
}
visibility_config = {
cloudwatch_metrics_enabled = true
sampled_requests_enabled = true
metric_name = "rule-30-metric"
}
},
{
name = "rule-40"
priority = 40
statement = {
name = "AWSManagedRulesBotControlRuleSet"
vendor_name = "AWS"
}
visibility_config = {
cloudwatch_metrics_enabled = true
sampled_requests_enabled = true
metric_name = "rule-40-metric"
}
}
//bot prevention managed rule set
]
rate_based_statement_rules = [
{
name = "rule-50"
action = "block"
priority = 50
statement = {
limit = 1000
aggregate_key_type = "IP"
}
visibility_config = {
cloudwatch_metrics_enabled = true
sampled_requests_enabled = true
metric_name = "rule-50-metric"
}
}
]
}
I need to override AWS#AWSManagedRulesCommonRuleSet#SizeRestrictions_BODY
to allow for bigger requests
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
each statement
in the rules has rule_action_override
in the variables
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
statement:
name:
The name of the managed rule group.
vendor_name:
The name of the managed rule group vendor.
version:
The version of the managed rule group.
You can set `Version_1.0` or `Version_1.1` etc. If you want to use the default version, do not set anything.
rule_action_override:
Action settings to use in the place of the rule actions that are configured inside the rule group.
You specify one override for each rule whose action you want to change.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you do it like that
- name: "AWS-AWSManagedRulesCommonRuleSet"
priority: 3
statement:
name: AWSManagedRulesCommonRuleSet
vendor_name: AWS
rule_action_override:
SizeRestrictions_BODY:
action: count
EC2MetaDataSSRF_BODY:
action: count
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it’s in YAML for atmos, but you can convert it to HCL and use directly in Terraform vars
data:image/s3,"s3://crabby-images/737f1/737f1792eca6fff0a2ec82888d0d447c8acd991f" alt="Pavel avatar"
im confused what action: count does
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
action: count
is just an example of what can be overridden
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can override anything you need
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Baseline rule groups available from AWS Managed Rules.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
see the doc, you can override all the configs
data:image/s3,"s3://crabby-images/737f1/737f1792eca6fff0a2ec82888d0d447c8acd991f" alt="Pavel avatar"
thanks
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Baseline rule groups available from AWS Managed Rules.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for each item like SizeRestrictions_BODY
, you have to find a separate doc from AWS with all the parameters that WAF supports and can be overridden, like action: count
(WAF is not simple)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
The list of available AWS Managed Rules rule groups.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can run this command to see the Action for each parameter and what items each action has https://docs.aws.amazon.com/waf/latest/APIReference/API_DescribeManagedRuleGroup.html
Provides high-level information for a managed rule group, including descriptions of the rules.
data:image/s3,"s3://crabby-images/13ba6/13ba6046042d92f6e2153ef5d99bf1a792713776" alt="Tyrone Meijn avatar"
Hey @Pavel I also had to this some time ago using the CP module. In our case we wanted to allow it only for a specific endpoint. First you have to set override count:
{
name = "AWSManagedRulesCommonRuleSet"
override_action = "none"
priority = 400
statement = {
name = "AWSManagedRulesCommonRuleSet"
vendor_name = "AWS"
rule_action_override = {
SizeRestrictions_BODY = {
action = "count"
}
CrossSiteScripting_BODY = {
action = "count"
}
}
}
visibility_config = {
cloudwatch_metrics_enabled = true
sampled_requests_enabled = true
metric_name = "AWSManagedRulesCommonRuleSet"
}
},
Then we had to create a new rule group resource:
resource "aws_wafv2_rule_group" "exclude_calculation_api_path" {
name = "${module.backend_waf_label.namespace}-managed-rules-exclusions"
scope = "REGIONAL"
capacity = 100
rule {
name = "exclude-calculation-api-path"
priority = 10
action {
block {}
}
statement {
# IF MATCHES ANY DEFINED LABEL AND IS NOT URI PATH == BLOCK
and_statement {
statement {
# IF MATCHES ANY DEFINED LABEL
or_statement {
statement {
label_match_statement {
scope = "LABEL"
key = "awswaf:managed:aws:core-rule-set:CrossSiteScripting_Body"
}
}
statement {
label_match_statement {
scope = "LABEL"
key = "awswaf:managed:aws:core-rule-set:SizeRestrictions_Body"
}
}
}
}
statement {
not_statement {
statement {
byte_match_statement {
field_to_match {
uri_path {}
}
positional_constraint = "STARTS_WITH"
search_string = "/api/floorplanproduct"
text_transformation {
priority = 0
type = "NONE"
}
}
}
}
}
}
}
visibility_config {
cloudwatch_metrics_enabled = false
metric_name = "exclude-calculation-api-path"
sampled_requests_enabled = false
}
}
visibility_config {
cloudwatch_metrics_enabled = true
metric_name = "${module.backend_waf_label.id}-managed-rules-exclusions"
sampled_requests_enabled = true
}
}
data:image/s3,"s3://crabby-images/13ba6/13ba6046042d92f6e2153ef5d99bf1a792713776" alt="Tyrone Meijn avatar"
And last, reference the group in the module:
rule_group_reference_statement_rules = [
{
name = "${module.backend_waf_label.id}-managed-rules-exclusions"
priority = 990
override_action = "none"
statement = {
arn = aws_wafv2_rule_group.exclude_calculation_api_path.arn
}
visibility_config = {
cloudwatch_metrics_enabled = true
sampled_requests_enabled = true
metric_name = "${module.backend_waf_label.id}-managed-rules-exclusions"
}
}
]
data:image/s3,"s3://crabby-images/13ba6/13ba6046042d92f6e2153ef5d99bf1a792713776" alt="Tyrone Meijn avatar"
Sorry, it’s a lot of code, the WAF has very verbose syntax, but hope it helps!
data:image/s3,"s3://crabby-images/737f1/737f1792eca6fff0a2ec82888d0d447c8acd991f" alt="Pavel avatar"
wow thats a lot. thanks for this
data:image/s3,"s3://crabby-images/94cc2/94cc2f89ba01eafea9abd63fe3c7e3d3f296fa84" alt="Sairam Madichetty avatar"
Hi. Has anyone worked on Keyfactor + cert manager acme?
2024-01-12
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
Hello AWS Pros! I was wondering if anyone had any good insight into handling configuration files with secrets in ECS Fargate. Some background additional background from me is that we’ve transitioned from EC2 based systems to ECS fargate but we’re still using ansible and ansible vault to maintain those configurations.
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
Other services of ours take advantage of Secrets Manager for secret retrieval at runtime. I also have a working example of using an init container to pull a base64 encoded secret and dumping it to a shared volume which is then mounted by the actual task/service.
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
ECS Tasks Definitions can pull secrets from Secrets Manager and SSM Parameter store are runtime
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
Instead of hardcoding sensitive information in plain text in your application, you can use Secrets Manager or AWS Systems Manager Parameter Store to store the sensitive data. Then, you can create an environment variable in the container definition and enter the ARN of the Secrets Manager or AWS Systems Manager secret as the value. This allows your container to retrieve sensitive data at runtime.
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
Thank you, I should have been more explicit, we are currently using value from in the task definition to fetch individual secrets
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
I guess it’s more about, what if you have a config file with multiple secrets, this might work for 10, but not 1000
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
I know that there’s a KV method of storing multiple secrets, but what if you want a config built
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
you can use a file stored in S3 too
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
Yeah that’s an interesting approach that I’ve heard of as well, but kinda worried about access to that bucket and what mechanism is used to updated/render that config file
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
yeah, I think env var proliferation might be considered, but I have no frame of reference of the need of your team. managing that many env vars just sounds rough.
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
secrets manager items can be quite large. you can save the config to a single item and read that.
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
Yeah and it seems that storing secrets in environment variables is kinda frowned upon for the event that a bad actor execs into your container
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
Ive done saving a config as a base64 encoded string to preserve the formatting, but not the config on its own, but I’m still faced with how that config gets rendered initially and updated
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
storing secrets in the env vars section of your task def is a no no, but using secrets binding to ssm/secrets manager isn’t an issue…you have bad actors execing to the container you have bigger issues to worry about than secrets.
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
just to clarify, it’s not in the env vars section, it’s in the “secrets” section which uses the arn to pull the secret at runtime and inject it as an env var, or at least that’s what I perceive is happening
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
but yes, I agree about being in a worse spot if a a bad actor execs into the container
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
I don’t see any security concerns with that, but I guess it depends on who all has exec access…ideal world it’d be nobody. if exec is granted to those that don’t also have access to the secrets, yeah that’s a concern.
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
yeah, least privs, especially in production
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
with 1000 secrets you also need to consider API usage, how often does the container need to restart, etc
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
yeah totally, we do have scaling set up, but I wouldn’t say we have that many tasks running at one time
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
and if that cost balloons, then I think it’s probably a good time to look at something like Vault, but it’s nice not having to manage anything extra right now
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
if it was me, I’d use less secrets with more data in them rather than 1:1 secrets
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
yeah, that seems like the better way, less api calls if they’re loaded into a KV secret
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
yeah, less things to keep track of all around
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
guessing rendering happens at runtime, but I’d hate for some non-escaped character messing up the config and causing the task to continuously reboot
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
that can def happen, but a blue:green deploy will prevent impact
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
that’s true, another thing to think about
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
or at least an automated job that pulls the secrets when it’s been updated and attempts to render it
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
yeah, monitoring for endless task spawns is good
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
or an integration test that reads the secret and validate a config can be parsed from it
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
you could even lambda that and run it when a new version is authored
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
yeah, that would be a cool little tool
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
I don’t think you can prevent the secret from being saved though
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
but you could have the lambda delete that version if you wanted to give it access
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
yeah definitely some interesting possibilities, the same could be said for storing in s3
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
storing the key in an environment variable to fetch the config
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
but I like the built in versioning aspect of secrets manager and better integration
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
I was initially intrigued by S3 because I thought it would be easier, but I ultimately went with a mix of SSM and Secrets Manager due to it being much easier to be confident that my task pulled the version I was expecting…sure you can do that with S3 file versioning, but I found the experience a lot better
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
yeah, kind of the same experience I had with storing lambdas in s3 vs ecr
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
The other idea I toyed with was using an efs mount for secrets and a dedicated manage task to update it periodically. Network failures aside, any other problems with this?
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
I would figure this would slow down task deployments
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
interesting, figured mounting would be pretty quick, but I haven’t tested it
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
I think creative solutions have their own problems, I try to stick w/the options detailed in the documentation unless there is very good not to.
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
I feel that
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
Because what happens when it breaks down, AWS support will just say you’re SOL
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
yeah, also makes onboarding others onto the project more difficult if you’re swimming upstream
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
true true
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
Have you looked at chamber? https://github.com/segmentio/chamber
CLI for managing secrets
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
I’ve heard of it, but haven’t tried it out yet, thank you for the reminder
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
In your entrypoint you’ll want something like
chamber exec <prefix> -- sh -c node main.js
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
Ahhh ok, so some kind of init script as the entry point
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
This v will convert parameter store entries under the prefix service
as environment variables in the shell that executes your process in the entrypoint
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
Oh wow, it actually uses parameter store
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
And I’m guessing local dev isn’t bad, same entry point, just local creds to fetch secrets
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
For local you can configure a different backend
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
Would you use encrypted store like ansible vault in git for local? Or does chamber have its own backend/encryption method?
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
I don’t know. I only use it with secrets manager and parameter store and in those cases you can use AWS kms
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
If you have an entrypoint script you could customize the behavior of how your container launches based on if it in AWS or not
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
Just found this, a little old, but some decent info https://omerxx.com/ops/secrets-with-ssm-and-chamber/
data:image/s3,"s3://crabby-images/2360c/2360c6f28ba43b390094e2e4d968c951fa3123d9" alt="attachment image"
Learning stuff about technology and the universe.
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
We use docker-compose locally and do stuff differently accordingly
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
Yeah, I’ve done something like this where if it detects an AWS access key in the environment variables, then it’s local, otherwise it’s running in fargate
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
I’d suggest using the AWS_EXECUTION_ENV
env var for that — or ECS_CONTAINER_METADATA_URI_V4
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
I guess that’s more complete when a local dev container isn’t reaching out to AWS services
2024-01-13
2024-01-22
data:image/s3,"s3://crabby-images/4a3e9/4a3e9adf00b35538e92e9bd18cd8752a8f823c5c" alt="Gábor Zeleszkó avatar"
Hello, in ECR Repository is there any way with Lifecycle policy to automatically delete the images which were not pulled for 60 days? If no, what is the best practice for this, what you use? Thanks!
data:image/s3,"s3://crabby-images/d3f60/d3f60f5d75781e7a4f243b6389efd39739791ca2" alt="Adi avatar"
data:image/s3,"s3://crabby-images/d3f60/d3f60f5d75781e7a4f243b6389efd39739791ca2" alt="Adi avatar"
imageCountMoreThan
data:image/s3,"s3://crabby-images/7576c/7576ce206191811f7c2a5ceeca2f0b7f341e215f" alt="Emi avatar"
IMPORTANT ADVICE
We’ve got critical information about changes to Amazon Elastic #Kubernetes Service that directly impact your costs. Read on to make sure you’re in the know Starting April 1, 2024, Amazon EKS will implement a pricing shift for clusters running on a #Kubernetes version in extended support. Brace yourself for a significant increase to $0.60 per cluster per hour. Yes, you read it right - *an increase from the current $0.10 per hour.*
Take Action Now - optimize your infrastructure: Head to our GitHub page ASAP to explore strategies for optimizing your EKS versions and mitigating these increased costs.
Update EKS versions to sidestep extended support charges https://lnkd.in/dBRFsr_7
Spread the word: Share this update with your network! Please let your peers know about the impending pricing shift, and together, let’s go through these changes as a community.
Important update for #AWS #EKS Users
We've got critical information about changes to Amazon Elastic #Kubernetes Service that directly impact your costs.…
data:image/s3,"s3://crabby-images/434ad/434ad5d4ce45ff4fb4a8c20300aa34eee68db7d3" alt="Sami avatar"
Hey all. I’m working to design a new AWS architecture for my current company to transition to. We’re in a bit of a growth stage so I want to design something that will be flexible for future use but also not overly complicated for the time being due to deadlines and a smaller team.
I’m hoping to get some feedback the AWS organisations. The current design I have is laid out to segregate production and non-production workloads. I specifically want to create a sandbox space for developers to utilise so they can create resources during their research and development stages.
I’m curious if people segregate their organisations into environments like production, staging, etc or by workloads and what might be some trade offs between?
data:image/s3,"s3://crabby-images/170b9/170b94e2f5912b6e1c9edf23935eab9f11298354" alt="Chris Wahl avatar"
For domain-driven design type environments, I prefer the approach similar to yours to avoid management sprawl. Top level OUs for core services (shared services), security, sandbox, prod, non-prod. I also like a suspended OU and migrated OU for future inbound/invited accounts from other sources. SCPs are generally well-defined in their scope to work with these OUs.
data:image/s3,"s3://crabby-images/434ad/434ad5d4ce45ff4fb4a8c20300aa34eee68db7d3" alt="Sami avatar"
Thanks for your reply Chris. When you talk about core services are you referring to creating accounts that manage resources like VPC’s and Route53 across the entire organisation?
I’ve modified my diagram a bit to include some other OUs and accounts but I’m starting to fall down the rabbit hole and can feel the complexity rolling in. I’ll have all of this managed through Terraform and provisioned through pipelines so I’m hoping the management won’t be overly complicated but I’m hoping to keep this as simple as I can.
Any thoughts on the new diagram would be greatly appreciated.
P.s. I’ve read a few of your articles on your website. Lots of great information there.
data:image/s3,"s3://crabby-images/170b9/170b94e2f5912b6e1c9edf23935eab9f11298354" alt="Chris Wahl avatar"
Core services
• network account hosting the transit gateway and ingress/egress controls
• shared services account hosting managed services available to everyone (e.g. CI/CD, code scan tools, dashboard tools)
• anything else that should be ubiquitously available to your tenants (think managed services) I prefer to use 1 account : 1 domain/app with a vending machine that builds the landing zones for each. I usually build a lightweight python SDK that pipelines use to dynamically build out the terraform backend code to do this, then save the artifacts for later tshooting/sbom type needs.
The vending machine has 2 contracts:
• a platform contract of infra needed to plug into the landing zone (tgw, attachments, ipam, vpc, state bucket)
• a service contract of infra needed to supply (e.g. cognito, database(s), buckets for data loads/exfil) Metadata created from the vending process is used downstream and saved in a location of your choice (param store, vault, dynamo, etc.)
data:image/s3,"s3://crabby-images/170b9/170b94e2f5912b6e1c9edf23935eab9f11298354" alt="Chris Wahl avatar"
I’m also typically in GovCloud environments which has no method of automatically vending AWS accounts, so I’m having to request & provision (bring into control tower) the accounts through a manual approval process. much easier in commercial cloud.
data:image/s3,"s3://crabby-images/170b9/170b94e2f5912b6e1c9edf23935eab9f11298354" alt="Chris Wahl avatar"
I also just realized there’s a typo on my first diagram, the bottom backend account should be DEV not TEST
data:image/s3,"s3://crabby-images/434ad/434ad5d4ce45ff4fb4a8c20300aa34eee68db7d3" alt="Sami avatar"
I like your ideas around the contracts and vending machine. I hadn’t specifically thought about the management of new project accounts so that’s valuable.
It almost makes me want to remove the project-based account structure all together to simplify management of everything, but I’ll see if I can come up with something to manage it. I have to find a balance as I’ll be the only one working on this while educating the team as I go, so if I can abstract as much as I can I will
This is some excellent information though Chris, I appreciate you passing it on.
data:image/s3,"s3://crabby-images/434ad/434ad5d4ce45ff4fb4a8c20300aa34eee68db7d3" alt="Sami avatar"
2024-01-23
2024-01-24
data:image/s3,"s3://crabby-images/36b0b/36b0b350cf153b8d3aeb9a6ec52f70b1167bac8d" alt="Juan Pablo Lorier avatar"
Hi, I’m trying to set the min and max capacity for an ecs service but I can’t find how to do it in the terraform-aws-ecs-alb-service-task module. Anyone can point me where to look? Thanks
Terraform module which implements an ECS service which exposes a web service via ALB.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
https://docs.aws.amazon.com/AmazonECS/latest/developerguide/cluster-capacity-providers.html
https://github.com/cloudposse/terraform-aws-ecs-alb-service-task/blob/main/variables.tf#L398
see the above ^
Amazon ECS capacity providers manage the scaling of infrastructure for tasks in your clusters. Each cluster can have one or more capacity providers and an optional capacity provider strategy.
variable "capacity_provider_strategies" {
data:image/s3,"s3://crabby-images/36b0b/36b0b350cf153b8d3aeb9a6ec52f70b1167bac8d" alt="Juan Pablo Lorier avatar"
Hi @Andriy Knysh (Cloud Posse) Thanks for your reply. I’m not sure we are talking of the same thing. I’m looking a way to control the min and max count of tasks in the service. This is the cloud formation reference:
Type: AWS::ScalableTarget Properties: RoleARN: !GetAtt AutoScalingRole.Arn MaxCapacity: 16 MinCapacity: 2
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i’m not sure how it’s related to the CloudFormation reference, but maybe this will help:
https://github.com/cloudposse/terraform-aws-ecs-alb-service-task/blob/main/main.tf#L369
https://github.com/cloudposse/terraform-aws-ecs-web-app/blob/main/main.tf#L174
https://github.com/cloudposse/terraform-aws-ecs-web-app/blob/main/examples/complete/main.tf
2024-01-25
2024-01-29
data:image/s3,"s3://crabby-images/46964/4696496b5c47ebf673adc4c491d8c9130b492350" alt="Sean avatar"
Hello, I am working to transition to a multi-account aws architecture and have been considering using atmos instead of a DIY solution. It seems I need to create a tfstate-backend > account > accountmap & the use of a workflow might be best since docs say account must be provisioned prior to account map. Is my understanding correct ? What is needed to access the cold start
document that I see referenced in some docs ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
What is needed to access the cold start
document that I see referenced in some docs ?
This is what we sell as our Bootcamp.
2024-01-30
data:image/s3,"s3://crabby-images/4331b/4331ba579b870f2994f5da05f6a111820eba2630" alt="j l avatar"
Hi, is there something to consider when configuring a socket.io multi-instance server behind an ALB from EKS using alb controller? So far I have set cookie sickness, duration and host header preservation but doesn’t seem to be enough.Does anybody has experience with this kind of setup? Thanks
data:image/s3,"s3://crabby-images/6153d/6153d2edef856aef90062c1b41d17154c31753dd" alt="venkata.mutyala avatar"
If this is for web sockets, I think you need to keep the connection alive. Are you losing it after 60 seconds or what’s happening?
data:image/s3,"s3://crabby-images/4331b/4331ba579b870f2994f5da05f6a111820eba2630" alt="j l avatar"
Actually I get this error when connecting to it {"code":1,"message":"Session ID unknown"}
so I think the connection not is even being established at first place, thanks for your reply!
data:image/s3,"s3://crabby-images/6153d/6153d2edef856aef90062c1b41d17154c31753dd" alt="venkata.mutyala avatar"
I’m stuck on why a node.js app that was moved to an IIS7 server is now failing. I know IIS7 doesn’t support web sockets but my understanding was that socket.io would fall back to long polling if web
data:image/s3,"s3://crabby-images/6153d/6153d2edef856aef90062c1b41d17154c31753dd" alt="venkata.mutyala avatar"
Is the app sending the sticky session cookie?
data:image/s3,"s3://crabby-images/4331b/4331ba579b870f2994f5da05f6a111820eba2630" alt="j l avatar"
app relies on redis for sessions management
data:image/s3,"s3://crabby-images/6153d/6153d2edef856aef90062c1b41d17154c31753dd" alt="venkata.mutyala avatar"
In theory if you scaled down to 1 it should work and because state is stored in redis (assuming it’s a separate pod) you should be able to kill the app and it should continue to work because the state is in redis. Also, i assume the TTL is long enough for you to do all of this.
data:image/s3,"s3://crabby-images/6153d/6153d2edef856aef90062c1b41d17154c31753dd" alt="venkata.mutyala avatar"
If you are sure the state management is working as expected then feel free to ignore the above.
data:image/s3,"s3://crabby-images/4331b/4331ba579b870f2994f5da05f6a111820eba2630" alt="j l avatar"
actually that’s a very good point that I missed, it should work by having only 1 backend instance, that would be a good test/starting point before start trying to make it work with multiple instances
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
Hhello all. Anybody has issues with route53 dns entries?
data:image/s3,"s3://crabby-images/6153d/6153d2edef856aef90062c1b41d17154c31753dd" alt="venkata.mutyala avatar"
We use it in production. No issues that i know of right now. What are you noticing?
data:image/s3,"s3://crabby-images/2efb7/2efb729d31057594f332f9910b29bb3a356285a6" alt="Balazs Varga avatar"
Few dns servers could not eesolve one of our entry, but it looks it was error on our side.
data:image/s3,"s3://crabby-images/36b0b/36b0b350cf153b8d3aeb9a6ec52f70b1167bac8d" alt="Juan Pablo Lorier avatar"
Hi, is there a way to provide a custom name to resources without following the cloudposse construction for tenant, namespace, environment, etc? I need to customize alb, redis, ecs modules to adapt to a specific naming convention and I can’t find a way to force it but with the name tag that not always works
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
Can you provide an example? It is customisable via label_order
but you have to have at least one label.
data:image/s3,"s3://crabby-images/36b0b/36b0b350cf153b8d3aeb9a6ec52f70b1167bac8d" alt="Juan Pablo Lorier avatar"
from what I read I understand that labels are tags and not the name (I should look the code for the label module). What I need is for instance, pass a string as the ECS cluster name which can’t be done like that. I can pass a name that will be concatenated with the tenant, the namespace, the stage, etc. I tryed to setup the Name tag (it worked for the ALB module) but didn’t make it for the cluster name
data:image/s3,"s3://crabby-images/36b0b/36b0b350cf153b8d3aeb9a6ec52f70b1167bac8d" alt="Juan Pablo Lorier avatar"
For the ECS cluster, the name of the cluster is like this:
name = module.this.id
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
So you can do
label_order = [“name”]
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
I’m on mobile but I could provide a better example later if you need it
data:image/s3,"s3://crabby-images/36b0b/36b0b350cf153b8d3aeb9a6ec52f70b1167bac8d" alt="Juan Pablo Lorier avatar"
ok, I looked at the code and firs of all, you are right, labels are used to form the name. I will have to see how to modify the labels, order, etc for each resouce, but I think I can achieve what I need.
data:image/s3,"s3://crabby-images/36b0b/36b0b350cf153b8d3aeb9a6ec52f70b1167bac8d" alt="Juan Pablo Lorier avatar"
Yes, module.this.label_order = [“name”] will do. Sorry I didn’t understand that when I read the documentation and it was clear when I saw the code. Thanks for the reply
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
is there a way to provide a custom name to resources without following the cloudposse construction for tenant, namespace, environment,
Also, just to call out, all parameters are optional.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So if you don’t want to use our conventions, just do as @Joe Niland alluded to, which is commandeer name for everything.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but also, good to be familiar with this https://masterpoint.io/updates/terraform-null-label/
data:image/s3,"s3://crabby-images/2d41b/2d41bdf79e6c93076fda84df34c5d48a1c1529f5" alt="attachment image"
A post highlighting one of our favorite terraform modules: terraform-null-label. We dive into what it is, why it’s great, and some potential use cases in …
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Later on this year, we hope to introduce support for arbitrary naming conventions
data:image/s3,"s3://crabby-images/36b0b/36b0b350cf153b8d3aeb9a6ec52f70b1167bac8d" alt="Juan Pablo Lorier avatar"
thanks @Erik Osterman (Cloud Posse) I’ve found Cloudposse module very useful and though some times I can’t figure how to use them propely, they I find that they can adapt to mostly every scenario. Thanks for your reply.