fix: build om docker file na raiz #10
@ -109,11 +109,11 @@ jobs:
|
|||||||
BRANCH_NAME="${{ github.ref_name }}"
|
BRANCH_NAME="${{ github.ref_name }}"
|
||||||
|
|
||||||
if [ "$BRANCH_NAME" = "main" ]; then
|
if [ "$BRANCH_NAME" = "main" ]; then
|
||||||
# Main = Produção (ARM64)
|
# Main = Produção (ARM64) - usando Dockerfile da raiz como QRRapido
|
||||||
echo "tag=latest" >> $GITHUB_OUTPUT
|
echo "tag=latest" >> $GITHUB_OUTPUT
|
||||||
echo "platform=linux/arm64" >> $GITHUB_OUTPUT
|
echo "platform=linux/arm64" >> $GITHUB_OUTPUT
|
||||||
echo "environment=Production" >> $GITHUB_OUTPUT
|
echo "environment=Production" >> $GITHUB_OUTPUT
|
||||||
echo "dockerfile=src/BCards.Web/Dockerfile" >> $GITHUB_OUTPUT
|
echo "dockerfile=Dockerfile" >> $GITHUB_OUTPUT
|
||||||
echo "deploy_target=production" >> $GITHUB_OUTPUT
|
echo "deploy_target=production" >> $GITHUB_OUTPUT
|
||||||
elif [[ "$BRANCH_NAME" == Release/* ]]; then
|
elif [[ "$BRANCH_NAME" == Release/* ]]; then
|
||||||
# Release = Staging (x86)
|
# Release = Staging (x86)
|
||||||
@ -194,11 +194,18 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
echo "🚀 Deploying to production servers (ARM64)..."
|
echo "🚀 Deploying to production servers (ARM64)..."
|
||||||
|
|
||||||
# Configura SSH
|
# Configura SSH (igual ao QRRapido)
|
||||||
mkdir -p ~/.ssh
|
mkdir -p ~/.ssh
|
||||||
echo "${{ secrets.SSH_PRIVATE_KEY }}" > ~/.ssh/id_rsa
|
echo "${{ secrets.SSH_PRIVATE_KEY }}" > ~/.ssh/id_rsa
|
||||||
chmod 600 ~/.ssh/id_rsa
|
chmod 600 ~/.ssh/id_rsa
|
||||||
|
|
||||||
|
# Adiciona hosts conhecidos
|
||||||
|
ssh-keyscan -H 141.148.162.114 >> ~/.ssh/known_hosts
|
||||||
|
ssh-keyscan -H 129.146.116.218 >> ~/.ssh/known_hosts
|
||||||
|
|
||||||
|
# Testa a chave SSH
|
||||||
|
ssh-add ~/.ssh/id_rsa 2>/dev/null || echo "SSH key loaded"
|
||||||
|
|
||||||
# Deploy no Servidor 1 (ARM - OCI)
|
# Deploy no Servidor 1 (ARM - OCI)
|
||||||
ssh -o StrictHostKeyChecking=no ubuntu@141.148.162.114 << 'EOF'
|
ssh -o StrictHostKeyChecking=no ubuntu@141.148.162.114 << 'EOF'
|
||||||
echo "🔄 Atualizando Servidor 1..."
|
echo "🔄 Atualizando Servidor 1..."
|
||||||
@ -296,11 +303,18 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
echo "🚀 Deploying to staging server (x86)..."
|
echo "🚀 Deploying to staging server (x86)..."
|
||||||
|
|
||||||
# Configura SSH
|
# Configura SSH (igual ao QRRapido)
|
||||||
mkdir -p ~/.ssh
|
mkdir -p ~/.ssh
|
||||||
echo "${{ secrets.SSH_PRIVATE_KEY }}" > ~/.ssh/id_rsa
|
echo "${{ secrets.SSH_PRIVATE_KEY }}" > ~/.ssh/id_rsa
|
||||||
chmod 600 ~/.ssh/id_rsa
|
chmod 600 ~/.ssh/id_rsa
|
||||||
|
|
||||||
|
# Adiciona hosts conhecidos
|
||||||
|
ssh-keyscan -H 141.148.162.114 >> ~/.ssh/known_hosts
|
||||||
|
ssh-keyscan -H 129.146.116.218 >> ~/.ssh/known_hosts
|
||||||
|
|
||||||
|
# Testa a chave SSH
|
||||||
|
ssh-add ~/.ssh/id_rsa 2>/dev/null || echo "SSH key loaded"
|
||||||
|
|
||||||
# Deploy no Servidor Local x86
|
# Deploy no Servidor Local x86
|
||||||
ssh -o StrictHostKeyChecking=no ubuntu@192.168.0.100 << EOF
|
ssh -o StrictHostKeyChecking=no ubuntu@192.168.0.100 << EOF
|
||||||
echo "🔄 Atualizando Servidor Staging..."
|
echo "🔄 Atualizando Servidor Staging..."
|
||||||
@ -350,11 +364,18 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
echo "🧹 Limpando recursos antigos..."
|
echo "🧹 Limpando recursos antigos..."
|
||||||
|
|
||||||
# Configura SSH
|
# Configura SSH (igual ao QRRapido)
|
||||||
mkdir -p ~/.ssh
|
mkdir -p ~/.ssh
|
||||||
echo "${{ secrets.SSH_PRIVATE_KEY }}" > ~/.ssh/id_rsa
|
echo "${{ secrets.SSH_PRIVATE_KEY }}" > ~/.ssh/id_rsa
|
||||||
chmod 600 ~/.ssh/id_rsa
|
chmod 600 ~/.ssh/id_rsa
|
||||||
|
|
||||||
|
# Adiciona hosts conhecidos
|
||||||
|
ssh-keyscan -H 141.148.162.114 >> ~/.ssh/known_hosts
|
||||||
|
ssh-keyscan -H 129.146.116.218 >> ~/.ssh/known_hosts
|
||||||
|
|
||||||
|
# Testa a chave SSH
|
||||||
|
ssh-add ~/.ssh/id_rsa 2>/dev/null || echo "SSH key loaded"
|
||||||
|
|
||||||
# Lista de servidores baseada na branch
|
# Lista de servidores baseada na branch
|
||||||
if [ "${{ github.ref_name }}" = "main" ]; then
|
if [ "${{ github.ref_name }}" = "main" ]; then
|
||||||
SERVERS=("141.148.162.114" "129.146.116.218")
|
SERVERS=("141.148.162.114" "129.146.116.218")
|
||||||
|
|||||||
39
Dockerfile
Normal file
39
Dockerfile
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
# Dockerfile - Production build (similar to QRRapido structure)
|
||||||
|
FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS base
|
||||||
|
WORKDIR /app
|
||||||
|
EXPOSE 8080
|
||||||
|
EXPOSE 8443
|
||||||
|
|
||||||
|
FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build
|
||||||
|
WORKDIR /src
|
||||||
|
COPY ["src/BCards.Web/BCards.Web.csproj", "src/BCards.Web/"]
|
||||||
|
RUN dotnet restore "src/BCards.Web/BCards.Web.csproj"
|
||||||
|
COPY . .
|
||||||
|
WORKDIR "/src/src/BCards.Web"
|
||||||
|
RUN dotnet build "BCards.Web.csproj" -c Release -o /app/build
|
||||||
|
|
||||||
|
FROM build AS publish
|
||||||
|
RUN dotnet publish "BCards.Web.csproj" -c Release -o /app/publish /p:UseAppHost=false
|
||||||
|
|
||||||
|
FROM base AS final
|
||||||
|
WORKDIR /app
|
||||||
|
COPY --from=publish /app/publish .
|
||||||
|
|
||||||
|
# Create uploads directory
|
||||||
|
RUN mkdir -p /app/uploads && chmod 755 /app/uploads
|
||||||
|
|
||||||
|
# Install dependencies for image processing
|
||||||
|
RUN apt-get update && apt-get install -y \
|
||||||
|
libgdiplus \
|
||||||
|
curl \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
# Environment variables
|
||||||
|
ENV ASPNETCORE_URLS=http://+:8080
|
||||||
|
ENV DOTNET_RUNNING_IN_CONTAINER=true
|
||||||
|
|
||||||
|
# Health check
|
||||||
|
HEALTHCHECK --interval=30s --timeout=10s --start-period=40s --retries=3 \
|
||||||
|
CMD curl -f http://localhost:8080/health || exit 1
|
||||||
|
|
||||||
|
ENTRYPOINT ["dotnet", "BCards.Web.dll"]
|
||||||
Loading…
Reference in New Issue
Block a user