Project Name | Stars | Downloads | Repos Using This | Packages Using This | Most Recent Commit | Total Releases | Latest Release | Open Issues | License | Language |
---|---|---|---|---|---|---|---|---|---|---|
Aws Lambda Power Tuning | 4,648 | 2 months ago | 8 | apache-2.0 | JavaScript | |||||
AWS Lambda Power Tuning is an open-source tool that can help you visualize and fine-tune the memory/power configuration of Lambda functions. It runs in your own AWS account - powered by AWS Step Functions - and it supports three optimization strategies: cost, speed, and balanced. | ||||||||||
Flaml | 2,868 | 8 | 2 days ago | 88 | August 15, 2023 | 200 | mit | Jupyter Notebook | ||
A fast library for AutoML and tuning. Join our Discord: https://discord.gg/Cppx2vSPVP. | ||||||||||
Aws Power Tuner Ui | 134 | 10 months ago | 14 | apache-2.0 | TypeScript | |||||
AWS Lambda Power Tuner UI is an open source project creating a deployable easy to use website built on a layered technology stack allowing you to optimize your Lambda functions for cost and/or performance in a data-driven way via an easy to use UI. | ||||||||||
Nodal.jl | 25 | 5 years ago | December 04, 2017 | 6 | other | Julia | ||||
NODAL is an Open Distributed Autotuning Library in Julia | ||||||||||
Stochasticsearch.jl | 1 | 7 years ago | other | Julia | ||||||
Julia package mirror. |
AWS Lambda Power Tuning is a state machine powered by AWS Step Functions that helps you optimize your Lambda functions for cost and/or performance in a data-driven way.
The state machine is designed to be easy to deploy and fast to execute. Also, it's language agnostic so you can optimize any Lambda functions in your account.
Basically, you can provide a Lambda function ARN as input and the state machine will invoke that function with multiple power configurations (from 128MB to 10GB, you decide which values). Then it will analyze all the execution logs and suggest you the best power configuration to minimize cost and/or maximize performance.
Please note that the input function will be executed in your AWS account - performing real HTTP requests, SDK calls, cold starts, etc. The state machine also supports cross-region invocations and you can enable parallel execution to generate results in just a few seconds.
It's pretty simple and you can visually inspect each step in the AWS management console.
The state machine will generate a visualization of average cost and speed for each power configuration.
For example, this is what the results look like for two CPU-intensive functions, which become cheaper AND faster with more power:
How to interpret the chart above: execution time goes from 35s with 128MB to less than 3s with 1.5GB, while being 14% cheaper to run.
How to interpret the chart above: execution time goes from 2.4s with 128MB to 300ms with 1GB, for the very same average cost.
There are a few options documented here.
You can execute the state machine manually or programmatically, see the documentation here.
Here's a typical execution input with basic parameters:
{
"lambdaARN": "your-lambda-function-arn",
"powerValues": [128, 256, 512, 1024],
"num": 50,
"payload": {}
}
Full input documentation here.
The state machine output will look like this:
{
"results": {
"power": "128",
"cost": 0.0000002083,
"duration": 2.906,
"stateMachine": {
"executionCost": 0.00045,
"lambdaCost": 0.0005252,
"visualization": "https://lambda-power-tuning.show/#<encoded_data>"
}
}
}
Full output documentation here.
You can visually inspect the tuning results to identify the optimal tradeoff between cost and performance.
The data visualization tool has been built by the community: it's a static website deployed via AWS Amplify Console and it's free to use. If you don't want to use the visualization tool, you can simply ignore the visualization URL provided in the execution output. No data is ever shared or stored by this tool.
Website repository: matteo-ronchetti/aws-lambda-power-tuning-ui
Optionally, you could deploy your own custom visualization tool and configure the CloudFormation Parameter named visualizationURL
with your own URL.
Lambda Power Tuner UI is a web interface to simplify the deployment and execution of Lambda Power Tuning. It's built and maintained by Matthew Dorrian and it aims at providing a consistent interface and a uniform developer experience across teams and projects.
Power Tuner UI repository: mattymoomoo/aws-power-tuner-ui
Here you can find out more about some advanced features of this project, its internals, and some considerations about security and execution cost.
From most recent to oldest, with major releases in bold:
Feature requests and pull requests are more than welcome!
For this repository, install dev dependencies with npm install
. You can run tests with npm test
, linting with npm run lint
, and coverage with npm run coverage
. Travis will automatically run the test suite on every commit and PR.