mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-11-04 03:13:15 +08:00 
			
		
		
		
	* refactor: add GetAdminToken interface. * update config. * update workflows logic. * feat: improve publish docker image workflows * update condition logic. * fix: update load file logic.
		
			
				
	
	
		
			151 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			151 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
name: Publish Docker image to registries
 | 
						|
 | 
						|
on:
 | 
						|
  push:
 | 
						|
    branches:
 | 
						|
      - release-*
 | 
						|
    # tags:
 | 
						|
    #   - 'v*'
 | 
						|
 | 
						|
  release:
 | 
						|
    types: [published]
 | 
						|
 | 
						|
  workflow_dispatch:
 | 
						|
    inputs:
 | 
						|
      tag:
 | 
						|
        description: "Tag version to be used for Docker image"
 | 
						|
        required: true
 | 
						|
        default: "v3.8.0"
 | 
						|
 | 
						|
jobs:
 | 
						|
  build-and-test:
 | 
						|
    runs-on: ubuntu-latest
 | 
						|
    steps:
 | 
						|
      - uses: actions/checkout@v4
 | 
						|
        with:
 | 
						|
          path: main-repo
 | 
						|
 | 
						|
      - name: Set up QEMU
 | 
						|
        uses: docker/setup-qemu-action@v3
 | 
						|
 | 
						|
      - name: Set up Docker Buildx
 | 
						|
        uses: docker/setup-buildx-action@v3
 | 
						|
 | 
						|
      - name: Build Docker image
 | 
						|
        id: build
 | 
						|
        uses: docker/build-push-action@v5
 | 
						|
        with:
 | 
						|
          context: ./main-repo
 | 
						|
          load: true
 | 
						|
          tags: "openim/openim-server:local"
 | 
						|
          cache-from: type=gha
 | 
						|
          cache-to: type=gha,mode=max
 | 
						|
 | 
						|
      - name: Save Docker image to file
 | 
						|
        run: docker save -o image.tar openim/openim-server:local
 | 
						|
 | 
						|
      - name: Checkout compose repository
 | 
						|
        uses: actions/checkout@v4
 | 
						|
        with:
 | 
						|
          repository: "openimsdk/openim-docker"
 | 
						|
          path: "compose-repo"
 | 
						|
 | 
						|
      - name: Get Internal IP Address
 | 
						|
        id: get-ip
 | 
						|
        run: |
 | 
						|
          IP=$(hostname -I | awk '{print $1}')
 | 
						|
          echo "The IP Address is: $IP"
 | 
						|
          echo "::set-output name=ip::$IP"
 | 
						|
 | 
						|
      - name: Update .env to use the local image
 | 
						|
        run: |
 | 
						|
          sed -i 's|OPENIM_SERVER_IMAGE=.*|OPENIM_SERVER_IMAGE=openim/openim-server:local|' ${{ github.workspace }}/compose-repo/.env
 | 
						|
          sed -i 's|MINIO_EXTERNAL_ADDRESS=.*|MINIO_EXTERNAL_ADDRESS=http://${{ steps.get-ip.outputs.ip }}:10005|' ${{ github.workspace }}/compose-repo/.env
 | 
						|
 | 
						|
      - name: Start services using Docker Compose
 | 
						|
        run: |
 | 
						|
          cd ${{ github.workspace }}/compose-repo
 | 
						|
          docker compose up -d
 | 
						|
          sleep 60
 | 
						|
 | 
						|
      # - name: Check openim-server health
 | 
						|
      #   run: |
 | 
						|
      #     timeout=300
 | 
						|
      #     interval=30
 | 
						|
      #     elapsed=0
 | 
						|
      #     while [[ $elapsed -le $timeout ]]; do
 | 
						|
      #       if ! docker exec openim-server mage check; then
 | 
						|
      #         echo "openim-server is not ready, waiting..."
 | 
						|
      #         sleep $interval
 | 
						|
      #         elapsed=$(($elapsed + $interval))
 | 
						|
      #       else
 | 
						|
      #         echo "Health check successful"
 | 
						|
      #         exit 0
 | 
						|
      #       fi
 | 
						|
      #     done
 | 
						|
      #     echo "Health check failed after 5 minutes"
 | 
						|
      #     exit 1
 | 
						|
 | 
						|
      # - name: Check openim-chat health
 | 
						|
      #   if: success()
 | 
						|
      #   run: |
 | 
						|
      #     if ! docker exec openim-chat mage check; then
 | 
						|
      #         echo "openim-chat check failed"
 | 
						|
      #         exit 1
 | 
						|
      #       else
 | 
						|
      #         echo "Health check successful"
 | 
						|
      #         exit 0
 | 
						|
      #       fi
 | 
						|
 | 
						|
      - name: Load Docker image from file
 | 
						|
        run: docker load -i image.tar
 | 
						|
 | 
						|
      - name: Extract metadata for Docker (tags, labels)
 | 
						|
        id: meta
 | 
						|
        uses: docker/metadata-action@v5.5.1
 | 
						|
        with:
 | 
						|
          images: |
 | 
						|
            openim/openim-server
 | 
						|
            ghcr.io/openimsdk/openim-server
 | 
						|
            registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-server
 | 
						|
          tags: |
 | 
						|
            type=ref,event=tag
 | 
						|
            type=schedule
 | 
						|
            type=ref,event=branch
 | 
						|
            type=semver,pattern={{version}}
 | 
						|
            type=semver,pattern=v{{version}}
 | 
						|
            type=semver,pattern={{major}}.{{minor}}
 | 
						|
            type=semver,pattern={{major}}
 | 
						|
            type=semver,pattern=release-{{raw}}
 | 
						|
            type=sha
 | 
						|
            type=raw,value=${{ github.event.inputs.tag }}
 | 
						|
 | 
						|
      - name: Log in to Docker Hub
 | 
						|
        uses: docker/login-action@v2
 | 
						|
        with:
 | 
						|
          username: ${{ secrets.DOCKER_USERNAME }}
 | 
						|
          password: ${{ secrets.DOCKER_PASSWORD }}
 | 
						|
 | 
						|
      - name: Log in to GitHub Container Registry
 | 
						|
        uses: docker/login-action@v2
 | 
						|
        with:
 | 
						|
          registry: ghcr.io
 | 
						|
          username: ${{ github.repository_owner }}
 | 
						|
          password: ${{ secrets.GITHUB_TOKEN }}
 | 
						|
 | 
						|
      - name: Log in to Aliyun Container Registry
 | 
						|
        uses: docker/login-action@v2
 | 
						|
        with:
 | 
						|
          registry: registry.cn-hangzhou.aliyuncs.com
 | 
						|
          username: ${{ secrets.ALIREGISTRY_USERNAME }}
 | 
						|
          password: ${{ secrets.ALIREGISTRY_TOKEN }}
 | 
						|
 | 
						|
      - name: Push Docker images
 | 
						|
        uses: docker/build-push-action@v5
 | 
						|
        with:
 | 
						|
          context: ./main-repo
 | 
						|
          push: true
 | 
						|
          platforms: linux/amd64,linux/arm64
 | 
						|
          tags: ${{ steps.meta.outputs.tags }}
 | 
						|
          labels: ${{ steps.meta.outputs.labels }}
 |