-
Notifications
You must be signed in to change notification settings - Fork 4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
(aws-logs): allow prefixing auto-generated log group names #19353
Comments
Probably makes sense to expand this feature request to all physical names. |
We just ran into this too, as Datadog requires the |
Just ran into the issue of CDK appending to the single resource log policy that it is re-using for all CDK stags in the region, and it ran out of max size, but did add /aws/vendedlogs/ logs. However, I could not update the code quickly enough and incurred downtime until I figured out how to delete certain resources from the policy and issue a 'Put'. Going through code and updating log groups for resources will take time, this issue would help. |
We found a solution to generate safe physical names for a Log Group (with the /aws/vendedlogs/ prefix. You can read out our solution here. |
Experiencing as well |
This issue has received a significant amount of attention so we are automatically upgrading its priority. A member of the community will see the re-prioritization and provide an update on the issue. |
Experiencing as well |
We ran into this issue as well with AWS WAF logs, which require the LogGroup name to be prefixed with |
Description
It would be nice to retain the flexibility of the auto-generated log group names provided by CDK & CloudFormation while also being able to apply a prefix to work around certain restrictions, as described here.
Use Case
I've got a client who uses AWS Step Functions heavily. They ran into the resource policy size issue described here, so they needed to prefix their log groups with
/aws/vendedlogs/
to work around the problem.So, they're now providing an explicit log group name, like this:
However, like with most other constructs, it would be preferable to have the entropy of auto-generated names, instead of hard-coding a static name.
For example, this simple stack produces a log group with the name
CdkTestingStack-LogGroupF5B46931-PEAj1XoIi1Q5
:What we'd like to accomplish is easily producing a log group with the name
/aws/vendedlogs/CdkTestingStack-LogGroupF5B46931-PEAj1XoIi1Q5
. This way, we work around the resource policy limitation while retaining the auto-generated name.Proposed Solution
An easy backward-compatible way to introduce this behavior would be to add an optional
logGroupNamePrefix
parameter to the L2LogGroup
construct.For example:
would provide a log group with the name
/aws/vendedlogs/CdkTestingStack-LogGroupF5B46931-PEAj1XoIi1Q5
.It could also work with statically provided names, such as:
which would provide a log group with the name
/aws/vendedlogs/MyLogGroup
.Other information
Possible Workarounds
L1
LogGroup
Construct ModificationI considered reaching into the
CfnLogGroup
and using anFn::Join
to get this behavior without a CDK change. However, I think I'd also need to adjust thearn
property, since it's set in the constructor as well:aws-cdk/packages/@aws-cdk/aws-logs/lib/log-group.ts
Lines 392 to 420 in d91b2e2
That seemed a bit too fragile to be worthwhile.
Using the Physical Name Generator
I thought about using the
generatePhysicalName
method to recreate the autogenerated name. However, this seemed unsafe to do, since the function lives inpackages/@aws-cdk/core/lib/private/physical-name-generator.ts
. Theprivate
specifier makes me think twice about using it.L2 StateMachine Construct
Since creating a
StateMachine
through the console automatically prefixes log groups with/aws/vendedlogs
, it could be nice to also add this behavior to the L2 construct once the ability to provide aprefix
is added.Acknowledge
The text was updated successfully, but these errors were encountered: