-
Notifications
You must be signed in to change notification settings - Fork 122
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
Fix nodejs12 end of support on lambda + Improvement to the minecraft cloudwatch filter + 50% reducement in AWS cost #61
base: main
Are you sure you want to change the base?
Conversation
This fixes the nodejs12.x incompatibility on lambdas runtimes enviroment. This was caused by a peer dependency on aws-cdk-lib. Once updated this peer dependency the lambda now uses node14js.x which is supported by AWS.
877f480
to
7c0bd38
Compare
It's a nice push, only will break it. |
Thank you! The reason to that filter is to avoid DNS checkers, agents and other bots triggering the server. This causes the sever to be on most of the day, starting and stopping continuously. There is an issue of someone also noticing this: #45 In order to fix this, I changed this filter to a very particular filter that focus on filtering the SRV record, which usually is not used by bots but used by Minecraft when connecting or checking for the health of a server. This made that the run of the server was only being triggered by Minecraft clients and not other agents scanning the domain. For me it has been working like a charm for more than 4 months, with 0 issues. Why do you say it will break things? |
I tried it with minecraft java edition, and it doesn't seem to trigger the lambda function.. |
If you have deploy this pull request you also need to perform a manual change on Route53. Check that you have applied this: aa57f4f#diff-b0b0aa5ef277f2eeabb6b5f834c43d21584c4deaa2f5fe02748cf2dd1a3025d0R66 and that you are receiving logs for that specific hosted zone. Also check if you can see a log similar to this one on the log group (/aws/route53/[subdomain].[domain]), it should appear when you try to connect to the Minecraft server from the Minecraft client: |
Oooh, that makes a lot of sense, since the first part is the SRV Minecraft record. This means that it is even more robust, only accepting Minecraft SRV calls to boot the server up. Thanks a lot for the investigation, I think your suggested fix will work. Going to fix it. |
aa57f4f
to
91fd5a3
Compare
@Colduck ah nvm, you pushed the fix it seems, lol |
Yes! thanks a lot for the help @Rithmatist! Everything else worked fine? If you find any other suggestion please let me know! |
hmmm, yeah... I just checked and Minecraft Bedrock does not support SRV records for now: source I can make the change so this feature only applies to Minecraft Java servers then. |
Yeah, the ones of bedrock are like this: I am using geyser mc ^^ |
With this new filter only the DNS calls made by a minecraft client triggers the start of the minecraft server
Reduced the cost of the AWS bill by only using 1 hosted zone instead of 2. The cost is reduced from 1 eur month to 0.5 eur month with the same functionality and no regression.
91fd5a3
to
be97df1
Compare
oh that is nice, I did not know about that tool. It will still perform the SRV call when connecting to a Minecraft Java server no? I want to make sure this change works even for those users. |
to turn the server on, I think not.. :/ |
@Colduck got discord? atm I am rewriting some code so it will support multple servers. like different modpacks, but now it won't work as there can only be 1 log group for the route53 so I had to write a check for existing log group. (and use that one) edit: will push this fix tomorrow.. |
replace:
with:
Note, this would only work if your current log-group name is /aws/route53/logs.domainhere.com Edit: This isn't the right approach, as it will only allow two subscription filters per log group. I am currently working on revamping the Lambda function and modifying the subscription filter to work with wildcards. This will enable the Lambda function to decode the logs and determine which server to turn on. |
hey! Were you able to add support also for bedrock servers? If not we can just keep this improvement for java servers, since it is a big improvement in cost and server usage. |
7c0bd38 -> Fixed the nodejs12.x incompatibility on lambda runtime environment. This was caused by a peer dependency on aws-cdk-lib. Once updated this peer dependency the lambda now uses node14js.x which is supported by AWS. Amazon announcement about end of support for nodejs12
00e7825 -> Updated the cloudWatch filter to be more specific. With this new filter only the DNS calls made by a minecraft client triggers the start of the minecraft server. This removes the problem of other agents pinging the DNS and activating the server incurring in a bigger operative cost
aa57f4f -> Reduced to 50% the costs of AWS. Reduced the cost of the AWS bill by only using 1 hosted zone instead of 2. The cost is reduced from 1 eur month to 0.5 eur month with the same functionality and no regression: