This repository provides pre-built openssl artifacts for use by Kong Gateway.
Update the OpenSSL variable in the .env
file.
Use the most recent artifact that matches your CPU architecutre and OSTYPE from the Releases page or alternatively a docker image from the packages page.
For example
#!/usr/bin/env bash
arch=$(uname -m)
KONG_OPENSSL_VER="${KONG_OPENSSL_VER:-1.1.0}"
package_architecture=x86_64
if [ "$(arch)" == "aarch64" ]; then
package_architecture=aarch64
fi
curl --fail -sSLo openssl.tar.gz https://github.com/hutchic-org/kong-openssl/releases/download/$KONG_OPENSSL_VER/$package_architecture-$OSTYPE.tar.gz
tar -C /tmp/build -xvf openssl.tar.gz
The gcr.io docker tag naming setup is:
ghcr.io/hutchic-org/kong-openssl:${GITHUB_RELEASE}-${OSTYPE}
# Example gcr.io/hutchic-org/kong-openssl:1.1.4-linux-musl which is a multi-architecture image
ghcr.io/hutchic-org/kong-openssl:${GITHUB_RELEASE}-${ARCHITECTURE}-${OSTYPE}
# Example gcr.io/hutchic-org/kong-openssl:1.1.0-aarch64-linux-musl
ghcr.io/hutchic-org/kong-openssl:${GIT_SHA}-${ARCHITECTURE}-${OSTYPE}
# Example kong-openssl:sha-17a5f5f-aarch64-linux-gnu
ghcr.io/hutchic-org/kong-openssl:${OPENSSL_VERSION}-${ARCHITECTURE}-${OSTYPE}
# Example gcr.io/hutchic-org/kong-openssl:1.1.1s-x86_64-linux-musl
The OPENSSL_VERSION tag is available for convenience and it is mutable. If you use it please pin the SHA
Prerequisites:
- make
- docker w\ buildkit
# Set desired environment variables. If not set the below are the defaults when this document was written
ARCHITECTURE=x86_64
OSTYPE=linux-gnu
make build/package
Will result in a local docker image and the build result in the package
directory
The same result without make
ARCHITECTURE=x86_64
OSTYPE=linux-gnu
docker buildx build \
--build-arg ARCHITECTURE=$(ARCHITECTURE) \
--build-arg OSTYPE=$(OSTYPE) \
--build-arg OPENSSL_VERSION=$(OPENSSL_VERSION) \
--target=package \
-o package .
A similar result without docker
ARCHITECTURE=x86_64
OSTYPE=linux-gnu
./build.sh
ls -la /tmp/build
This will use your local compiler / linker so the result will not be equivalent to a docker build and there's a strong chance the result will not be compatible with all platforms we target for release