diff options
| author | Ho3ein <ho3ein.sanaei@gmail.com> | 2023-05-07 22:15:39 +0300 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-05-07 22:15:39 +0300 |
| commit | eb83516fa58e0e84377a8694e989f45c378afe2f (patch) | |
| tree | 2ae53d186f0dc0db63404160a3ec1b6d593ba237 | |
| parent | 9bbcb74db6a935d19cf5c79c0bade33bdb253bfb (diff) | |
| parent | 1b8df3c0a17bb4f23992f225deebc52508e14072 (diff) | |
Merge pull request #360 from itspooya/main
Added Github Container registry auto build
| -rw-r--r-- | .github/workflows/docker.yml | 41 | ||||
| -rw-r--r-- | Dockerfile | 54 |
2 files changed, 95 insertions, 0 deletions
diff --git a/.github/workflows/docker.yml b/.github/workflows/docker.yml new file mode 100644 index 00000000..af7961f3 --- /dev/null +++ b/.github/workflows/docker.yml @@ -0,0 +1,41 @@ +name: Release X-ui dockerhub +on: + push: + tags: + - "*" + workflow_dispatch: + +jobs: + build_and_push: + runs-on: ubuntu-latest + + steps: + - name: Check out the code + uses: actions/checkout@v3 + - name: Set up QEMU + uses: docker/setup-qemu-action@v2 + + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v2 + + - name: Log in to GitHub Container Registry + uses: docker/login-action@v2 + with: + registry: ghcr.io + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Docker meta + id: meta + uses: docker/metadata-action@v3 + with: + images: ghcr.io/${{ github.repository }} + + - name: Build and push Docker image + uses: docker/build-push-action@v4 + with: + context: . + push: ${{ github.event_name != 'pull_request' }} + platforms: linux/amd64,linux/arm64 + tags: ${{ steps.meta.outputs.tags }} + labels: ${{ steps.meta.outputs.labels }} diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 00000000..676ea92c --- /dev/null +++ b/Dockerfile @@ -0,0 +1,54 @@ +# Use the official Golang image as the base image +FROM golang:1.20 as builder + +ARG TARGETARCH +ARG TARGETOS + +# Set up the working directory +WORKDIR /app + +# Copy the Go modules and download the dependencies +COPY go.mod go.sum ./ +RUN go mod download + +# Copy the source code +COPY . . + +# Build the X-ui binary +RUN CGO_ENABLED=1 GOOS=${TARGETOS} GOARCH=${TARGETARCH} go build -o xui-release-${TARGETARCH} -v main.go + +# Start a new stage using the base image +FROM ubuntu:20.04 + +ARG TARGETARCH + +# Set up the working directory +WORKDIR /app + +# Copy the X-ui binary and required files from the builder stage +COPY --from=builder /app/xui-release-${TARGETARCH} /app/x-ui/xui-release +COPY x-ui.service /app/x-ui/x-ui.service +COPY x-ui.sh /app/x-ui/x-ui.sh + +# Set up the runtime environment +RUN apt-get update && apt-get install -y \ + wget \ + unzip \ + && rm -rf /var/lib/apt/lists/* + +WORKDIR /app/x-ui/bin + +# Download and set up the required files +RUN wget https://github.com/mhsanaei/Xray-core/releases/latest/download/Xray-linux-64.zip \ + && unzip Xray-linux-64.zip \ + && rm -f Xray-linux-64.zip geoip.dat geosite.dat iran.dat \ + && wget https://github.com/Loyalsoldier/v2ray-rules-dat/releases/latest/download/geoip.dat \ + && wget https://github.com/Loyalsoldier/v2ray-rules-dat/releases/latest/download/geosite.dat \ + && wget https://github.com/bootmortis/iran-hosted-domains/releases/latest/download/iran.dat \ + && mv xray xray-linux-\${TARGETARCH} + +WORKDIR /app +RUN chmod +x /app/x-ui/x-ui.sh + +# Set the entrypoint +ENTRYPOINT ["/app/x-ui/x-ui.sh"] |
