|
34 | 34 | # -- //test/... |
35 | 35 |
|
36 | 36 | # Update base image |
37 | | -ARG UBUNTU_VERSION=22.04 |
38 | | -FROM ubuntu:${UBUNTU_VERSION} as build |
39 | | -RUN apt update && apt upgrade -y |
40 | | -RUN apt autoremove -y |
| 37 | +ARG UBUNTU_VERSION=24.04 |
| 38 | +FROM ubuntu:${UBUNTU_VERSION} AS build |
41 | 39 |
|
42 | | -# Install Bazel deps |
43 | | -RUN apt install -y software-properties-common |
44 | | -RUN add-apt-repository ppa:openjdk-r/ppa |
45 | | -RUN apt install -y \ |
| 40 | +# Use bash for all RUN instructions |
| 41 | +SHELL ["/bin/bash", "-c"] |
| 42 | + |
| 43 | +# Consolidated system update/upgrade and autoremove |
| 44 | +RUN apt-get update && \ |
| 45 | + apt-get upgrade -y && \ |
| 46 | + apt-get autoremove -y && \ |
| 47 | + rm -rf /var/lib/apt/lists/* |
| 48 | + |
| 49 | +## All build dependencies for Bazel and ProxyWasm are listed in DEPS for clarity and maintainability. |
| 50 | +ARG DEPS="\ |
46 | 51 | build-essential \ |
| 52 | + clang \ |
| 53 | + curl \ |
| 54 | + git \ |
| 55 | + libssl-dev \ |
| 56 | + libstdc++6 \ |
| 57 | + libz-dev \ |
47 | 58 | openjdk-21-jdk \ |
48 | 59 | python3 \ |
49 | | - curl \ |
50 | | - zip \ |
51 | | - unzip |
| 60 | + unzip \ |
| 61 | + zip\ |
| 62 | +" |
| 63 | +# Install all build dependencies (no PPA needed on Ubuntu 24.04) |
| 64 | +RUN apt-get update && \ |
| 65 | + DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends $DEPS && \ |
| 66 | + rm -rf /var/lib/apt/lists/* |
52 | 67 |
|
53 | | -# Download Bazel source |
| 68 | +# Set working directory for Bazel build |
| 69 | +WORKDIR /root/bazel |
| 70 | + |
| 71 | + |
| 72 | +# Download Bazel source and remove zip immediately after extraction |
54 | 73 | ARG BAZEL_VERSION=7.7.1 |
55 | | -RUN cd ~ && mkdir bazel && cd bazel |
56 | | -RUN curl -LO https://github.com/bazelbuild/bazel/releases/download/${BAZEL_VERSION}/bazel-${BAZEL_VERSION}-dist.zip |
57 | | -RUN unzip -q bazel-${BAZEL_VERSION}-dist.zip |
| 74 | +RUN curl -LO https://github.com/bazelbuild/bazel/releases/download/${BAZEL_VERSION}/bazel-${BAZEL_VERSION}-dist.zip && \ |
| 75 | + unzip -q bazel-${BAZEL_VERSION}-dist.zip && \ |
| 76 | + rm -f bazel-${BAZEL_VERSION}-dist.zip |
58 | 77 |
|
59 | | -# Build Bazel |
60 | | -# NOTE: This step is flaky and frequently hangs for multiarch / buildx. |
61 | | -# If it takes more than 2 hours, restart the Docker build and try again. |
| 78 | +## Build Bazel and copy the binary |
| 79 | +# NOTE: This step is flaky and may hang for multiarch/buildx. |
| 80 | +# If it takes more than 2 hours, restart the Docker build. |
62 | 81 | ENV EXTRA_BAZEL_ARGS="--tool_java_runtime_version=local_jdk" |
63 | | -RUN bash ./compile.sh |
| 82 | +RUN ./compile.sh && \ |
| 83 | + mv /output/bazel /usr/bin/bazel && \ |
| 84 | + rm -rf /root/bazel |
64 | 85 |
|
65 | | -# Copy output to /usr/bin |
66 | | -RUN cp /output/bazel /usr/bin/bazel |
67 | | - |
68 | | -# Install ProxyWasm build deps |
69 | | -RUN apt install -y \ |
70 | | - git \ |
71 | | - python3-distutils \ |
72 | | - clang \ |
73 | | - libstdc++6 \ |
74 | | - libssl-dev \ |
75 | | - libz-dev |
| 86 | +# Ensure a valid working directory after build |
| 87 | +WORKDIR /root |
0 commit comments