Compare commits
2 commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
241a91fa6e | ||
|
|
d5e41da39d |
1 changed files with 57 additions and 39 deletions
96
Jenkinsfile
vendored
96
Jenkinsfile
vendored
|
|
@ -15,7 +15,12 @@ pipeline {
|
|||
timestamps()
|
||||
}
|
||||
|
||||
parameters {
|
||||
booleanParam(name: 'ROLLBACK', defaultValue: false, description: 'Executar rollback da produção?')
|
||||
}
|
||||
|
||||
stages {
|
||||
|
||||
stage('Commit') {
|
||||
steps {
|
||||
echo 'Pipeline iniciado via push ou merge.'
|
||||
|
|
@ -24,7 +29,7 @@ pipeline {
|
|||
|
||||
stage('Checkout Código') {
|
||||
steps {
|
||||
git branch: 'main', url: 'https://forgeo-olymp.duckdns.org/rayankonecny/astro-app.git'
|
||||
git branch: 'main', url: 'https://forgeo-olymp.duckdns.org/rayankonecny/portal-app.git'
|
||||
script {
|
||||
env.GIT_COMMIT = sh(script: 'git rev-parse --short HEAD', returnStdout: true).trim()
|
||||
env.BUILD_TAG = "${env.BUILD_NUMBER}-${env.GIT_COMMIT}"
|
||||
|
|
@ -36,7 +41,7 @@ pipeline {
|
|||
stage('Build') {
|
||||
steps {
|
||||
sh 'npm ci'
|
||||
sh 'npm run build'
|
||||
sh 'npm run build || echo "Build não crítico"'
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -46,42 +51,53 @@ pipeline {
|
|||
}
|
||||
}
|
||||
|
||||
stage('SonarQube Analysis') {
|
||||
environment {
|
||||
SONAR_SCANNER_HOME = tool 'SonarQube Scanner'
|
||||
}
|
||||
steps {
|
||||
withSonarQubeEnv('SonarQube') {
|
||||
sh """
|
||||
${SONAR_SCANNER_HOME}/bin/sonar-scanner \
|
||||
-Dsonar.projectKey=${SONAR_PROJECT_KEY} \
|
||||
-Dsonar.sources=. \
|
||||
-Dsonar.host.url=$SONAR_HOST_URL \
|
||||
-Dsonar.login=$SONAR_AUTH_TOKEN
|
||||
"""
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
stage('Deploy to Stage') {
|
||||
steps {
|
||||
sshagent(credentials: ['chave-ssh-id']) {
|
||||
sh """
|
||||
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} '
|
||||
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} "
|
||||
set -e
|
||||
|
||||
rm -rf ${REMOTE_PATH}
|
||||
mkdir -p ${REMOTE_PATH}
|
||||
git clone https://forgeo-olymp.duckdns.org/rayankonecny/portal-app.git ${REMOTE_PATH}
|
||||
cd ${REMOTE_PATH}
|
||||
|
||||
sed -i '/NODE_ENV/d' .env || true
|
||||
|
||||
cat <<EOF > Dockerfile
|
||||
# STAGE 1: Build (não será usado aqui no servidor)
|
||||
FROM node:20-alpine AS build
|
||||
|
||||
# STAGE 2: Produção estática
|
||||
FROM node:20-alpine
|
||||
WORKDIR /var/app/usr/astro
|
||||
RUN npm install -g serve
|
||||
COPY dist ./dist
|
||||
EXPOSE 3000
|
||||
CMD ["serve", "dist", "-l", "3000"]
|
||||
FROM node:18-alpine
|
||||
WORKDIR /app
|
||||
COPY package*.json ./
|
||||
RUN npm install
|
||||
COPY . .
|
||||
EXPOSE 5173
|
||||
CMD [\\"npm\\", \\"run\\", \\"dev\\"]
|
||||
EOF
|
||||
|
||||
exit
|
||||
'
|
||||
|
||||
# Copia arquivos necessários via SCP
|
||||
scp -r ./dist ${DEPLOY_USER}@${DEPLOY_SERVER}:${REMOTE_PATH}/dist
|
||||
|
||||
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} '
|
||||
cd ${REMOTE_PATH}
|
||||
podman build -t ${IMAGE_NAME}:${BUILD_TAG}-stage -t ${IMAGE_NAME}:stage .
|
||||
|
||||
podman stop ${CONTAINER_NAME}-stage || true
|
||||
podman rm ${CONTAINER_NAME}-stage || true
|
||||
|
||||
podman run -d --network host --name ${CONTAINER_NAME}-stage ${IMAGE_NAME}:${BUILD_TAG}-stage
|
||||
'
|
||||
"
|
||||
"""
|
||||
}
|
||||
}
|
||||
|
|
@ -97,14 +113,17 @@ ssh ${DEPLOY_USER}@${DEPLOY_SERVER} '
|
|||
steps {
|
||||
sshagent(credentials: ['chave-ssh-id']) {
|
||||
sh """
|
||||
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} '
|
||||
echo "${BUILD_TAG}" > ${REMOTE_PATH}/last_successful_build.txt
|
||||
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} "
|
||||
echo '${BUILD_TAG}' > ${REMOTE_PATH}/last_successful_build.txt
|
||||
|
||||
cd ${REMOTE_PATH}
|
||||
podman build -t ${IMAGE_NAME}:${BUILD_TAG}-prod -t ${IMAGE_NAME}:prod .
|
||||
|
||||
podman stop ${CONTAINER_NAME} || true
|
||||
podman rm ${CONTAINER_NAME} || true
|
||||
|
||||
podman run -d --network host --name ${CONTAINER_NAME} ${IMAGE_NAME}:${BUILD_TAG}-prod
|
||||
'
|
||||
"
|
||||
"""
|
||||
}
|
||||
}
|
||||
|
|
@ -114,9 +133,9 @@ ssh ${DEPLOY_USER}@${DEPLOY_SERVER} '
|
|||
steps {
|
||||
sshagent(credentials: ['chave-ssh-id']) {
|
||||
sh """
|
||||
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} '
|
||||
podman ps | grep ${CONTAINER_NAME} || echo "Container não encontrado"
|
||||
'
|
||||
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} "
|
||||
podman ps | grep ${CONTAINER_NAME} || echo 'Container não encontrado'
|
||||
"
|
||||
"""
|
||||
}
|
||||
}
|
||||
|
|
@ -129,23 +148,26 @@ ssh ${DEPLOY_USER}@${DEPLOY_SERVER} '
|
|||
steps {
|
||||
sshagent(credentials: ['chave-ssh-id']) {
|
||||
sh """
|
||||
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} '
|
||||
TAG=$(cat ${REMOTE_PATH}/last_successful_build.txt || echo "latest")
|
||||
echo "[INFO] Restaurando versão: \$TAG"
|
||||
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} "
|
||||
TAG=\$(cat ${REMOTE_PATH}/last_successful_build.txt || echo 'latest')
|
||||
|
||||
echo '[INFO] Restaurando versão: \$TAG'
|
||||
|
||||
podman stop ${CONTAINER_NAME} || true
|
||||
podman rm ${CONTAINER_NAME} || true
|
||||
|
||||
podman run -d --network host --name ${CONTAINER_NAME} ${IMAGE_NAME}:\$TAG
|
||||
'
|
||||
"
|
||||
"""
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
stage('Limpeza') {
|
||||
stage('Limpeza de Imagens Antigas') {
|
||||
steps {
|
||||
sshagent(credentials: ['chave-ssh-id']) {
|
||||
sh """
|
||||
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} 'podman image prune -f'
|
||||
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} "podman image prune -f"
|
||||
"""
|
||||
}
|
||||
}
|
||||
|
|
@ -172,8 +194,4 @@ curl -H "Content-Type: application/json" -X POST \
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
parameters {
|
||||
booleanParam(name: 'ROLLBACK', defaultValue: false, description: 'Executar rollback da produção?')
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue