From 59402612460e2710dfae1fc52c1b671783024c31 Mon Sep 17 00:00:00 2001 From: renxia Date: Mon, 19 Feb 2024 15:10:24 +0800 Subject: [PATCH] chore: fix for docker-deploy --- .github/workflows/docker-deploy.yml | 83 +++++++++++++++++ .github/workflows/npm-publish.yml | 85 ++++++++++++++++++ .github/workflows/release.yml | 134 ---------------------------- 3 files changed, 168 insertions(+), 134 deletions(-) create mode 100644 .github/workflows/docker-deploy.yml create mode 100644 .github/workflows/npm-publish.yml delete mode 100644 .github/workflows/release.yml diff --git a/.github/workflows/docker-deploy.yml b/.github/workflows/docker-deploy.yml new file mode 100644 index 0000000..1188a56 --- /dev/null +++ b/.github/workflows/docker-deploy.yml @@ -0,0 +1,83 @@ +name: deploy to docker hub + +on: + push: + tags: + - "v*.*.*" + branches: + - 'master' + +env: + # Use docker.io for Docker Hub if empty + REGISTRY: ${{ secrets.REGISTRY }} + # github.repository as / + IMAGE_NAME: ${{ github.repository }} + +jobs: + docker-deploy: + runs-on: ubuntu-latest + steps: + - + name: Checkout + uses: actions/checkout@v4 + # - + # name: Set up QEMU + # uses: docker/setup-qemu-action@v3 + # - + # name: Set up Docker Buildx + # uses: docker/setup-buildx-action@v3 + # 提供 docker 元数据,构建 docker images tag 时使用 + - + name: Extract Docker metadata + id: meta + uses: docker/metadata-action@v5 + with: + images: ${{ env.IMAGE_NAME }} + tags: | + # set latest tag for default branch + type=raw,value=latest,enable={{is_default_branch}} + # tag event + type=ref,enable=true,priority=600,prefix=,suffix=,event=tag + - + name: Login to Docker Hub + uses: docker/login-action@v3 + with: + # registry: ghcr.io # 声明镜像源 + username: ${{ secrets.DOCKER_USERNAME }} + password: ${{ secrets.DOCKER_PASSWORD }} + - + name: Build and push + uses: docker/build-push-action@v5 + with: + context: . + # platforms: linux/amd64,linux/arm64 + push: ${{ github.event_name != 'pull_request' }} + tags: ${{ steps.meta.outputs.tags }} + labels: ${{ steps.meta.outputs.labels }} + + # - + # name: Login to Docker Hub + # run: | + # docker login --username=${{ secrets.DOCKER_USERNAME }} --password ${{ secrets.DOCKER_PASSWORD }} ${{ env.REGISTRY }} + # - + # name: Build and push Docker Image + # run: | + # docker build -t ${{ env.REGISTRY }}/${{ steps.meta.outputs.tags }} -f Dockerfile . + # docker push ${{ env.REGISTRY }}/${{ steps.meta.outputs.tags }} + + # - + # name: Deploy Docker App + # uses: appleboy/ssh-action@master + # env: + # TZ: Asia/Shanghai + # with: + # host: ${{ secrets.HOST }} + # username: ${{ secrets.HOST_USERNAME }} + # key: ${{ secrets.HOST_SSHKEY }} + # port: ${{ secrets.PORT }} + # script: | + # wget https://raw.githubusercontent.com/${{ env.IMAGE_NAME }}/master/docker/docker-compose.yml + # ls + # cat docker-compose.yml + # docker-compose down -v + # docker-compose up -d diff --git a/.github/workflows/npm-publish.yml b/.github/workflows/npm-publish.yml new file mode 100644 index 0000000..7e97002 --- /dev/null +++ b/.github/workflows/npm-publish.yml @@ -0,0 +1,85 @@ +# see: https://help.github.com/actions/language-and-framework-guides/publishing-nodejs-packages + +name: Publish to NPM + +on: + push: + tags: + - "v*.*.*" + # release: + # types: [created] + +jobs: + npm-publish: + runs-on: ubuntu-latest + permissions: + contents: write + concurrency: + group: ${{ github.workflow }}-${{ github.ref }} + steps: + - + name: Checkout + uses: actions/checkout@v4 + with: + submodules: 'recursive' + - + name: Install Node.js + uses: actions/setup-node@v3 + with: + node-version: 18 + registry-url: https://registry.npmjs.com + - + name: Install pnpm + uses: pnpm/action-setup@v2 + id: pnpm-install + with: + version: 8 + run_install: false + - + name: Get pnpm store directory + id: pnpm-cache + shell: bash + run: | + echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT + - + name: Setup pnpm cache + uses: actions/cache@v3 + with: + path: ${{ steps.pnpm-cache.outputs.STORE_PATH }} + key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} + restore-keys: | + ${{ runner.os }}-pnpm-store- + - + name: Install dependencies + run: pnpm install --no-frozen-lockfile --ignore-scripts + + # - name: Build and npm-publish + # run: npm run release + + - run: npm publish + env: + NODE_AUTH_TOKEN: ${{secrets.NPM_TOKEN}} + + # run: npm run publish:github # --registry=https://npm.pkg.github.com + # env: + # NODE_AUTH_TOKEN: ${{secrets.GITHUB_TOKEN}} + + # - name: GitHub Pages action + # uses: peaceiris/actions-gh-pages@v3 + # with: + # github_token: ${{ secrets.GITHUB_TOKEN }} + # publish_dir: ./docs + - + name: Github Release + uses: softprops/action-gh-release@v1 + if: startsWith(github.ref, 'refs/tags/') + with: + draft: false + prerelease: false + # tag_name: ${{ github.ref }} + # name: Release ${{ github.ref }} + # body: TODO New Release. + # files: | + # ${{ secrets.ReleaseZipName }}.zip + # LICENSE + diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml deleted file mode 100644 index 3434854..0000000 --- a/.github/workflows/release.yml +++ /dev/null @@ -1,134 +0,0 @@ -# see: https://help.github.com/actions/language-and-framework-guides/publishing-nodejs-packages - -name: Publish Package to npmjs - -on: - push: - tags: - - "v*.*.*" - # release: - # types: [created] - -env: - # Use docker.io for Docker Hub if empty - REGISTRY: ${{ secrets.REGISTRY }} - # github.repository as / - IMAGE_NAME: ${{ github.repository }} - -jobs: - npm-publish: - runs-on: ubuntu-latest - permissions: - contents: write - concurrency: - group: ${{ github.workflow }}-${{ github.ref }} - steps: - - name: Checkout - uses: actions/checkout@v3 - with: - submodules: 'recursive' - - - name: Install Node.js - uses: actions/setup-node@v3 - with: - node-version: 18 - registry-url: https://registry.npmjs.com - - - uses: pnpm/action-setup@v2 - name: Install pnpm - id: pnpm-install - with: - version: 8 - run_install: false - - - name: Get pnpm store directory - id: pnpm-cache - shell: bash - run: | - echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT - - - uses: actions/cache@v3 - name: Setup pnpm cache - with: - path: ${{ steps.pnpm-cache.outputs.STORE_PATH }} - key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} - restore-keys: | - ${{ runner.os }}-pnpm-store- - - - name: Install dependencies - run: pnpm install --no-frozen-lockfile --ignore-scripts - - # - name: Build and npm-publish - # run: npm run release - - - run: npm publish - env: - NODE_AUTH_TOKEN: ${{secrets.NPM_TOKEN}} - - # run: npm run publish:github # --registry=https://npm.pkg.github.com - # env: - # NODE_AUTH_TOKEN: ${{secrets.GITHUB_TOKEN}} - - # - name: GitHub Pages action - # uses: peaceiris/actions-gh-pages@v3 - # with: - # github_token: ${{ secrets.GITHUB_TOKEN }} - # publish_dir: ./docs - - - name: Github Release - uses: softprops/action-gh-release@v1 - if: startsWith(github.ref, 'refs/tags/') - with: - draft: false - prerelease: false - # tag_name: ${{ github.ref }} - # name: Release ${{ github.ref }} - # body: TODO New Release. - # files: | - # ${{ secrets.ReleaseZipName }}.zip - # LICENSE - - docker-deploy: - runs-on: ubuntu-latest - steps: - - # 提供 docker 元数据,构建 docker images tag 时使用 - - name: Extract Docker metadata - id: meta - uses: docker/metadata-action@v4 - with: - images: ${{ env.IMAGE_NAME }} - tags: | - # set latest tag for default branch - type=raw,value=latest,enable={{is_default_branch}} - # tag event - type=ref,enable=true,priority=600,prefix=,suffix=,event=tag - - # 构建镜像 使用 docker/Build-And-push@v5 插件有问题 - - uses: actions/checkout@v2 - - name: Build Docker Image - run: | - docker build -t ${{ env.REGISTRY }}/${{ steps.meta.outputs.tags }} -f ./docker/nginx/Dockerfile . - - name: Push Docker Image - run: | - docker login --username=${{ secrets.DOCKER_USERNAME }} --password ${{ secrets.DOCKER_PASSWORD }} ${{ env.REGISTRY }} - docker push ${{ env.REGISTRY }}/${{ steps.meta.outputs.tags }} - - # 运行 docker 服务 - # 另外一种选择是通过 scp 将文件传到指定服务器,完成 docker-compose 启动 - # - name: Deploy Docker App - # uses: appleboy/ssh-action@master - # env: - # TZ: Asia/Shanghai - # with: - # host: ${{ secrets.HOST }} - # username: ${{ secrets.HOST_USERNAME }} - # key: ${{ secrets.HOST_SSHKEY }} - # port: ${{ secrets.PORT }} - # script: | - # # 获取 docker-compose 文件 - # wget https://raw.githubusercontent.com/${{ env.IMAGE_NAME }}/master/docker/docker-compose.yml - # ls - # cat docker-compose.yml - # docker-compose down -v - # docker-compose up -d