Compare commits

...

10 commits

9 changed files with 258 additions and 19 deletions

View file

@ -0,0 +1,92 @@
name: Build Docker Images (Mainline)
on:
workflow_dispatch:
inputs:
branch:
description: "The branch version you want to build"
required: true
default: "main"
repository_dispatch:
types: [build-mainline]
jobs:
build:
strategy:
fail-fast: true
matrix:
buildType: [full]
distro: [alpine]
runs-on: ubuntu-latest
steps:
- name: Checkout Source Code of 'SagerNet/sing-box'
uses: actions/checkout@v3
with:
repository: 'SagerNet/sing-box'
ref: ${{ github.event.inputs.branch }}
submodules: true
- name: Checkout Action Repo
uses: actions/checkout@v3
with:
path: action
- name: Setup Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Setup QEMU for Docker Buildx
uses: docker/setup-qemu-action@v2
- name: Login to Docker Hub Container Registry
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Docker metadata
id: metadata
uses: docker/metadata-action@v4
with:
images: etnperlong/sing-box
- name: Select Dockerfile
id: dockerfile
run: |
if [[ "${{ matrix.buildType }}" == "full" ]]; then
if [[ "${{ matrix.distro }}" == "distroless" ]]; then
cp "$GITHUB_WORKSPACE/action/dockerfiles/Dockerfile.distroless.full" "$GITHUB_WORKSPACE/Dockerfile"
echo "tagpost=full-distroless" >> $GITHUB_OUTPUT
else
cp "$GITHUB_WORKSPACE/action/dockerfiles/Dockerfile.full" "$GITHUB_WORKSPACE/Dockerfile"
# echo "tagpost=full" >> $GITHUB_OUTPUT
fi
elif [[ "${{ matrix.buildType }}" == "minimized" ]]; then
if [[ "${{ matrix.distro }}" == "distroless" ]]; then
cp "$GITHUB_WORKSPACE/action/dockerfiles/Dockerfile.distroless.minimized" "$GITHUB_WORKSPACE/Dockerfile"
echo "tagpost=mini-distroless" >> $GITHUB_OUTPUT
else
cp "$GITHUB_WORKSPACE/action/dockerfiles/Dockerfile.minimized" "$GITHUB_WORKSPACE/Dockerfile"
echo "tagpost=mini" >> $GITHUB_OUTPUT
fi
else
if [[ "${{ matrix.distro }}" == "distroless" ]]; then
cp "$GITHUB_WORKSPACE/action/dockerfiles/Dockerfile.distroless.standard" "$GITHUB_WORKSPACE/Dockerfile"
echo "tagpost=distroless" >> $GITHUB_OUTPUT
else
cp "$GITHUB_WORKSPACE/action/dockerfiles/Dockerfile.standard" "$GITHUB_WORKSPACE/Dockerfile"
fi
fi
- name: Get tag to build
id: tag
run: |
if [[ -z "${{ github.event.inputs.branch }}" ]]; then
echo "versioned=etnperlong/sing-box:${{ github.ref_name }}" >> $GITHUB_OUTPUT
else
if [[ -n "${{ steps.dockerfile.outputs.tagpost }}" ]]; then
echo "versioned=etnperlong/sing-box:${{ github.event.inputs.branch }}-${{ steps.dockerfile.outputs.tagpost }}" >> $GITHUB_OUTPUT
else
echo "versioned=etnperlong/sing-box:${{ github.event.inputs.branch }}" >> $GITHUB_OUTPUT
fi
fi
- name: Build and release Docker images
uses: docker/build-push-action@v4
with:
context: .
platforms: linux/amd64,linux/arm64,linux/arm/v7
target: dist
tags: |
${{ steps.tag.outputs.versioned }}
push: true

View file

@ -0,0 +1,103 @@
name: Build Docker Images (Pre-Release)
on:
workflow_dispatch:
inputs:
tag:
description: "The tag version you want to build"
required: true
default: "main"
repository_dispatch:
types: [build-prerelease]
jobs:
build:
strategy:
fail-fast: true
matrix:
buildType: [full]
distro: [alpine]
runs-on: ubuntu-latest
env:
TAG: ${{ github.event.client_payload.tag || github.event.inputs.tag}}
steps:
- name: Get Build Tags
run: |
echo "Version: ${{env.TAG}}"
- name: Checkout Source Code of 'SagerNet/sing-box'
uses: actions/checkout@v3
with:
repository: 'SagerNet/sing-box'
ref: ${{env.TAG}}
submodules: true
- name: Checkout Action Repo
uses: actions/checkout@v3
with:
path: action
- name: Setup Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Setup QEMU for Docker Buildx
uses: docker/setup-qemu-action@v2
- name: Login to Docker Hub Container Registry
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Docker metadata
id: metadata
uses: docker/metadata-action@v4
with:
images: etnperlong/sing-box
- name: Select Dockerfile
id: dockerfile
run: |
if [[ "${{ matrix.buildType }}" == "full" ]]; then
if [[ "${{ matrix.distro }}" == "distroless" ]]; then
cp "$GITHUB_WORKSPACE/action/dockerfiles/Dockerfile.distroless.full" "$GITHUB_WORKSPACE/Dockerfile"
echo "tagpost=full-distroless" >> $GITHUB_OUTPUT
else
cp "$GITHUB_WORKSPACE/action/dockerfiles/Dockerfile.full" "$GITHUB_WORKSPACE/Dockerfile"
# echo "tagpost=full" >> $GITHUB_OUTPUT
fi
elif [[ "${{ matrix.buildType }}" == "minimized" ]]; then
if [[ "${{ matrix.distro }}" == "distroless" ]]; then
cp "$GITHUB_WORKSPACE/action/dockerfiles/Dockerfile.distroless.minimized" "$GITHUB_WORKSPACE/Dockerfile"
echo "tagpost=mini-distroless" >> $GITHUB_OUTPUT
else
cp "$GITHUB_WORKSPACE/action/dockerfiles/Dockerfile.minimized" "$GITHUB_WORKSPACE/Dockerfile"
echo "tagpost=mini" >> $GITHUB_OUTPUT
fi
else
if [[ "${{ matrix.distro }}" == "distroless" ]]; then
cp "$GITHUB_WORKSPACE/action/dockerfiles/Dockerfile.distroless.standard" "$GITHUB_WORKSPACE/Dockerfile"
echo "tagpost=distroless" >> $GITHUB_OUTPUT
else
cp "$GITHUB_WORKSPACE/action/dockerfiles/Dockerfile.standard" "$GITHUB_WORKSPACE/Dockerfile"
fi
fi
- name: Get tag to build
id: tag
run: |
if [[ "${{ matrix.distro }}" == "alpine" && "${{ matrix.buildType }}" == "full" ]]; then
echo "latest=etnperlong/sing-box:latest" >> $GITHUB_OUTPUT
fi
if [[ "${{ matrix.distro }}" == "distroless" && "${{ matrix.buildType }}" == "full" ]]; then
echo "latest=etnperlong/sing-box:distroless" >> $GITHUB_OUTPUT
fi
if [[ -z "${{env.TAG}}" ]]; then
echo "versioned=etnperlong/sing-box:${{ github.ref_name }}" >> $GITHUB_OUTPUT
else
if [[ -n "${{ steps.dockerfile.outputs.tagpost }}" ]]; then
echo "versioned=etnperlong/sing-box:${{env.TAG}}-${{ steps.dockerfile.outputs.tagpost }}" >> $GITHUB_OUTPUT
else
echo "versioned=etnperlong/sing-box:${{env.TAG}}" >> $GITHUB_OUTPUT
fi
fi
- name: Build and pre-release Docker images
uses: docker/build-push-action@v4
with:
context: .
platforms: linux/amd64,linux/arm64,linux/arm/v7
target: dist
tags: |
${{ steps.tag.outputs.versioned }}
push: true

View file

@ -6,21 +6,28 @@ on:
description: "The tag version you want to build"
required: true
default: "main"
repository_dispatch:
types: [build-release]
jobs:
build:
strategy:
fail-fast: true
matrix:
buildType: [standard, minimized, full]
distro: [alpine, distroless]
buildType: [full]
distro: [alpine]
runs-on: ubuntu-latest
env:
TAG: ${{ github.event.client_payload.tag || github.event.inputs.tag}}
steps:
- name: Get Build Tags
run: |
echo "Version: ${{env.TAG}}"
- name: Checkout Source Code of 'SagerNet/sing-box'
uses: actions/checkout@v3
with:
repository: 'SagerNet/sing-box'
ref: ${{ github.event.inputs.tag }}
ref: ${{env.TAG}}
submodules: true
- name: Checkout Action Repo
uses: actions/checkout@v3
@ -49,7 +56,7 @@ jobs:
echo "tagpost=full-distroless" >> $GITHUB_OUTPUT
else
cp "$GITHUB_WORKSPACE/action/dockerfiles/Dockerfile.full" "$GITHUB_WORKSPACE/Dockerfile"
echo "tagpost=full" >> $GITHUB_OUTPUT
# echo "tagpost=full" >> $GITHUB_OUTPUT
fi
elif [[ "${{ matrix.buildType }}" == "minimized" ]]; then
if [[ "${{ matrix.distro }}" == "distroless" ]]; then
@ -70,17 +77,19 @@ jobs:
- name: Get tag to build
id: tag
run: |
if [[ "${{ matrix.distro }}" == "alpine" && "${{ matrix.buildType }}" == "standard" ]]; then
latest="etnperlong/sing-box:latest"
echo "latest=$latest" >> $GITHUB_OUTPUT
if [[ "${{ matrix.distro }}" == "alpine" && "${{ matrix.buildType }}" == "full" ]]; then
echo "latest=etnperlong/sing-box:latest" >> $GITHUB_OUTPUT
fi
if [[ -z "${{ github.event.inputs.tag }}" ]]; then
if [[ "${{ matrix.distro }}" == "distroless" && "${{ matrix.buildType }}" == "full" ]]; then
echo "latest=etnperlong/sing-box:distroless" >> $GITHUB_OUTPUT
fi
if [[ -z "${{env.TAG}}" ]]; then
echo "versioned=etnperlong/sing-box:${{ github.ref_name }}" >> $GITHUB_OUTPUT
else
if [[ -n "${{ steps.dockerfile.outputs.tagpost }}" ]]; then
echo "versioned=etnperlong/sing-box:${{ github.event.inputs.tag }}-${{ steps.dockerfile.outputs.tagpost }}" >> $GITHUB_OUTPUT
echo "versioned=etnperlong/sing-box:${{env.TAG}}-${{ steps.dockerfile.outputs.tagpost }}" >> $GITHUB_OUTPUT
else
echo "versioned=etnperlong/sing-box:${{ github.event.inputs.tag }}" >> $GITHUB_OUTPUT
echo "versioned=etnperlong/sing-box:${{env.TAG}}" >> $GITHUB_OUTPUT
fi
fi
- name: Build and release Docker images

35
README.md Normal file
View file

@ -0,0 +1,35 @@
# sing-box Docker Image by etnperlong
![Docker Stars](https://img.shields.io/docker/stars/etnperlong/sing-box.svg) ![Docker Pulls](https://img.shields.io/docker/pulls/etnperlong/sing-box.svg)
[sing-box](https://sing-box.sagernet.org/) is a universal proxy platform for building your own proxy.
Docker images are designed for rapid deployment to various computing cloud providers.
For more information on Docker and containerization technologies, read the [official document](https://docs.docker.com/).
## Documentation
[https://sing-box.sagernet.org](https://sing-box.sagernet.org)
## Community
[https://community.sagernet.org/c/sing-box/](https://community.sagernet.org/c/sing-box/)
## Supported architectures
- amd64
- arm64
- arm/v7
## Enabled features
**Full version!**
> `with_gvisor,with_quic,with_grpc,with_dhcp,with_wireguard,with_shadowsocksr,with_ech,with_utls,with_reality_server,with_clash_api,with_v2ray_api,with_acme`
## Supported tags
- `latest` *([latest release](https://github.com/SagerNet/sing-box/releases))*
- `main` *([main branch](https://github.com/SagerNet/sing-box/tree/main))*
- `dev` *([dev branch](https://github.com/SagerNet/sing-box/tree/dev))*
- `dev-next` *([dev-next branch](https://github.com/SagerNet/sing-box/tree/dev))*
For example, `etnperlong/sing-box:dev-next` means a fully functional docker image.

View file

@ -13,7 +13,7 @@ RUN set -ex \
-o /go/bin/sing-box \
-ldflags "-X \"github.com/sagernet/sing-box/constant.Version=$VERSION\" -s -w -buildid=" \
./cmd/sing-box
FROM gcr.io/distroless/base-debian11:nonroot AS dist
FROM gcr.io/distroless/static-debian11:latest AS dist
LABEL maintainer="Evans Mike <etnperlong@gmail.com>"
COPY --from=builder /go/bin/sing-box /
CMD ["/sing-box"]
ENTRYPOINT ["/sing-box"]

View file

@ -13,7 +13,7 @@ RUN set -ex \
-o /go/bin/sing-box \
-ldflags "-X \"github.com/sagernet/sing-box/constant.Version=$VERSION\" -s -w -buildid=" \
./cmd/sing-box
FROM gcr.io/distroless/base-debian11:nonroot AS dist
FROM gcr.io/distroless/static-debian11:latest AS dist
LABEL maintainer="Evans Mike <etnperlong@gmail.com>"
COPY --from=builder /go/bin/sing-box /
CMD ["/sing-box"]
ENTRYPOINT ["/sing-box"]

View file

@ -13,7 +13,7 @@ RUN set -ex \
-o /go/bin/sing-box \
-ldflags "-X \"github.com/sagernet/sing-box/constant.Version=$VERSION\" -s -w -buildid=" \
./cmd/sing-box
FROM gcr.io/distroless/base-debian11:nonroot AS dist
FROM gcr.io/distroless/static-debian11:latest AS dist
LABEL maintainer="Evans Mike <etnperlong@gmail.com>"
COPY --from=builder /go/bin/sing-box /
CMD ["/sing-box"]
ENTRYPOINT ["/sing-box"]

View file

@ -1,4 +1,4 @@
FROM golang:1.20-alpine AS builder
FROM golang:1.21-alpine AS builder
LABEL maintainer="nekohasekai <contact-git@sekai.icu>"
COPY . /go/src/github.com/sagernet/sing-box
WORKDIR /go/src/github.com/sagernet/sing-box
@ -9,7 +9,7 @@ RUN set -ex \
&& apk add git build-base \
&& export COMMIT=$(git rev-parse --short HEAD) \
&& export VERSION=$(go run ./cmd/internal/read_tag) \
&& go build -v -trimpath -tags with_gvisor,with_quic,with_grpc,with_dhcp,with_wireguard,with_shadowsocksr,with_ech,with_utls,with_reality_server,with_clash_api,with_v2ray_api,with_acme \
&& go build -v -trimpath -tags with_gvisor,with_quic,with_grpc,with_dhcp,with_wireguard,with_ech,with_utls,with_reality_server,with_clash_api,with_acme,with_v2ray_api \
-o /go/bin/sing-box \
-ldflags "-X \"github.com/sagernet/sing-box/constant.Version=$VERSION\" -s -w -buildid=" \
./cmd/sing-box

View file

@ -9,7 +9,7 @@ RUN set -ex \
&& apk add git build-base \
&& export COMMIT=$(git rev-parse --short HEAD) \
&& export VERSION=$(go run ./cmd/internal/read_tag) \
&& go build -v -trimpath -tags with_gvisor,with_quic,with_wireguard,with_utls,with_reality_server,with_clash_api,with_acme \
&& go build -v -trimpath -tags with_gvisor,with_quic,with_dhcp,with_wireguard,with_utls,with_reality_server,with_clash_api,with_acme \
-o /go/bin/sing-box \
-ldflags "-X \"github.com/sagernet/sing-box/constant.Version=$VERSION\" -s -w -buildid=" \
./cmd/sing-box