update docker and release workflow
This commit is contained in:
@@ -1,57 +0,0 @@
|
|||||||
name: Sing-box Docker Image CI
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: Get latest release
|
|
||||||
id: get_release
|
|
||||||
run: |
|
|
||||||
latest_release=$(curl -Ls "https://api.github.com/repos/sagernet/sing-box/releases/latest" | grep '"tag_name":' | sed -E 's/.*"([^"]+)".*/\1/')
|
|
||||||
echo "latest_release: $latest_release"
|
|
||||||
echo "latest_release=$latest_release" >> $GITHUB_OUTPUT
|
|
||||||
|
|
||||||
- name: Docker meta
|
|
||||||
id: meta
|
|
||||||
uses: docker/metadata-action@v5
|
|
||||||
with:
|
|
||||||
images: |
|
|
||||||
alireza7/s-ui-singbox
|
|
||||||
ghcr.io/alireza0/s-ui-singbox
|
|
||||||
tags: |
|
|
||||||
type=sha
|
|
||||||
type=pep440,pattern=${{ steps.get_release.outputs.latest_release }}
|
|
||||||
|
|
||||||
- name: Set up QEMU
|
|
||||||
uses: docker/setup-qemu-action@v3
|
|
||||||
|
|
||||||
- name: Set up Docker Buildx
|
|
||||||
uses: docker/setup-buildx-action@v3
|
|
||||||
|
|
||||||
- name: Login to Docker Hub
|
|
||||||
uses: docker/login-action@v3
|
|
||||||
with:
|
|
||||||
username: ${{ secrets.DOCKER_HUB_USERNAME }}
|
|
||||||
password: ${{ secrets.DOCKER_HUB_TOKEN }}
|
|
||||||
|
|
||||||
- name: Login to GHCR
|
|
||||||
uses: docker/login-action@v3
|
|
||||||
with:
|
|
||||||
registry: ghcr.io
|
|
||||||
username: ${{ github.repository_owner }}
|
|
||||||
password: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
|
|
||||||
- name: Build and push
|
|
||||||
uses: docker/build-push-action@v6
|
|
||||||
with:
|
|
||||||
context: core/
|
|
||||||
push: true
|
|
||||||
build-args: SINGBOX_VER=${{ steps.get_release.outputs.latest_release }}
|
|
||||||
platforms: linux/amd64,linux/arm64/v8,linux/arm/v7,linux/386
|
|
||||||
tags: ${{ steps.meta.outputs.tags }}
|
|
||||||
labels: ${{ steps.meta.outputs.labels }}
|
|
||||||
@@ -60,7 +60,7 @@ jobs:
|
|||||||
cd ..
|
cd ..
|
||||||
mv frontend/dist backend/web/html
|
mv frontend/dist backend/web/html
|
||||||
|
|
||||||
- name: Build s-ui & singbox
|
- name: Build s-ui
|
||||||
run: |
|
run: |
|
||||||
export CGO_ENABLED=1
|
export CGO_ENABLED=1
|
||||||
export GOOS=linux
|
export GOOS=linux
|
||||||
@@ -88,27 +88,15 @@ jobs:
|
|||||||
export CC=s390x-linux-gnu-gcc
|
export CC=s390x-linux-gnu-gcc
|
||||||
fi
|
fi
|
||||||
|
|
||||||
#### Build Sing-Box
|
|
||||||
export VERSION=v1.10.1
|
|
||||||
git clone -b $VERSION https://github.com/SagerNet/sing-box
|
|
||||||
cd sing-box
|
|
||||||
go build -tags with_quic,with_grpc,with_wireguard,with_ech,with_utls,with_reality_server,with_acme,with_v2ray_api,with_clash_api,with_gvisor \
|
|
||||||
-v -trimpath -ldflags "-X 'github.com/sagernet/sing-box/constant.Version=${VERSION}' -s -w -buildid=" \
|
|
||||||
-o sing-box ./cmd/sing-box
|
|
||||||
cd ..
|
|
||||||
|
|
||||||
### Build s-ui
|
### Build s-ui
|
||||||
cd backend
|
cd backend
|
||||||
go build -o ../sui main.go
|
go build -ldflags="-w -s" -tags "with_quic,with_grpc,with_ech,with_utls,with_reality_server,with_acme,with_gvisor" -o ../sui main.go
|
||||||
cd ..
|
cd ..
|
||||||
|
|
||||||
mkdir s-ui
|
mkdir s-ui
|
||||||
cp sui s-ui/
|
cp sui s-ui/
|
||||||
cp s-ui.service s-ui/
|
cp s-ui.service s-ui/
|
||||||
cp sing-box.service s-ui/
|
cp s-ui.sh s-ui/
|
||||||
mkdir s-ui/bin
|
|
||||||
cp sing-box/sing-box s-ui/bin/
|
|
||||||
cp core/runSingbox.sh s-ui/bin/
|
|
||||||
|
|
||||||
- name: Package
|
- name: Package
|
||||||
run: tar -zcvf s-ui-linux-${{ matrix.platform }}.tar.gz s-ui
|
run: tar -zcvf s-ui-linux-${{ matrix.platform }}.tar.gz s-ui
|
||||||
|
|||||||
+1
-1
@@ -12,7 +12,7 @@ ENV GOARCH=$TARGETARCH
|
|||||||
RUN apk update && apk --no-cache --update add build-base gcc wget unzip
|
RUN apk update && apk --no-cache --update add build-base gcc wget unzip
|
||||||
COPY backend/ ./
|
COPY backend/ ./
|
||||||
COPY --from=front-builder /app/dist/ /app/web/html/
|
COPY --from=front-builder /app/dist/ /app/web/html/
|
||||||
RUN go build -ldflags="-w -s" -o sui main.go
|
RUN go build -ldflags="-w -s" -tags "with_quic,with_grpc,with_ech,with_utls,with_reality_server,with_acme,with_gvisor" -o sui main.go
|
||||||
|
|
||||||
FROM --platform=$TARGETPLATFORM alpine
|
FROM --platform=$TARGETPLATFORM alpine
|
||||||
LABEL org.opencontainers.image.authors="alireza7@gmail.com"
|
LABEL org.opencontainers.image.authors="alireza7@gmail.com"
|
||||||
|
|||||||
@@ -12,4 +12,4 @@ mkdir -p web/html
|
|||||||
rm -fr web/html/*
|
rm -fr web/html/*
|
||||||
cp -R ../frontend/dist/* web/html/
|
cp -R ../frontend/dist/* web/html/
|
||||||
|
|
||||||
go build -o ../sui main.go
|
go build -tags "with_quic,with_grpc,with_ech,with_utls,with_reality_server,with_acme,with_gvisor" -o ../sui main.go
|
||||||
|
|||||||
+1
-61
@@ -3,15 +3,10 @@ services:
|
|||||||
s-ui:
|
s-ui:
|
||||||
image: alireza7/s-ui
|
image: alireza7/s-ui
|
||||||
container_name: s-ui
|
container_name: s-ui
|
||||||
hostname: "S-UI docker"
|
hostname: "s-ui"
|
||||||
volumes:
|
volumes:
|
||||||
- "singbox:/app/bin"
|
|
||||||
- "./db:/app/db"
|
- "./db:/app/db"
|
||||||
- "./cert:/app/cert"
|
- "./cert:/app/cert"
|
||||||
- "logs:/logs"
|
|
||||||
environment:
|
|
||||||
SINGBOX_API: "sing-box:1080"
|
|
||||||
SUI_DB_FOLDER: "db"
|
|
||||||
tty: true
|
tty: true
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
ports:
|
ports:
|
||||||
@@ -19,64 +14,9 @@ services:
|
|||||||
- "2096:2096"
|
- "2096:2096"
|
||||||
networks:
|
networks:
|
||||||
- s-ui
|
- s-ui
|
||||||
links:
|
|
||||||
- syslog
|
|
||||||
logging:
|
|
||||||
driver: syslog
|
|
||||||
options:
|
|
||||||
tag: "s-ui"
|
|
||||||
syslog-address: "udp://127.0.0.1:1514"
|
|
||||||
entrypoint: "./entrypoint.sh"
|
entrypoint: "./entrypoint.sh"
|
||||||
depends_on:
|
|
||||||
- syslog
|
|
||||||
|
|
||||||
sing-box:
|
|
||||||
image: alireza7/s-ui-singbox
|
|
||||||
container_name: sing-box
|
|
||||||
volumes:
|
|
||||||
- "singbox:/app/"
|
|
||||||
- "./cert:/cert"
|
|
||||||
networks:
|
|
||||||
- s-ui
|
|
||||||
ports:
|
|
||||||
- "443:443"
|
|
||||||
- "1443:1443"
|
|
||||||
- "2443:2443"
|
|
||||||
- "3443:3443"
|
|
||||||
restart: unless-stopped
|
|
||||||
links:
|
|
||||||
- syslog
|
|
||||||
logging:
|
|
||||||
driver: syslog
|
|
||||||
options:
|
|
||||||
tag: "sing-box"
|
|
||||||
syslog-address: "udp://127.0.0.1:1514"
|
|
||||||
depends_on:
|
|
||||||
- s-ui
|
|
||||||
- syslog
|
|
||||||
|
|
||||||
syslog:
|
|
||||||
image: rsyslog/syslog_appliance_alpine
|
|
||||||
container_name: syslog
|
|
||||||
volumes:
|
|
||||||
- "logs:/logs"
|
|
||||||
networks:
|
|
||||||
- s-ui
|
|
||||||
ports:
|
|
||||||
- "127.0.0.1:1514:1514/udp"
|
|
||||||
restart: unless-stopped
|
|
||||||
environment:
|
|
||||||
- RSYSLOG_CONF_GLOBAL_CONF=template(name="RemoteLogs" type="string" string="/logs/%programname%.log")
|
|
||||||
- RSYSLOG_CONF_INPUT_UDP="input(type=\"imudp\" port=\"1514\" ruleset=\"remote\")"
|
|
||||||
- RSYSLOG_CONF_RULESET_REMOTE="ruleset(name=\"remote\") { action(type=\"omfile\" dynaFile=\"RemoteLogs\") }"
|
|
||||||
command: >
|
|
||||||
sh -c 'touch /config/container_config'
|
|
||||||
|
|
||||||
networks:
|
networks:
|
||||||
s-ui:
|
s-ui:
|
||||||
driver: bridge
|
driver: bridge
|
||||||
|
|
||||||
volumes:
|
|
||||||
logs:
|
|
||||||
singbox:
|
|
||||||
|
|
||||||
Reference in New Issue
Block a user