|
|
@@ -1,32 +1,47 @@
|
|
|
FROM archlinux:latest
|
|
|
LABEL maintainer="Jeremy Zheng"
|
|
|
|
|
|
-RUN pacman-key --init
|
|
|
-RUN pacman -Sy --noconfirm archlinux-keyring
|
|
|
-RUN pacman-key --populate
|
|
|
-RUN pacman -Syu --noconfirm
|
|
|
-RUN pacman -S --needed --noconfirm base-devel aarch64-linux-gnu-gcc risc-v \
|
|
|
- bzip2 bzip3 p7zip unarchiver \
|
|
|
- vim git cmake thrift capnproto wget zsh man-db man-pages \
|
|
|
- pwgen sshpass openssl openssh rsync zip unzip tree tmux asciidoc doxygen cpio net-tools bind-tools \
|
|
|
- clang llvm lld lldb mold bison flex ninja bazel \
|
|
|
- imagemagick ffmpeg xorg-font-util \
|
|
|
- ansible ansible-lint \
|
|
|
- wqy-bitmapfont wqy-microhei wqy-zenhei \
|
|
|
- ttf-fira-code woff-fira-code woff2-fira-code \
|
|
|
- adobe-source-code-pro-fonts adobe-source-serif-fonts adobe-source-sans-fonts \
|
|
|
- adobe-source-han-serif-cn-fonts adobe-source-han-serif-hk-fonts adobe-source-han-serif-jp-fonts adobe-source-han-serif-kr-fonts adobe-source-han-serif-tw-fonts \
|
|
|
- adobe-source-han-sans-cn-fonts adobe-source-han-sans-hk-fonts adobe-source-han-sans-jp-fonts adobe-source-han-sans-kr-fonts adobe-source-han-sans-tw-fonts \
|
|
|
- ttf-dejavu nerd-fonts ttf-ubuntu-font-family \
|
|
|
- ttf-arphic-ukai ttf-arphic-uming \
|
|
|
- texlive texlive-lang graphviz pandoc \
|
|
|
- hspell nuspell libvoikko hunspell hunspell-en_us \
|
|
|
- xdebug php-fpm php-pgsql php-sqlite php-redis php-mongodb php-imagick php-gd php-intl php-enchant php-snmp php-tidy php-xsl php-sodium php-odbc php-pspell \
|
|
|
- dart haxe lua \
|
|
|
- erlang elixir rebar \
|
|
|
- jdk-openjdk libxcrypt-compat \
|
|
|
- nginx mariadb postgresql rabbitmq redis supervisor
|
|
|
-RUN pacman -Scc --noconfirm
|
|
|
+RUN pacman-key --init \
|
|
|
+ && pacman -Sy --noconfirm archlinux-keyring \
|
|
|
+ && pacman-key --populate \
|
|
|
+ && pacman -Syu --noconfirm
|
|
|
+
|
|
|
+RUN pacman bzip2 bzip3 p7zip unarchiver \
|
|
|
+ git subversion screen vim wget zsh man-db man-pages \
|
|
|
+ pwgen sshpass openssl openssh rsync zip unzip tree tmux asciidoc doxygen cpio net-tools bind-tools \
|
|
|
+ -S --needed --noconfirm && pacman -Scc --noconfirm
|
|
|
+RUN pacman imagemagick ffmpeg xorg-font-util \
|
|
|
+ pandoc graphviz \
|
|
|
+ hspell nuspell libvoikko hunspell hunspell-en_us \
|
|
|
+ -S --needed --noconfirm && pacman -Scc --noconfirm
|
|
|
+RUN pacman base-devel clang llvm lld lldb mold bison flex ninja bazel \
|
|
|
+ cmake thrift capnproto grpc flatbuffers \
|
|
|
+ -S --needed --noconfirm && pacman -Scc --noconfirm
|
|
|
+RUN pacman aarch64-linux-gnu-gcc risc-v \
|
|
|
+ -S --needed --noconfirm && pacman -Scc --noconfirm
|
|
|
+RUN pacman xdebug php-fpm php-pgsql php-sqlite php-redis php-mongodb php-imagick php-gd php-intl php-enchant php-snmp php-tidy php-xsl php-sodium php-odbc \
|
|
|
+ libxcrypt-compat \
|
|
|
+ -S --needed --noconfirm && pacman -Scc --noconfirm
|
|
|
+RUN pacman dart haxe lua erlang elixir jdk-openjdk \
|
|
|
+ -S --needed --noconfirm && pacman -Scc --noconfirm
|
|
|
+RUN pacman nginx mariadb postgresql rabbitmq redis supervisor \
|
|
|
+ ansible ansible-lint \
|
|
|
+ -S --needed --noconfirm && pacman -Scc --noconfirm
|
|
|
+RUN pacman wqy-bitmapfont wqy-microhei wqy-zenhei \
|
|
|
+ ttf-arphic-ukai ttf-arphic-uming \
|
|
|
+ ttf-fira-code woff-fira-code woff2-fira-code \
|
|
|
+ ttf-dejavu ttf-ubuntu-font-family \
|
|
|
+ adobe-source-code-pro-fonts adobe-source-serif-fonts adobe-source-sans-fonts \
|
|
|
+ adobe-source-han-serif-cn-fonts adobe-source-han-serif-hk-fonts adobe-source-han-serif-jp-fonts adobe-source-han-serif-kr-fonts adobe-source-han-serif-tw-fonts \
|
|
|
+ adobe-source-han-sans-cn-fonts adobe-source-han-sans-hk-fonts adobe-source-han-sans-jp-fonts adobe-source-han-sans-kr-fonts adobe-source-han-sans-tw-fonts \
|
|
|
+ -S --needed --noconfirm && pacman -Scc --noconfirm
|
|
|
+RUN pacman texlive -S --needed --noconfirm && pacman -Scc --noconfirm
|
|
|
+RUN pacman texlive-lang -S --needed --noconfirm && pacman -Scc --noconfirm
|
|
|
+RUN pacman nerd-fonts -S --needed --noconfirm && pacman -Scc --noconfirm
|
|
|
+
|
|
|
+
|
|
|
+# RUN pacman -S --needed --noconfirm && pacman -Scc --noconfirm
|
|
|
+
|
|
|
|
|
|
RUN echo "en_US.UTF-8 UTF-8" > /etc/locale.gen && locale-gen
|
|
|
RUN useradd -s /bin/zsh -m deploy
|
|
|
@@ -36,14 +51,14 @@ USER deploy
|
|
|
RUN mkdir -p $HOME/downloads $HOME/build $HOME/local $HOME/tmp
|
|
|
|
|
|
# https://pkl-lang.org/main/current/pkl-cli/index.html#linux-executable
|
|
|
-ENV PKL_VERSION="0.25.1"
|
|
|
+ENV PKL_VERSION="0.30.2"
|
|
|
RUN curl -L -o $HOME/downloads/pkl https://github.com/apple/pkl/releases/download/$PKL_VERSION/pkl-linux-amd64 \
|
|
|
&& sudo cp $HOME/downloads/pkl /usr/local/bin/ \
|
|
|
&& sudo chmod +x /usr/local/bin/pkl
|
|
|
|
|
|
|
|
|
# https://github.com/envoyproxy/envoy
|
|
|
-ENV ENVOY_VERSION "1.33.0"
|
|
|
+ENV ENVOY_VERSION="1.36.4"
|
|
|
RUN wget -q -O $HOME/downloads/envoy https://github.com/envoyproxy/envoy/releases/download/v${ENVOY_VERSION}/envoy-${ENVOY_VERSION}-linux-x86_64 \
|
|
|
&& sudo cp $HOME/downloads/envoy /usr/local/bin/ \
|
|
|
&& sudo chmod +x /usr/local/bin/envoy
|
|
|
@@ -56,16 +71,19 @@ RUN cd $HOME/downloads \
|
|
|
|
|
|
|
|
|
# https://github.com/bazelbuild/bazelisk
|
|
|
-ENV BAZEL_VERSION "v1.25.0"
|
|
|
+ENV BAZEL_VERSION="v1.27.0"
|
|
|
RUN wget -q -O $HOME/downloads/bazel \
|
|
|
https://github.com/bazelbuild/bazelisk/releases/download/${BAZEL_VERSION}/bazelisk-linux-amd64
|
|
|
RUN sudo cp $HOME/downloads/bazel /usr/local/bin && sudo chmod +x /usr/local/bin/bazel
|
|
|
|
|
|
|
|
|
# https://min.io/download#/linux
|
|
|
-RUN wget -q -O $HOME/downloads/minio https://dl.min.io/server/minio/release/linux-amd64/minio \
|
|
|
+RUN wget -q -P $HOME/downloads/ https://dl.min.io/aistor/minio/release/linux-amd64/minio \
|
|
|
+ && chmod +x $HOME/downloads/minio \
|
|
|
&& sudo cp $HOME/downloads/minio /usr/local/bin/ \
|
|
|
- && sudo chmod +x /usr/local/bin/minio
|
|
|
+ && wget -q -P $HOME/downloads/ https://dl.min.io/aistor/mc/release/linux-amd64/mc \
|
|
|
+ && chmod +x $HOME/downloads/mc \
|
|
|
+ && sudo cp $HOME/downloads/mc /usr/local/bin/
|
|
|
|
|
|
# https://github.com/amacneil/dbmate
|
|
|
RUN curl -fsSL -o $HOME/downloads/dbmate https://github.com/amacneil/dbmate/releases/latest/download/dbmate-linux-amd64 \
|
|
|
@@ -73,7 +91,7 @@ RUN curl -fsSL -o $HOME/downloads/dbmate https://github.com/amacneil/dbmate/rele
|
|
|
&& sudo chmod +x /usr/local/bin/dbmate
|
|
|
|
|
|
# https://aur.archlinux.org/packages/ttf-arphic-tex-extra
|
|
|
-ENV ARPHIC_TTF_VERSION "20161212-1"
|
|
|
+ENV ARPHIC_TTF_VERSION="20161212-1"
|
|
|
RUN git clone https://aur.archlinux.org/ttf-arphic-tex-extra.git $HOME/downloads/ttf-arphic-tex-extra \
|
|
|
&& cd $HOME/downloads/ttf-arphic-tex-extra/ \
|
|
|
&& makepkg \
|
|
|
@@ -89,25 +107,26 @@ RUN echo 'export LANG=en_US.UTF-8' >> $HOME/.zshrc \
|
|
|
|
|
|
RUN git config --global core.quotepath false \
|
|
|
&& git config --global http.version HTTP/1.1 \
|
|
|
- && git config --global pull.rebase false \
|
|
|
+ && git config --global pull.rebase true \
|
|
|
&& git config --global url."https://".insteadOf git://
|
|
|
RUN echo 'set-option -g history-limit 102400' > $HOME/.tmux.conf \
|
|
|
&& echo 'set-option -g default-shell "/bin/zsh"' >> $HOME/.tmux.conf
|
|
|
|
|
|
-# https://musl.cc/
|
|
|
-RUN wget -q -P $HOME/downloads https://more.musl.cc/x86_64-linux-musl/x86_64-linux-musl-cross.tgz \
|
|
|
- && tar xf $HOME/downloads/x86_64-linux-musl-cross.tgz -C $HOME/local \
|
|
|
+# https://github.com/cross-tools/musl-cross
|
|
|
+RUN git clone https://github.com/cross-tools/musl-cross.git $HOME/build/musl-cross
|
|
|
+ENV MUSL_TOOLCHAIN_VERSION=20250929
|
|
|
+RUN wget -q -P $HOME/downloads https://github.com/cross-tools/musl-cross/releases/download/${MUSL_TOOLCHAIN_VERSION}/x86_64-unknown-linux-musl.tar.xz \
|
|
|
+ && tar xf $HOME/downloads/x86_64-unknown-linux-musl.tar.xz -C $HOME/local \
|
|
|
+ && echo 'export PATH=$HOME/local/x86_64-unknown-linux-musl/bin:$PATH' >> $HOME/.zshrc
|
|
|
+RUN wget -q -P $HOME/downloads https://github.com/cross-tools/musl-cross/releases/download/${MUSL_TOOLCHAIN_VERSION}/aarch64-unknown-linux-musl.tar.xz \
|
|
|
+ && tar xf $HOME/downloads/aarch64-unknown-linux-musl.tar.xz -C $HOME/local \
|
|
|
+ && echo 'export PATH=$HOME/local/aarch64-unknown-linux-musl/bin:$PATH' >> $HOME/.zshrc
|
|
|
+RUN wget -q -P $HOME/downloads https://github.com/cross-tools/musl-cross/releases/download/${MUSL_TOOLCHAIN_VERSION}/riscv64-unknown-linux-musl.tar.xz \
|
|
|
+ && tar xf $HOME/downloads/riscv64-unknown-linux-musl.tar.xz -C $HOME/local \
|
|
|
&& echo 'export PATH=$HOME/local/x86_64-linux-musl-cross/bin:$PATH' >> $HOME/.zshrc
|
|
|
-RUN wget -q -P $HOME/downloads https://more.musl.cc/x86_64-linux-musl/armv7l-linux-musleabihf-cross.tgz \
|
|
|
- && tar xf $HOME/downloads/armv7l-linux-musleabihf-cross.tgz -C $HOME/local \
|
|
|
- && echo 'export PATH=$HOME/local/armv7l-linux-musleabihf-cross/bin:$PATH' >> $HOME/.zshrc
|
|
|
-RUN wget -q -P $HOME/downloads https://more.musl.cc/x86_64-linux-musl/aarch64-linux-musl-cross.tgz \
|
|
|
- && tar xf $HOME/downloads/aarch64-linux-musl-cross.tgz -C $HOME/local \
|
|
|
- && echo 'export PATH=$HOME/local/aarch64-linux-musl-cross/bin:$PATH' >> $HOME/.zshrc
|
|
|
-RUN wget -q -P $HOME/downloads https://more.musl.cc/x86_64-linux-musl/riscv64-linux-musl-cross.tgz \
|
|
|
- && tar xf $HOME/downloads/riscv64-linux-musl-cross.tgz -C $HOME/local \
|
|
|
- && echo 'export PATH=$HOME/local/riscv64-linux-musl-cross/bin:$PATH' >> $HOME/.zshrc
|
|
|
-
|
|
|
+RUN wget -q -P $HOME/downloads https://github.com/cross-tools/musl-cross/releases/download/${MUSL_TOOLCHAIN_VERSION}/loongarch64-unknown-linux-musl.tar.xz \
|
|
|
+ && tar xf $HOME/downloads/loongarch64-unknown-linux-musl.tar.xz -C $HOME/local \
|
|
|
+ && echo 'export PATH=$HOME/local/loongarch64-unknown-linux-musl/bin:$PATH' >> $HOME/.zshrc
|
|
|
|
|
|
# https://pip.pypa.io/en/stable/installation/
|
|
|
RUN zsh -c ". $HOME/.zshrc \
|
|
|
@@ -117,13 +136,14 @@ RUN zsh -c ". $HOME/.zshrc \
|
|
|
&& pip install ansible paramiko conan \
|
|
|
&& pip install grpcio-tools grpcio-health-checking"
|
|
|
RUN echo 'source $HOME/local/python3/bin/activate' >> $HOME/.zshrc
|
|
|
+RUN zsh -c ". $HOME/.zshrc && ansible-galaxy collection install ansible.posix"
|
|
|
RUN echo 'export ANSIBLE_HOST_KEY_CHECKING=False' >> $HOME/.zshrc \
|
|
|
&& echo 'alias peony="ANSIBLE_LOG_PATH=$HOME/tmp/$(date +%Y%m%d%H%M%S).log ansible-playbook"' >> $HOME/.zshrc
|
|
|
|
|
|
|
|
|
# https://github.com/rbenv/rbenv
|
|
|
# https://github.com/rbenv/ruby-build/tree/master/share/ruby-build
|
|
|
-ENV RUBY_VERSION "3.4.1"
|
|
|
+ENV RUBY_VERSION="4.0.0"
|
|
|
RUN git clone https://github.com/rbenv/rbenv.git $HOME/.rbenv \
|
|
|
&& git clone https://github.com/rbenv/ruby-build.git $HOME/.rbenv/plugins/ruby-build \
|
|
|
&& git clone https://github.com/rbenv/rbenv-vars.git $HOME/.rbenv/plugins/rbenv-vars
|
|
|
@@ -135,12 +155,12 @@ RUN zsh -c "source $HOME/.zshrc \
|
|
|
&& gem install bundler"
|
|
|
|
|
|
# https://go.dev/doc/install
|
|
|
-ENV GO_VERSION "1.23.5"
|
|
|
+ENV GO_VERSION="1.25.5"
|
|
|
RUN wget -q -P $HOME/downloads https://go.dev/dl/go${GO_VERSION}.linux-amd64.tar.gz
|
|
|
RUN tar xf $HOME/downloads/go${GO_VERSION}.linux-amd64.tar.gz -C $HOME/local
|
|
|
RUN echo 'export PATH=$HOME/local/go/bin:$PATH' >> $HOME/.zshrc \
|
|
|
&& echo 'export GOPATH=$HOME/go' >> $HOME/.zshrc \
|
|
|
- && echo 'export PATH="$(go env GOPATH)/bin:$PATH"' >> $HOME/.zshrc
|
|
|
+ && echo 'export PATH=$(go env GOPATH)/bin:$PATH' >> $HOME/.zshrc
|
|
|
# https://code.visualstudio.com/docs/languages/go
|
|
|
RUN zsh -c "source $HOME/.zshrc \
|
|
|
&& go install golang.org/x/tools/gopls@latest \
|
|
|
@@ -149,25 +169,35 @@ RUN zsh -c "source $HOME/.zshrc \
|
|
|
|
|
|
# https://github.com/sdkman/sdkman-cli
|
|
|
# https://docs.gradle.org/current/userguide/compatibility.html
|
|
|
-ENV JDK_VERSION "23.0.1-open"
|
|
|
-ENV GRADLE_VERSION "8.12.1"
|
|
|
-ENV THRIFT_JAVA_VERSION "19.0.2-open"
|
|
|
-ENV THRIFT_GRADLE_VERSION "7.6.4"
|
|
|
+# https://thrift.apache.org/lib/java.html
|
|
|
+ENV JDK_VERSION="25.0.1-amzn"
|
|
|
+ENV GRADLE_VERSION="9.2.1"
|
|
|
RUN curl -s "https://get.sdkman.io" | bash
|
|
|
RUN sed -i -e 's/sdkman_auto_answer=false/sdkman_auto_answer=true/g' $HOME/.sdkman/etc/config
|
|
|
RUN zsh -c "source $HOME/.zshrc \
|
|
|
&& sdk install java ${JDK_VERSION} \
|
|
|
- && sdk install ant \
|
|
|
- && sdk install maven \
|
|
|
&& sdk install gradle ${GRADLE_VERSION} \
|
|
|
+ && sdk install maven \
|
|
|
&& sdk install kotlin \
|
|
|
- && sdk install java ${THRIFT_JAVA_VERSION} \
|
|
|
- && sdk install gradle ${THRIFT_GRADLE_VERSION} \
|
|
|
&& sdk default java ${JDK_VERSION} \
|
|
|
&& sdk default gradle ${GRADLE_VERSION}"
|
|
|
|
|
|
+# https://asdf-vm.com/guide/getting-started.html
|
|
|
+RUN zsh -c "source $HOME/.zshrc && go install github.com/asdf-vm/asdf/cmd/asdf@v0.18.0" \
|
|
|
+ && echo 'export PATH=${ASDF_DATA_DIR:-$HOME/.asdf}/shims:$PATH' >> $HOME/.zshrc
|
|
|
+# asdf list all XXX
|
|
|
+ENV ERLANG_VERSION="28.3"
|
|
|
+ENV ELIXIR_VERSION="1.19.4"
|
|
|
+RUN zsh -c "source $HOME/.zshrc \
|
|
|
+ && asdf plugin add erlang https://github.com/asdf-vm/asdf-erlang.git \
|
|
|
+ && asdf install erlang ${ERLANG_VERSION} \
|
|
|
+ && asdf plugin add elixir https://github.com/asdf-vm/asdf-elixir.git \
|
|
|
+ && asdf install elixir ${ELIXIR_VERSION}"
|
|
|
+RUN echo "export HEX_HTTP_CONCURRENCY=1" >> $HOME/.zshrc \
|
|
|
+ && echo "export HEX_HTTP_TIMEOUT=120" >> $HOME/.zshrc
|
|
|
+
|
|
|
# https://github.com/nvm-sh/nvm
|
|
|
-ENV NVM_VERSION "v0.40.1"
|
|
|
+ENV NVM_VERSION="v0.40.3"
|
|
|
RUN git clone -b ${NVM_VERSION} https://github.com/nvm-sh/nvm.git $HOME/.nvm
|
|
|
RUN echo 'export NVM_DIR="$HOME/.nvm"' >> $HOME/.zshrc \
|
|
|
&& echo '[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh"' >> $HOME/.zshrc \
|
|
|
@@ -197,13 +227,17 @@ RUN zsh -c "source $HOME/.cargo/env \
|
|
|
RUN zsh -c "source $HOME/.zshrc \
|
|
|
&& cargo install --locked cargo-outdated \
|
|
|
&& cargo install diesel_cli \
|
|
|
- && cargo install mdbook"
|
|
|
+ && cargo install mdbook \
|
|
|
+ && cargo install cross"
|
|
|
|
|
|
-# https://www.swift.org/download/#releases
|
|
|
-ENV SWIFT_VERSION "6.0.3"
|
|
|
-RUN wget -q -P $HOME/downloads https://download.swift.org/swift-${SWIFT_VERSION}-release/ubuntu2404/swift-${SWIFT_VERSION}-RELEASE/swift-${SWIFT_VERSION}-RELEASE-ubuntu24.04.tar.gz \
|
|
|
- && tar xf $HOME/downloads/swift-${SWIFT_VERSION}-RELEASE-ubuntu24.04.tar.gz -C $HOME/local \
|
|
|
- && echo "export PATH=\$HOME/local/swift-${SWIFT_VERSION}-RELEASE-ubuntu24.04/bin:\$PATH" >> $HOME/.zshrc
|
|
|
+# FIXME Unable to find release information from file /etc/os-release
|
|
|
+# https://www.swift.org/install/linux/
|
|
|
+# RUN wget -q -P $HOME/downloads/ https://download.swift.org/swiftly/linux/swiftly-x86_64.tar.gz \
|
|
|
+# && mkdir -p $HOME/local/swift \
|
|
|
+# && tar xf $HOME/downloads/swiftly-x86_64.tar.gz -C $HOME/local/swift \
|
|
|
+# && cd $HOME/local/swift/ \
|
|
|
+# && ./swiftly init --quiet-shell-followup -y \
|
|
|
+# && echo '. "${SWIFTLY_HOME_DIR:-$HOME/.local/share/swiftly}/env.sh"' >> $HOME/.zshrc
|
|
|
|
|
|
|
|
|
# https://xmake.io/#/guide/installation?id=via-curl
|
|
|
@@ -215,38 +249,37 @@ RUN $HOME/local/vcpkg/bootstrap-vcpkg.sh \
|
|
|
&& echo 'export VCPKG_DISABLE_METRICS=1' >> $HOME/.zshrc
|
|
|
|
|
|
# https://opensearch.org/downloads.html#opensearch
|
|
|
-ENV OPENSEARCH_VERSION "2.18.0"
|
|
|
+ENV OPENSEARCH_VERSION="3.4.0"
|
|
|
RUN wget -q -P $HOME/downloads \
|
|
|
https://artifacts.opensearch.org/releases/bundle/opensearch/${OPENSEARCH_VERSION}/opensearch-${OPENSEARCH_VERSION}-linux-x64.tar.gz
|
|
|
RUN tar xf $HOME/downloads/opensearch-${OPENSEARCH_VERSION}-linux-x64.tar.gz -C $HOME/tmp \
|
|
|
&& sudo mv $HOME/tmp/opensearch-${OPENSEARCH_VERSION} /opt/opensearch
|
|
|
|
|
|
# https://github.com/grpc/grpc
|
|
|
-ENV GRPC_VERSION "v1.70.0"
|
|
|
-RUN git clone --recurse-submodules -b $GRPC_VERSION https://github.com/grpc/grpc.git $HOME/downloads/grpc
|
|
|
+ENV GRPC_VERSION="v1.76.0"
|
|
|
+RUN git clone -b $GRPC_VERSION https://github.com/grpc/grpc.git $HOME/downloads/grpc
|
|
|
+RUN cd $HOME/downloads/grpc/ && git submodule update --init --recursive
|
|
|
# ENV PROTOBUF_VERSION "v3.21.8"
|
|
|
# RUN cd $HOME/downloads/grpc/third_party/protobuf \
|
|
|
# && git checkout ${PROTOBUF_VERSION} \
|
|
|
# && git submodule update --init --recursive
|
|
|
RUN zsh -c "source $HOME/.zshrc \
|
|
|
&& mkdir -pv $HOME/build/grpc \
|
|
|
- && cd $HOME/build/grpc \
|
|
|
- && CC=clang CXX=clang++ cmake -DCMAKE_BUILD_TYPE=Release \
|
|
|
- -DgRPC_INSTALL=ON \
|
|
|
- -DgRPC_SSL_PROVIDER=package \
|
|
|
- -DgRPC_BUILD_TESTS=OFF \
|
|
|
- -DCMAKE_INSTALL_PREFIX=$HOME/.local $HOME/downloads/grpc \
|
|
|
- && make -j $(nproc --ignore=2) \
|
|
|
- && make install"
|
|
|
+ && CC=clang CXX=clang++ cmake -DCMAKE_BUILD_TYPE=Release -G Ninja \
|
|
|
+ -DgRPC_INSTALL=ON -DgRPC_SSL_PROVIDER=package -DgRPC_BUILD_TESTS=OFF \
|
|
|
+ -DCMAKE_INSTALL_PREFIX=$HOME/.local -B $HOME/build/grpc -S $HOME/downloads/grpc \
|
|
|
+ && cmake --build $HOME/build/grpc \
|
|
|
+ && cmake --install $HOME/build/grpc \
|
|
|
+ && rm -r $HOME/build/grpc"
|
|
|
|
|
|
# https://github.com/grpc/grpc-web#code-generator-plugin
|
|
|
-ENV GRPC_WEB_PLUGIN_VERSION "1.5.0"
|
|
|
+ENV GRPC_WEB_PLUGIN_VERSION="2.0.2"
|
|
|
RUN wget -q -O $HOME/.local/bin/protoc-gen-grpc-web \
|
|
|
https://github.com/grpc/grpc-web/releases/download/${GRPC_WEB_PLUGIN_VERSION}/protoc-gen-grpc-web-${GRPC_WEB_PLUGIN_VERSION}-linux-x86_64
|
|
|
RUN chmod +x $HOME/.local/bin/protoc-gen-grpc-web
|
|
|
|
|
|
# https://github.com/protocolbuffers/protobuf-javascript
|
|
|
-ENV GRPC_JS_PLUGIN_VERSION "3.21.4"
|
|
|
+ENV GRPC_JS_PLUGIN_VERSION="4.0.1"
|
|
|
RUN wget -q -P $HOME/downloads \
|
|
|
https://github.com/protocolbuffers/protobuf-javascript/releases/download/v${GRPC_JS_PLUGIN_VERSION}/protobuf-javascript-${GRPC_JS_PLUGIN_VERSION}-linux-x86_64.tar.gz
|
|
|
RUN mkdir -p $HOME/build/protobuf-javascript \
|
|
|
@@ -255,7 +288,7 @@ RUN mkdir -p $HOME/build/protobuf-javascript \
|
|
|
|
|
|
# https://repo1.maven.org/maven2/io/grpc/protoc-gen-grpc-java/
|
|
|
# https://github.com/grpc/grpc-java
|
|
|
-ENV GRPC_JAVA_PLUGIN_VERSION "1.70.1"
|
|
|
+ENV GRPC_JAVA_PLUGIN_VERSION="1.78.0"
|
|
|
RUN wget -q -O $HOME/.local/bin/grpc_java_plugin \
|
|
|
https://repo1.maven.org/maven2/io/grpc/protoc-gen-grpc-java/${GRPC_JAVA_PLUGIN_VERSION}/protoc-gen-grpc-java-${GRPC_JAVA_PLUGIN_VERSION}-linux-x86_64.exe
|
|
|
RUN chmod +x $HOME/.local/bin/grpc_java_plugin
|
|
|
@@ -274,22 +307,23 @@ RUN zsh -c "source $HOME/.zshrc \
|
|
|
go install github.com/fullstorydev/grpcurl/cmd/grpcurl@latest"
|
|
|
|
|
|
# https://github.com/google/flatbuffers
|
|
|
-ENV FLATBUFFERS_VERSION "v25.2.10"
|
|
|
+ENV FLATBUFFERS_VERSION="v25.12.19"
|
|
|
RUN git clone -b $FLATBUFFERS_VERSION https://github.com/google/flatbuffers.git $HOME/downloads/flatbuffers
|
|
|
RUN zsh -c "source $HOME/.zshrc \
|
|
|
&& mkdir -pv $HOME/build/flatbuffers \
|
|
|
- && cd $HOME/build/flatbuffers \
|
|
|
- && CC=clang CXX=clang++ cmake -G 'Unix Makefiles' -DCMAKE_BUILD_TYPE=Release -DFLATBUFFERS_BUILD_TESTS=OFF \
|
|
|
- -DCMAKE_INSTALL_PREFIX=$HOME/.local $HOME/downloads/flatbuffers \
|
|
|
- && make -j $(nproc --ignore=2) \
|
|
|
- && make install"
|
|
|
-
|
|
|
+ && CC=clang CXX=clang++ cmake -G Ninja -DCMAKE_BUILD_TYPE=Release \
|
|
|
+ -DFLATBUFFERS_BUILD_TESTS=OFF \
|
|
|
+ -DCMAKE_INSTALL_PREFIX=$HOME/.local -B $HOME/build/flatbuffers -S $HOME/downloads/flatbuffers \
|
|
|
+ && cmake --build $HOME/build/flatbuffers \
|
|
|
+ && cmake --install $HOME/build/flatbuffers \
|
|
|
+ && rm -r $HOME/build/flatbuffers"
|
|
|
|
|
|
# https://opensearch.org/docs/latest/opensearch/install/tar/
|
|
|
RUN echo "network.host: 0.0.0.0" >> /opt/opensearch/config/opensearch.yml \
|
|
|
&& echo "discovery.type: single-node" >> /opt/opensearch/config/opensearch.yml \
|
|
|
- && echo "plugins.security.disabled: true" >> /opt/opensearch/config/opensearch.yml \
|
|
|
- && sudo chown -R nobody:nobody /opt/opensearch
|
|
|
+ && echo "plugins.security.disabled: true" >> /opt/opensearch/config/opensearch.yml
|
|
|
+# https://github.com/infinilabs/analysis-stconvert
|
|
|
+RUN cd /opt/opensearch/ && bin/opensearch-plugin install https://get.infini.cloud/opensearch/analysis-stconvert/${OPENSEARCH_VERSION}
|
|
|
|
|
|
RUN sudo mkdir -p /var/lib/minio/data && sudo chown -R nobody:nobody /var/lib/minio
|
|
|
|
|
|
@@ -297,7 +331,9 @@ RUN sudo mkdir -p /var/lib/minio/data && sudo chown -R nobody:nobody /var/lib/mi
|
|
|
RUN echo 'loopback_users = none' | sudo tee -a /etc/rabbitmq/rabbitmq.conf \
|
|
|
&& sudo sed -i "s/NODENAME.*/NODENAME=palm/g" /etc/rabbitmq/rabbitmq-env.conf \
|
|
|
&& sudo rabbitmq-plugins enable rabbitmq_mqtt \
|
|
|
- && sudo rabbitmq-plugins enable rabbitmq_management
|
|
|
+ && sudo rabbitmq-plugins enable rabbitmq_management \
|
|
|
+ && sudo rabbitmq-plugins enable rabbitmq_stream \
|
|
|
+ && sudo rabbitmq-plugins enable rabbitmq_shovel rabbitmq_shovel_management
|
|
|
|
|
|
RUN cd /usr && sudo mariadb-install-db --datadir=/var/lib/mysql --user=mysql
|
|
|
|
|
|
@@ -310,13 +346,14 @@ RUN echo "listen_addresses = '0.0.0.0'" | sudo tee -a /var/lib/postgres/data/pos
|
|
|
ADD etc/redis/* /etc/redis/
|
|
|
RUN sudo mkdir -p /var/lib/redis \
|
|
|
&& sudo mkdir /var/lib/redis/single /var/lib/redis/node-1 /var/lib/redis/node-2 /var/lib/redis/node-3 /var/lib/redis/node-4 /var/lib/redis/node-5 /var/lib/redis/node-6 \
|
|
|
- && sudo chown -R redis:redis /var/lib/redis \
|
|
|
+ && sudo chown -R valkey:valkey /var/lib/redis \
|
|
|
&& sudo chmod 750 /var/lib/redis
|
|
|
|
|
|
RUN sudo mkdir -p /var/www/html \
|
|
|
&& echo "<?php phpinfo(); ?>" | sudo tee /var/www/html/info.php \
|
|
|
+ && sudo cp /etc/nginx/nginx.conf /etc/nginx/nginx.conf.orig \
|
|
|
&& echo "daemon off;" | sudo tee -a /etc/nginx/nginx.conf \
|
|
|
- && sudo sed -i '35,79d' /etc/nginx/nginx.conf \
|
|
|
+ && sudo sed -i '35,82d' /etc/nginx/nginx.conf \
|
|
|
&& sudo sed -i '35i include sites-enabled/*.conf;' /etc/nginx/nginx.conf \
|
|
|
&& sudo sed -i "s/error_log =.*/error_log = log\/php-fpm.log/g" /etc/php/php-fpm.conf
|
|
|
ADD etc/nginx/sites-enabled/localhost.conf /etc/nginx/sites-enabled/localhost.conf
|
|
|
@@ -343,7 +380,6 @@ RUN sudo sed -i 's/memory_limit =.*/memory_limit = 1G/' /etc/php/php.ini \
|
|
|
&& sudo sed -i 's/;extension=pdo_pgsql/extension=pdo_pgsql/' /etc/php/php.ini \
|
|
|
&& sudo sed -i 's/;extension=pdo_sqlite/extension=pdo_sqlite/' /etc/php/php.ini \
|
|
|
&& sudo sed -i 's/;extension=pgsql/extension=pgsql/' /etc/php/php.ini \
|
|
|
- && sudo sed -i 's/;extension=pspell/extension=pspell/' /etc/php/php.ini \
|
|
|
&& sudo sed -i 's/;extension=snmp/extension=snmp/' /etc/php/php.ini \
|
|
|
&& sudo sed -i 's/;extension=soap/extension=soap/' /etc/php/php.ini \
|
|
|
&& sudo sed -i 's/;extension=sockets/extension=sockets/' /etc/php/php.ini \
|
|
|
@@ -376,6 +412,7 @@ RUN mkdir -p $HOME/.ssh \
|
|
|
ADD etc/envoy.yaml /etc/
|
|
|
RUN sudo mkdir -p /var/log/envoy
|
|
|
ADD etc/supervisor /etc/supervisor
|
|
|
+ADD opt/bin /etc/bin
|
|
|
|
|
|
RUN echo "$(date -u +%4Y%m%d%H%M%S)" | sudo tee /VERSION
|
|
|
|