forked from BLC/sgeUpdated
Compare commits
9 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 47f06688e0 | |||
| a0ec570147 | |||
| 7696d0f133 | |||
| e67dcea72e | |||
| 7a948f3b7e | |||
| 49ce97d394 | |||
| a7ba6fe3e4 | |||
| 66aeed7fda | |||
| 8f41ce3d51 |
54
deploy.sh
54
deploy.sh
@@ -3,6 +3,18 @@ set -euo pipefail
|
||||
|
||||
cd /home/ubuntu/Bgreen/sgeUpdated
|
||||
|
||||
# -----------------------
|
||||
# Harbor settings
|
||||
# -----------------------
|
||||
HARBOR_REGISTRY="10.150.1.166"
|
||||
HARBOR_PROJECT="bgreen"
|
||||
|
||||
BACKEND_IMAGE_REPO="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/bgreen-backend"
|
||||
FRONTEND_IMAGE_REPO="${HARBOR_REGISTRY}/${HARBOR_PROJECT}/bgreen-frontend"
|
||||
|
||||
# Tag images with git commit (better than latest; enables rollback)
|
||||
VERSION="$(git rev-parse --short HEAD)"
|
||||
|
||||
echo "📦 Fetching latest changes from origin/main..."
|
||||
git fetch myfork main
|
||||
|
||||
@@ -22,12 +34,12 @@ git reset --hard myfork/main
|
||||
BACKEND_CHANGED=false
|
||||
FRONTEND_CHANGED=false
|
||||
|
||||
# Check if backend folder changed
|
||||
# Check if backend folder changed (excluding README.md)
|
||||
if echo "$CHANGED_FILES" | grep "^sge-backend/" | grep -qv "README.md$"; then
|
||||
BACKEND_CHANGED=true
|
||||
fi
|
||||
|
||||
# Check if frontend folder changed
|
||||
# Check if frontend folder changed (excluding README.md)
|
||||
if echo "$CHANGED_FILES" | grep "^sge-frontend/" | grep -qv "README.md$"; then
|
||||
FRONTEND_CHANGED=true
|
||||
fi
|
||||
@@ -37,12 +49,25 @@ fi
|
||||
# -----------------------
|
||||
if [ "$BACKEND_CHANGED" = true ]; then
|
||||
echo "⚡ Backend changes detected."
|
||||
|
||||
cd sge-backend
|
||||
echo "Running Maven build..."
|
||||
/opt/apache-maven-3.9.11/bin/mvn clean install -DskipTests
|
||||
cd ../..
|
||||
echo "Rebuilding backend Docker container..."
|
||||
docker compose up -d --build bgreen-backend
|
||||
|
||||
echo "🐳 Building backend Docker image..."
|
||||
docker build -t "${BACKEND_IMAGE_REPO}:${VERSION}" .
|
||||
|
||||
echo "📤 Pushing backend image to Harbor..."
|
||||
docker push "${BACKEND_IMAGE_REPO}:${VERSION}"
|
||||
|
||||
echo "📥 Pulling backend image from Harbor (to ensure registry is source of truth)..."
|
||||
docker pull "${BACKEND_IMAGE_REPO}:${VERSION}"
|
||||
|
||||
cd ..
|
||||
|
||||
echo "🚀 Recreating backend container using Harbor image..."
|
||||
VERSION="$VERSION" docker compose up -d bgreen-backend
|
||||
|
||||
else
|
||||
echo "✅ No backend changes."
|
||||
fi
|
||||
@@ -56,7 +81,7 @@ if [ "$FRONTEND_CHANGED" = true ]; then
|
||||
|
||||
# Check if package.json or package-lock.json changed
|
||||
if echo "$CHANGED_FILES" | grep -qE "^sge-frontend/(package\.json|package-lock\.json)$"; then
|
||||
echo "📦 package.json changed. Running 'npm instal' and 'npm run build'..."
|
||||
echo "📦 package.json changed. Running 'npm install' and 'npm run build'..."
|
||||
npm install
|
||||
npm run build
|
||||
else
|
||||
@@ -64,9 +89,20 @@ if [ "$FRONTEND_CHANGED" = true ]; then
|
||||
npm run build
|
||||
fi
|
||||
|
||||
cd ../..
|
||||
echo "Rebuilding frontend Docker container..."
|
||||
docker compose up -d --build bgreen-frontend
|
||||
echo "🐳 Building frontend Docker image..."
|
||||
docker build -t "${FRONTEND_IMAGE_REPO}:${VERSION}" .
|
||||
|
||||
echo "📤 Pushing frontend image to Harbor..."
|
||||
docker push "${FRONTEND_IMAGE_REPO}:${VERSION}"
|
||||
|
||||
echo "📥 Pulling frontend image from Harbor (to ensure registry is source of truth)..."
|
||||
docker pull "${FRONTEND_IMAGE_REPO}:${VERSION}"
|
||||
|
||||
cd ..
|
||||
|
||||
echo "🚀 Recreating frontend container using Harbor image..."
|
||||
VERSION="$VERSION" docker compose up -d bgreen-frontend
|
||||
|
||||
else
|
||||
echo "✅ No frontend changes."
|
||||
fi
|
||||
|
||||
@@ -1,8 +1,6 @@
|
||||
services:
|
||||
bgreen-backend:
|
||||
build:
|
||||
context: ./sge-backend
|
||||
dockerfile: Dockerfile
|
||||
image: 10.150.1.166/bgreen/bgreen-backend:${VERSION}
|
||||
ports:
|
||||
- "8080:8080"
|
||||
env_file:
|
||||
@@ -14,9 +12,7 @@ services:
|
||||
restart: unless-stopped
|
||||
|
||||
bgreen-frontend:
|
||||
build:
|
||||
context: ./sge-frontend
|
||||
dockerfile: Dockerfile
|
||||
image: 10.150.1.166/bgreen/bgreen-frontend:${VERSION}
|
||||
ports:
|
||||
- "80:80"
|
||||
env_file:
|
||||
|
||||
@@ -11,7 +11,7 @@
|
||||
</parent>
|
||||
<groupId>com.sgs</groupId>
|
||||
<artifactId>sgs</artifactId>
|
||||
<version>0.0.2-SNAPSHOT</version>
|
||||
<version>0.0.4-SNAPSHOT</version>
|
||||
<name>sgs</name>
|
||||
<description>SGS project for Spring Boot</description>
|
||||
<properties>
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "sgs-web",
|
||||
"version": "1.0.1",
|
||||
"version": "1.0.2",
|
||||
"private": true,
|
||||
"dependencies": {
|
||||
"@apollo/client": "^3.13.8",
|
||||
|
||||
Reference in New Issue
Block a user