Stacktape

Sign up



Packaging

Packaging Lambda functions

Stacktape-lambda-buildpack

  • Built-in, zero-config, heavily optimized buildpack that creates a lambda artifact from an entryfile path
  • Currently supported languages are: Javascript, Typescript, Python, Java and Go.
  • Your deployment packages are cached. Stacktape creates a digest (checksum) from all the necessary files (and your package manager lockfiles). If a workload with the same digest is already deployed, the packaging and deployment is skipped.
  • Lambda function packages are zipped and uploaded to a pre-created S3 bucket.
  • The upload uses S3 transfer acceleration - upload is done to the nearest AWS's edge location, and then routed to the bucket using an Amazon backbone network. This is faster and more secure, but incurs additional transfer costs ($0.04 per GB). To disable this behavior, set (config).deploymentConfig.useS3TransferAcceleration to false.

Copy

resources:
myLambda:
type: function
properties:
packaging:
type: stacktape-lambda-buildpack
properties:
entryfilePath: path/to/my-lambda.ts
timeout: 10
memory: 2048

Example function using stacktape-lambda-buildpack packaging

Javascript and Typescript

  • Your source code is built into a single file with all of its external dependencies. This ensures you are shipping only the minimum required code. Behind the scenes, Stacktape uses esbuild.
  • Source-maps are automatically generated and includes in your deployment package. The generated code also includes the source map support library to make them usable.
  • If your dependency uses dynamic require() and can't be statically built, it will be copied as-is instead.
  • If your dependency is dependent on a binary file, the dependency will be installed in a Docker container (based on the runtime used) and copied to the deployment package. This ensures your binary dependencies are usable even when deploying from a different OS (Windows or Mac).

Python

  • Your source code is packed into into a zip archive with all its defined dependencies using docker, so you don't need to have python installed for deployment.
  • Supported versions are 3.7, 3.8 and 3.9 (default).
  • Installing dependencies is supported using pip, pipenv or poetry.
  • If your source code dependencies are defined in non-standard file located outside root folder, you can specify it using packageManagerFile and packageManager in languageSpecificProperties.

Java

  • Your source code is packed into into a zip archive with all its defined dependencies using docker, so you don't need to have java installed for deployment.
  • Supported versions are 8, 11 (default).
  • Gradle (default) and Maven projects are supported.
  • If your project uses Maven, configure useMaven property in the languageSpecificProperties configuration. Stacktape will. convert your maven project to a gradle project and build it as a gradle project (which is 2-10x times faster than maven).

Go

  • Your source code is packed into into a zip archive with all its defined dependencies using docker, so you don't need to have go installed for deployment.
StpBuildpackLambdaPackaging  API reference
entryfilePath
Required
handlerFunction
includeFiles
excludeFiles
excludeDependencies
languageSpecificConfig

Custom-artifact

  • You supply a path to your own, pre-created artifact.
  • If the specified path is a directory or an un-zipped file, Stacktape will zip it.
  • The zipped lambda package is then uploaded to a pre-created S3 bucket using S3 transfer acceleration.
CustomArtifactLambdaPackaging  API reference
packagePath
Required
handler

Packaging containers

Applies to Web services, Private services, Worker services, Multi-container workloads and Batch jobs.

Stacktape-image-buildpack

  • Built-in, zero-config, heavily optimized buildpack that creates a runnable container image from your source-code.
  • Currently supported languages are: Javascript, Typescript, Python, Java and Go.
  • The image is uploaded to a pre-created (AWS ECR) container registry.

Javascript and Typescript

  • Your source code is built into a single file with all of its external dependencies. This ensures you are shipping only the minimum required code. Behind the scenes, Stacktape uses esbuild.
  • Source-maps are automatically generated and includes in your deployment package. The generated code also includes the source map support library to make them usable.
  • If your dependency uses dynamic require() and can't be statically built, it will be copied as-is instead.
  • If your dependency is dependent on a binary file, the dependency will be installed in a Docker container using a Docker multi-stage build.
  • The base image used is the latest LTS version of node.js.
    • node:18-alpine in case your app doesn't require glibc-based binaries.
    • node:18 in case it does.

Python

  • Your source code is copied to docker container with all its defined dependencies.
  • Supported versions are 3.7, 3.8 and 3.9 (default).
  • Installing dependencies is supported using pip, pipenv or poetry
  • If your source code dependencies are defined in non-standard file located outside root folder, you can specify it using packageManagerFile and packageManager in languageSpecificProperties
  • Base image used:
    • public.ecr.aws/docker/library/python:${pythonVersion}-alpine in case your app doesn't require glibc-based binaries.
    • public.ecr.aws/docker/library/python:${pythonVersion} in case it does.

Java

  • Your source code is copied to docker container with all its defined dependencies.
  • Supported versions are 8, 11 (default).
  • Gradle (default) and maven projects are supported.
  • If your project uses Maven, configure useMaven property in the languageSpecificProperties configuration. Stacktape will convert your maven project to a gradle project and build it as a gradle project (which is 2-10x times faster than maven).
  • Base image used:
    • public.ecr.aws/docker/library/gradle:7.5.1-jdk${javaVersion}-alpine in case your app doesn't require glibc-based binaries.
    • public.ecr.aws/docker/library/gradle:7.5.1-jdk${javaVersion} in case it does.

Go

  • Your source code is copied to docker container with all its defined dependencies.
  • Base image used:
    • public.ecr.aws/docker/library/golang-alpine in case your app doesn't require glibc-based binaries.
    • public.ecr.aws/docker/library/golang in case it does.
StpBuildpackCwImagePackaging  API reference
entryfilePath
Required
languageSpecificConfig
requiresGlibcBinaries
customDockerBuildCommands
includeFiles
excludeFiles
excludeDependencies

Copy

resources:
webService:
type: web-service
properties:
packaging:
type: stacktape-image-buildpack
properties:
entryfilePath: src/main.ts
resources:
cpu: 2
memory: 2048

External-buildpack

  • The image is built using a zero-config external buildpack.
  • You can find a buildpack for almost any language or framework. The default buildpack used is paketobuildpacks/builder:base. You can configure the buildpack used by specifying the buildpack property.
  • The buildpack works by scanning the specified source directory and automatically determining how the build the image for a given application.
  • The image is uploaded to a pre-created (AWS ECR) container registry.
ExternalBuildpackCwImagePackaging  API reference
sourceDirectoryPath
Required
builder
Default: paketobuildpacks/builder-jammy-base
buildpacks
command

Copy

resources:
webService:
type: web-service
properties:
packaging:
type: external-buildpack
properties:
sourceDirectoryPath: ./src
builder: heroku/buildpacks:20
resources:
cpu: 2
memory: 2048

Custom-dockerfile

  • The image is built from your own Dockerfile.
  • You need to configure buildContextPath. Stacktape will look for a Dockerfile in this directory (or use a Dockerfile specified by dockerfilePath).
  • The image is uploaded to a pre-created (AWS ECR) container registry.
CustomDockerfileCwImagePackaging  API reference
buildContextPath
Required
entryPoint
dockerfilePath
buildArgs
command

Copy

resources:
webService:
type: web-service
properties:
packaging:
type: custom-dockerfile
properties:
buildContextPath: ./server
dockerfilePath: Dockerfile
resources:
cpu: 2
memory: 2048

Prebuilt-image

  • Pre-built image is used.
  • To use private images, you need to configure repositoryCredentialsSecretArn. The body of the secret should have the following format: {"username" : "<<privateRegistryUsername>>", "password" : "<<privateRegistryPassword>>"}. Secrets can be managed directly using Stacktape. For more information, refer to secrets docs.
PrebuiltImageCwPackaging  API reference
image
Required
repositoryCredentialsSecretArn
entryPoint
command

Copy

resources:
webService:
type: web-service
properties:
packaging:
type: prebuilt-image
properties:
image: httpd:latest
resources:
cpu: 2
memory: 2048

API reference

DockerBuildArg  API reference
argName
Required
value
Required
EsLanguageSpecificConfig  API reference
tsConfigPath
emitTsDecoratorMetadata
dependenciesToExcludeFromBundle
outputModuleFormat
Default: 'cjs'
PyLanguageSpecificConfig  API reference
packageManagerFile
packageManager
pythonVersion
runAppAs
JavaLanguageSpecificConfig  API reference
useMaven
packageManagerFile
javaVersion

Need help? Ask a question on Discord or info@stacktape.com.