-
Notifications
You must be signed in to change notification settings - Fork 284
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
7 changed files
with
235 additions
and
7 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,143 @@ | ||
# Builds aztec image quickly, bootstrapping from S3 cache. | ||
# TODO: Implement fallback to a normal build when cache is unavailable. | ||
# Currently optimized for 'yarn-project' oriented workflow. | ||
# If other components are iterated on, this will still work if a PR pushes to cache, or earthly-local is tweaked to push to cache and the component built. | ||
|
||
# Use an ARG to define the architecture, defaulting to amd64 | ||
ARG ARCH=amd64 | ||
|
||
# Set the base image based on the architecture | ||
FROM aztecprotocol/build:1.0-${ARCH} | ||
|
||
# Set the working directory | ||
WORKDIR /usr/src | ||
|
||
# Initialize git repository for computing content hash | ||
RUN git init -b master \ | ||
&& git config --global gc.auto 0 \ | ||
&& git add . \ | ||
&& git config user.name 'AztecBot' \ | ||
&& git config user.email 'tech@aztecprotocol.com' | ||
|
||
# ---------- EXTRACT BUILD-SYSTEM ---------- | ||
COPY build-system.tar.gz . | ||
RUN tar -xzf build-system.tar.gz \ | ||
&& rm build-system.tar.gz && git add . \ | ||
&& git commit -m "Update git metadata" >/dev/null | ||
|
||
# ---------- BUILD BARRETENBERG ---------- | ||
COPY barretenberg.tar.gz . | ||
RUN tar -xzf barretenberg.tar.gz \ | ||
&& rm barretenberg.tar.gz && git add . \ | ||
&& git commit -m "Update git metadata" >/dev/null | ||
|
||
# Bootstrap cache for barretenberg/cpp | ||
RUN --mount=type=secret,id=aws_access_key_id \ | ||
--mount=type=secret,id=aws_secret_access_key \ | ||
cd barretenberg/cpp \ | ||
&& AWS_ACCESS_KEY_ID=$(cat /run/secrets/aws_access_key_id) \ | ||
AWS_SECRET_ACCESS_KEY=$(cat /run/secrets/aws_secret_access_key) \ | ||
./bootstrap_cache.sh \ | ||
&& echo "barretenberg/cpp: Success" | ||
|
||
# Bootstrap cache for barretenberg/ts | ||
RUN --mount=type=secret,id=aws_access_key_id \ | ||
--mount=type=secret,id=aws_secret_access_key \ | ||
cd barretenberg/ts \ | ||
&& AWS_ACCESS_KEY_ID=$(cat /run/secrets/aws_access_key_id) \ | ||
AWS_SECRET_ACCESS_KEY=$(cat /run/secrets/aws_secret_access_key) \ | ||
./bootstrap_cache.sh \ | ||
&& echo "barretenberg/ts: Success" | ||
|
||
# ---------- BUILD NOIR ---------- | ||
COPY noir.tar.gz . | ||
RUN tar -xzf noir.tar.gz \ | ||
&& rm noir.tar.gz && git add . \ | ||
&& git commit -m "Update git metadata" >/dev/null | ||
|
||
# Bootstrap cache for Noir | ||
RUN --mount=type=secret,id=aws_access_key_id \ | ||
--mount=type=secret,id=aws_secret_access_key \ | ||
cd noir \ | ||
&& AWS_ACCESS_KEY_ID=$(cat /run/secrets/aws_access_key_id) \ | ||
AWS_SECRET_ACCESS_KEY=$(cat /run/secrets/aws_secret_access_key) \ | ||
./bootstrap_cache.sh \ | ||
&& echo "noir: Success" | ||
|
||
# ---------- BUILD L1 CONTRACTS ---------- | ||
COPY l1-contracts.tar.gz . | ||
RUN tar -xzf l1-contracts.tar.gz \ | ||
&& rm l1-contracts.tar.gz && git add . \ | ||
&& git commit -m "Update git metadata" >/dev/null | ||
|
||
# Bootstrap cache for L1 Contracts | ||
RUN --mount=type=secret,id=aws_access_key_id \ | ||
--mount=type=secret,id=aws_secret_access_key \ | ||
cd l1-contracts \ | ||
&& AWS_ACCESS_KEY_ID=$(cat /run/secrets/aws_access_key_id) \ | ||
AWS_SECRET_ACCESS_KEY=$(cat /run/secrets/aws_secret_access_key) \ | ||
./bootstrap_cache.sh \ | ||
&& echo "l1-contracts: Success" | ||
|
||
# ---------- BUILD AVM TRANSPILER ---------- | ||
COPY avm-transpiler.tar.gz . | ||
RUN tar -xzf avm-transpiler.tar.gz \ | ||
&& rm avm-transpiler.tar.gz && git add . \ | ||
&& git commit -m "Update git metadata" >/dev/null | ||
|
||
# Bootstrap cache for AVM Transpiler | ||
RUN --mount=type=secret,id=aws_access_key_id \ | ||
--mount=type=secret,id=aws_secret_access_key \ | ||
cd avm-transpiler \ | ||
&& AWS_ACCESS_KEY_ID=$(cat /run/secrets/aws_access_key_id) \ | ||
AWS_SECRET_ACCESS_KEY=$(cat /run/secrets/aws_secret_access_key) \ | ||
./bootstrap_cache.sh \ | ||
&& echo "avm-transpiler: Success" | ||
|
||
# ---------- BUILD NOIR PROJECTS ---------- | ||
COPY noir-projects.tar.gz . | ||
RUN tar -xzf noir-projects.tar.gz \ | ||
&& rm noir-projects.tar.gz && git add . \ | ||
&& git commit -m "Update git metadata" >/dev/null | ||
|
||
# Bootstrap cache for Noir Projects | ||
RUN --mount=type=secret,id=aws_access_key_id \ | ||
--mount=type=secret,id=aws_secret_access_key \ | ||
cd noir-projects \ | ||
&& AWS_ACCESS_KEY_ID=$(cat /run/secrets/aws_access_key_id) \ | ||
AWS_SECRET_ACCESS_KEY=$(cat /run/secrets/aws_secret_access_key) \ | ||
./bootstrap_cache.sh \ | ||
&& echo "noir-projects: Success" | ||
|
||
# ---------- BUILD YARN PROJECT ---------- | ||
COPY yarn-project.tar.gz . | ||
RUN tar -xzf yarn-project.tar.gz \ | ||
&& rm yarn-project.tar.gz && git add . \ | ||
&& git commit -m "Update git metadata" >/dev/null | ||
|
||
# Build yarn-project directly (no cache script) | ||
RUN cd yarn-project \ | ||
&& ./bootstrap.sh fast-only \ | ||
&& echo "yarn-project: Success" | ||
|
||
# ---------- SETUP ENVIRONMENT VARIABLES ---------- | ||
ENV BB_WORKING_DIRECTORY=/usr/src/bb | ||
ENV BB_BINARY_PATH=/usr/src/barretenberg/cpp/build/bin/bb | ||
ENV ACVM_WORKING_DIRECTORY=/usr/src/acvm | ||
ENV ACVM_BINARY_PATH=/usr/src/noir/noir-repo/target/release/acvm | ||
ENV PORT=8080 | ||
|
||
# Create necessary directories | ||
RUN mkdir -p $BB_WORKING_DIRECTORY \ | ||
$ACVM_WORKING_DIRECTORY \ | ||
/usr/src/yarn-project/world-state/build | ||
|
||
# Set the entrypoint | ||
ENTRYPOINT ["node", "--no-warnings", "/usr/src/yarn-project/aztec/dest/bin/index.js"] | ||
|
||
# Healthcheck configuration | ||
HEALTHCHECK --interval=10s --timeout=10s --retries=6 --start-period=120s \ | ||
CMD curl -fsS http://127.0.0.1:$PORT/status | ||
|
||
# Expose port 8080 | ||
EXPOSE 8080 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,79 @@ | ||
#!/usr/bin/env bash | ||
# TODO eventually rename this docker.sh when we've moved to it entirely | ||
set -eux | ||
|
||
function start_minio() { | ||
if nc -z 127.0.0.1 12000 2>/dev/null >/dev/null ; then | ||
# Already started | ||
return | ||
fi | ||
docker run -d -p 12000:9000 -p 12001:12001 -v minio-data:/data \ | ||
quay.io/minio/minio server /data --console-address ":12001" | ||
# Make our cache bucket | ||
AWS_ACCESS_KEY_ID="minioadmin" AWS_SECRET_ACCESS_KEY="minioadmin" aws --endpoint-url http://localhost:12000 s3 mb s3://aztec-ci-artifacts 2>/dev/null || true | ||
} | ||
|
||
S3_BUILD_CACHE_UPLOAD=${S3_BUILD_CACHE_UPLOAD:-false} | ||
S3_BUILD_CACHE_MINIO_URL="http://$(hostname -I | awk '{print $1}'):12000" | ||
|
||
# Start local file server for a quicker cache layer | ||
start_minio | ||
|
||
if ! git diff-index --quiet HEAD --; then | ||
echo "Warning: You have unstaged changes. Disabling S3 caching and local MinIO caching to avoid polluting cache (which uses Git data)." >&2 | ||
S3_BUILD_CACHE_UPLOAD=false | ||
S3_BUILD_CACHE_DOWNLOAD=false | ||
S3_BUILD_CACHE_MINIO_URL="" | ||
echo "Fatal: For now, this is a fatal error as it would defeat the purpose of 'fast'." >&2 | ||
exit 1 | ||
elif [ ! -z "${AWS_ACCESS_KEY_ID:-}" ] ; then | ||
S3_BUILD_CACHE_DOWNLOAD=true | ||
elif [ -f ~/.aws/credentials ]; then | ||
# Retrieve credentials if available in AWS config | ||
AWS_ACCESS_KEY_ID=$(aws configure get default.aws_access_key_id) | ||
AWS_SECRET_ACCESS_KEY=$(aws configure get default.aws_secret_access_key) | ||
S3_BUILD_CACHE_DOWNLOAD=true | ||
else | ||
S3_BUILD_CACHE_UPLOAD=false | ||
S3_BUILD_CACHE_DOWNLOAD=false | ||
fi | ||
|
||
TMP=$(mktemp -d) | ||
|
||
function on_exit() { | ||
rm -rf "$TMP" | ||
} | ||
trap on_exit EXIT | ||
|
||
# Save each secret environment variable into a separate file in $TMP directory | ||
echo "${AWS_ACCESS_KEY_ID:-}" > "$TMP/aws_access_key_id.txt" | ||
echo "${AWS_SECRET_ACCESS_KEY:-}" > "$TMP/aws_secret_access_key.txt" | ||
echo "${S3_BUILD_CACHE_MINIO_URL:-}" > "$TMP/s3_build_cache_minio_url.txt" | ||
echo "${S3_BUILD_CACHE_UPLOAD:-}" > "$TMP/s3_build_cache_upload.txt" | ||
echo "${S3_BUILD_CACHE_DOWNLOAD:-}" > "$TMP/s3_build_cache_download.txt" | ||
|
||
cd $(git rev-parse --show-toplevel) | ||
|
||
PROJECTS=( | ||
barretenberg | ||
build-system | ||
noir | ||
l1-contracts | ||
avm-transpiler | ||
noir-projects | ||
yarn-project | ||
) | ||
|
||
for project in "${PROJECTS[@]}"; do | ||
# Archive Git-tracked files per project into a tar.gz file | ||
git archive --format=tar.gz -o "$TMP/$project.tar.gz" HEAD $project | ||
done | ||
|
||
# Run Docker build with secrets in the folder with our archive | ||
DOCKER_BUILDKIT=1 docker build -t aztecprotocol/aztec -f Dockerfile.fast --progress=plain \ | ||
--secret id=aws_access_key_id,src=$TMP/aws_access_key_id.txt \ | ||
--secret id=aws_secret_access_key,src=$TMP/aws_secret_access_key.txt \ | ||
--secret id=s3_build_cache_minio_url,src=$TMP/s3_build_cache_minio_url.txt \ | ||
--secret id=s3_build_cache_upload,src=$TMP/s3_build_cache_upload.txt \ | ||
--secret id=s3_build_cache_download,src=$TMP/s3_build_cache_download.txt \ | ||
"$TMP" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters