package and zip lambdas then run terraform.
Project description
spin-and-heave
Spin & Heave uses the lambdaci docker image to package and zip a lambda package.
If you do not already have the docker image, docker will attempt to download it.
After this is done, S&H will run terraform apply
(can be skipped with a flag).
With null resources, etags, triggers, and source code hashes, it almost feels like you could use terraform as an end-to-end deployment tool for lambda. You could make a change to your function code, and when you ran apply terraform would spot the change in the hash or etag, and everything (including your infrastructure) would update accordingly. To it's credit, you can almost get it working with just pure terraform. But as my friend Gus said, "when you first get a hammer everything looks like a nail." and Terraform isn't an all powerful hammer for deployment and everything. For example, it shouldn't be used to create build artifacts, as apparentlymart makes clear in several git issues.
Spin & Heave is one solution (of many). Instead of running terraform apply
and using null resources to build and zip, I use S&H, which leverages docker to
build and zip everything, then apply changes in terraform. My terraform code simply
refers to the zip S&H created. If the zip has changed terraform will upload a new
zip to either lambda, or s3, and then redeploy the lambda function.
flags
positional arguments:
source the directory with your lambda code in it
$ spin-and-heave lambda
where `lambda` is the dir including the python lambda code and requirements
for more information: https://gitlab.com/shindagger/spin-and-heave
optional arguments:
-h, --help show this help message and exit
-r RUNTIME, --runtime RUNTIME
optional. define a runtime.
defaults:
python: `python3.6`
nodejs: `nodejs10.x` with the --node [-js] flag
-bc BUILD, --build BUILD
optional. define a build command.
defaults:
python: `pip install --progress-bar off -r requirements.txt -t .`
nodejs: `npm install --production` with the --node [-js] flag
-x EXCLUDE, --exclude EXCLUDE
optional. exclude files and directories from the zip file.
uses zip command -x flag conventions.
example: `spin-and-heave lambda -x file.jpg -x docker/\*`
-js, --node deploy node.
-s, --skip skip terraform apply.
-i, --init init terraform before running apply.
-a, --approve run terraform apply with `auto-approve` flag
-v, --version show program's version number and exit
usage
$ spin-and-heave -h
show spin-and-heave help page.
$ spin-and-heave lambda_project
where "lambda_project" is the directory with your python lambda files. this will run the lambdaci docker image for the runtime python3.6 then save the zip file (in this case "lambda_project.zip") in your current working directory
$ spin-and-heave lambda_project -s
skip terraform apply
$ spin-and-heave lambda_project -ai
run terraform init before applying [-i], also run terraform apply with -auto-approve flag [-a]
useful for CI/CD
$ spin-and-heave lambda_project -js
spin and heave a node lambda package, defaults to nodejs10.x this will run "npm install --production" instead of "pip install"
$ spin-and-heave lambda_project -r python3.7
alternatively, use custom runtimes. The runtime you pick will use the lambdaci docker image with that runtime as a tag
NOTE: at this point any runtime besides node and python also require a build command.
$ spin-and-heave lambda_project -r ruby2.5 -bc "bundle install --deployment"
an example using ruby, which includes a build command.
NOTE: at this point any runtime besides node and python also
require a build command.
$ spin-and-heave lambda_project -js -x file.jpg -x docker/\*
spin and heave a node lambda package, excluding file.jpg and a directory called docker from the zip
for an example terraform/lambda setup to play with see:
https://gitlab.com/shindagger/spin-and-heave/tree/master/example
installation
$ pip install spin-and-heave
example
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file spin-and-heave-3.1.4.tar.gz
.
File metadata
- Download URL: spin-and-heave-3.1.4.tar.gz
- Upload date:
- Size: 6.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6284bd905060980bb8c0719a693cdd41d8d7565b1d4409a52babc170e5747c5b |
|
MD5 | 4e5939330fa85e62431003c2006901d4 |
|
BLAKE2b-256 | cb9ea8f43a1484025f93ffb0bb7deb8d08b19baf91831439480c24d73ed52bfd |
File details
Details for the file spin_and_heave-3.1.4-py3-none-any.whl
.
File metadata
- Download URL: spin_and_heave-3.1.4-py3-none-any.whl
- Upload date:
- Size: 10.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0e41d083ab082076d0084bd6c36802b62f11610ec75311cd2d19b795c2c923d9 |
|
MD5 | bb8e0a5c0f20c863ae0a3594f34c9ea2 |
|
BLAKE2b-256 | 967672b63f98f684c0d416ee0fb61fd8ba8e826c80f22b6747dde4ee93190805 |