Compare commits

...

10 Commits

Author SHA1 Message Date
David Osipov a56f705dd5
Merge 1b9f483a08 into b8ca1fc166 2026-03-24 20:58:19 +03:00
Alexey b8ca1fc166
Update Dockerfile 2026-03-24 20:55:32 +03:00
Alexey f9986944df
Update release.yml 2026-03-24 20:53:56 +03:00
Alexey cb877c2bc3
Update release profile settings for better optimization: merge pull request #574 from vladon/main
Update release profile settings for better optimization
2026-03-24 14:10:04 +03:00
Vladislav Yaroslavlev 4426082c17
Update release profile settings for better optimization 2026-03-24 14:01:49 +03:00
Alexey 22097f8c7c
Update Dockerfile 2026-03-24 11:46:49 +03:00
Alexey 1450af60a0
Update Dockerfile 2026-03-24 11:41:53 +03:00
Alexey f1cc8d65f2
Update release.yml 2026-03-24 11:12:03 +03:00
Alexey ec7e808daf
Update release.yml 2026-03-24 11:05:50 +03:00
Alexey e4b7e23e76
New TLS-Fetcher + TLS SNI Validator + Upstream-driver getProxySecret/Config + Workflow Tunings + Redesign Quotas on Atomics + Tests Swap: merge pull request #569 from telemt/flow
New TLS-Fetcher + TLS SNI Validator + Upstream-driver getProxySecret/Config + Workflow Tunings + Redesign Quotas on Atomics + Tests Swap
2026-03-24 10:56:15 +03:00
3 changed files with 140 additions and 71 deletions

View File

@ -104,10 +104,10 @@ jobs:
build-musl: build-musl:
name: MUSL ${{ matrix.target }} name: MUSL ${{ matrix.target }}
runs-on: ubuntu-latest runs-on: ubuntu-latest
container: container:
image: rust:slim-bookworm image: rust:slim-bookworm
strategy: strategy:
fail-fast: false fail-fast: false
matrix: matrix:
@ -116,18 +116,54 @@ jobs:
asset: telemt-x86_64-linux-musl asset: telemt-x86_64-linux-musl
- target: aarch64-unknown-linux-musl - target: aarch64-unknown-linux-musl
asset: telemt-aarch64-linux-musl asset: telemt-aarch64-linux-musl
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v4
- name: Install deps - name: Install deps
run: | run: |
apt-get update apt-get update
apt-get install -y musl-tools pkg-config curl apt-get install -y \
musl-tools \
pkg-config \
curl
- uses: actions/cache@v4
if: matrix.target == 'aarch64-unknown-linux-musl'
with:
path: ~/.musl-aarch64
key: musl-toolchain-aarch64-v1
- name: Install aarch64 musl toolchain
if: matrix.target == 'aarch64-unknown-linux-musl'
run: |
set -e
TOOLCHAIN_DIR="$HOME/.musl-aarch64"
ARCHIVE="aarch64-linux-musl-cross.tgz"
URL="https://github.com/telemt/telemt/releases/download/toolchains/$ARCHIVE"
if [ -x "$TOOLCHAIN_DIR/bin/aarch64-linux-musl-gcc" ]; then
echo "✅ MUSL toolchain cached"
else
echo "⬇️ Downloading MUSL toolchain..."
curl -fL \
--retry 5 \
--retry-delay 3 \
--connect-timeout 10 \
--max-time 120 \
-o "$ARCHIVE" "$URL"
mkdir -p "$TOOLCHAIN_DIR"
tar -xzf "$ARCHIVE" --strip-components=1 -C "$TOOLCHAIN_DIR"
fi
echo "$TOOLCHAIN_DIR/bin" >> $GITHUB_PATH
- name: Add rust target - name: Add rust target
run: rustup target add ${{ matrix.target }} run: rustup target add ${{ matrix.target }}
- uses: actions/cache@v4 - uses: actions/cache@v4
with: with:
path: | path: |
@ -135,31 +171,33 @@ jobs:
/usr/local/cargo/git /usr/local/cargo/git
target target
key: musl-${{ matrix.target }}-${{ hashFiles('**/Cargo.lock') }} key: musl-${{ matrix.target }}-${{ hashFiles('**/Cargo.lock') }}
- name: Build - name: Build
run: | run: |
if [ "${{ matrix.target }}" = "aarch64-unknown-linux-musl" ]; then if [ "${{ matrix.target }}" = "aarch64-unknown-linux-musl" ]; then
export CC=aarch64-linux-musl-gcc export CC=aarch64-linux-musl-gcc
export CC_aarch64_unknown_linux_musl=aarch64-linux-musl-gcc
export RUSTFLAGS="-C target-feature=+crt-static -C linker=aarch64-linux-musl-gcc" export RUSTFLAGS="-C target-feature=+crt-static -C linker=aarch64-linux-musl-gcc"
else else
export CC=musl-gcc export CC=musl-gcc
export CC_x86_64_unknown_linux_musl=musl-gcc
export RUSTFLAGS="-C target-feature=+crt-static" export RUSTFLAGS="-C target-feature=+crt-static"
fi fi
cargo build --release --target ${{ matrix.target }} cargo build --release --target ${{ matrix.target }}
- name: Package - name: Package
run: | run: |
mkdir -p dist mkdir -p dist
cp target/${{ matrix.target }}/release/${{ env.BINARY_NAME }} dist/telemt cp target/${{ matrix.target }}/release/${{ env.BINARY_NAME }} dist/telemt
cd dist cd dist
tar -czf ${{ matrix.asset }}.tar.gz \ tar -czf ${{ matrix.asset }}.tar.gz \
--owner=0 --group=0 --numeric-owner \ --owner=0 --group=0 --numeric-owner \
telemt telemt
sha256sum ${{ matrix.asset }}.tar.gz > ${{ matrix.asset }}.sha256 sha256sum ${{ matrix.asset }}.tar.gz > ${{ matrix.asset }}.sha256
- uses: actions/upload-artifact@v4 - uses: actions/upload-artifact@v4
with: with:
name: ${{ matrix.asset }} name: ${{ matrix.asset }}
@ -194,51 +232,48 @@ jobs:
prerelease: ${{ contains(github.ref, '-') }} prerelease: ${{ contains(github.ref, '-') }}
# ========================== # ==========================
# Docker (FROM RELEASE) # Docker
# ========================== # ==========================
docker: docker:
name: Docker (from release) name: Docker
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: release needs: [build-gnu, build-musl]
permissions: permissions:
contents: read contents: read
packages: write packages: write
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v4
- name: Install gh - uses: actions/download-artifact@v4
run: apt-get update && apt-get install -y gh with:
path: dist
- name: Extract version
id: vars - name: Extract binaries
run: echo "VERSION=${GITHUB_REF#refs/tags/}" >> $GITHUB_OUTPUT
- name: Download binary
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: | run: |
mkdir dist mkdir bin
gh release download ${{ steps.vars.outputs.VERSION }} \ tar -xzf dist/telemt-x86_64-linux-musl/telemt-x86_64-linux-musl.tar.gz -C bin
--repo ${{ github.repository }} \ mv bin/telemt bin/telemt-amd64
--pattern "telemt-x86_64-linux-musl.tar.gz" \
--dir dist tar -xzf dist/telemt-aarch64-linux-musl/telemt-aarch64-linux-musl.tar.gz -C bin
mv bin/telemt bin/telemt-arm64
tar -xzf dist/telemt-x86_64-linux-musl.tar.gz -C dist
chmod +x dist/telemt
- uses: docker/setup-qemu-action@v3 - uses: docker/setup-qemu-action@v3
- uses: docker/setup-buildx-action@v3 - uses: docker/setup-buildx-action@v3
- uses: docker/login-action@v3 - uses: docker/login-action@v3
with: with:
registry: ghcr.io registry: ghcr.io
username: ${{ github.actor }} username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }} password: ${{ secrets.GITHUB_TOKEN }}
- name: Build & Push - name: Extract version
id: vars
run: echo "VERSION=${GITHUB_REF#refs/tags/}" >> $GITHUB_OUTPUT
- name: Build & Push (multi-arch)
uses: docker/build-push-action@v6 uses: docker/build-push-action@v6
with: with:
context: . context: .
@ -248,4 +283,5 @@ jobs:
ghcr.io/${{ github.repository }}:${{ steps.vars.outputs.VERSION }} ghcr.io/${{ github.repository }}:${{ steps.vars.outputs.VERSION }}
ghcr.io/${{ github.repository }}:latest ghcr.io/${{ github.repository }}:latest
build-args: | build-args: |
BINARY=dist/telemt BINARY_AMD64=bin/telemt-amd64
BINARY_ARM64=bin/telemt-arm64

View File

@ -83,4 +83,6 @@ name = "crypto_bench"
harness = false harness = false
[profile.release] [profile.release]
lto = "thin" lto = "fat"
codegen-units = 1

View File

@ -1,47 +1,78 @@
# syntax=docker/dockerfile:1 # syntax=docker/dockerfile:1
ARG BINARY ARG TARGETARCH
ARG BINARY_AMD64
ARG BINARY_ARM64
# ========================== # ==========================
# Stage: minimal # Minimal Image
# ========================== # ==========================
FROM debian:12-slim AS minimal FROM debian:12-slim AS minimal
RUN apt-get update && apt-get install -y --no-install-recommends \ ARG TARGETARCH
binutils \ ARG BINARY_AMD64
curl \ ARG BINARY_ARM64
ca-certificates \
&& rm -rf /var/lib/apt/lists/* \ RUN set -eux; \
apt-get update; \
apt-get install -y --no-install-recommends \
binutils \
curl \
xz-utils \
ca-certificates; \
rm -rf /var/lib/apt/lists/*
# --- Select correct binary ---
RUN set -eux; \
case "${TARGETARCH}" in \
amd64) BIN="${BINARY_AMD64}" ;; \
arm64) BIN="${BINARY_ARM64}" ;; \
*) echo "Unsupported TARGETARCH: ${TARGETARCH}" >&2; exit 1 ;; \
esac; \
echo "Using binary: $BIN"; \
test -f "$BIN"; \
cp "$BIN" /telemt
# --- Install UPX (arch-aware) ---
RUN set -eux; \
case "${TARGETARCH}" in \
amd64) UPX_ARCH="amd64" ;; \
arm64) UPX_ARCH="arm64" ;; \
*) echo "Unsupported TARGETARCH: ${TARGETARCH}" >&2; exit 1 ;; \
esac; \
\ \
&& curl -fL \ curl -fL \
--retry 5 \ --retry 5 \
--retry-delay 3 \ --retry-delay 3 \
--connect-timeout 10 \ --connect-timeout 10 \
--max-time 120 \ --max-time 120 \
-o /tmp/upx.tar.xz \ -o /tmp/upx.tar.xz \
https://github.com/telemt/telemt/releases/download/toolchains/upx-amd64_linux.tar.xz \ "https://github.com/telemt/telemt/releases/download/toolchains/upx-${UPX_ARCH}_linux.tar.xz"; \
&& tar -xf /tmp/upx.tar.xz -C /tmp \ \
&& mv /tmp/upx*/upx /usr/local/bin/upx \ tar -xf /tmp/upx.tar.xz -C /tmp; \
&& chmod +x /usr/local/bin/upx \ install -m 0755 /tmp/upx*/upx /usr/local/bin/upx; \
&& rm -rf /tmp/upx* rm -rf /tmp/upx*
COPY ${BINARY} /telemt # --- Optimize binary ---
RUN set -eux; \
RUN strip /telemt || true test -f /telemt; \
RUN upx --best --lzma /telemt || true strip --strip-unneeded /telemt || true; \
upx --best --lzma /telemt || true
# ========================== # ==========================
# Debug image # Debug Image
# ========================== # ==========================
FROM debian:12-slim AS debug FROM debian:12-slim AS debug
RUN apt-get update && apt-get install -y --no-install-recommends \ RUN set -eux; \
ca-certificates \ apt-get update; \
tzdata \ apt-get install -y --no-install-recommends \
curl \ ca-certificates \
iproute2 \ tzdata \
busybox \ curl \
&& rm -rf /var/lib/apt/lists/* iproute2 \
busybox; \
rm -rf /var/lib/apt/lists/*
WORKDIR /app WORKDIR /app
@ -54,7 +85,7 @@ ENTRYPOINT ["/app/telemt"]
CMD ["config.toml"] CMD ["config.toml"]
# ========================== # ==========================
# Production (REAL distroless) # Production Distroless on MUSL
# ========================== # ==========================
FROM gcr.io/distroless/static-debian12 AS prod FROM gcr.io/distroless/static-debian12 AS prod
@ -68,4 +99,4 @@ USER nonroot:nonroot
EXPOSE 443 9090 9091 EXPOSE 443 9090 9091
ENTRYPOINT ["/app/telemt"] ENTRYPOINT ["/app/telemt"]
CMD ["config.toml"] CMD ["config.toml"]