Add S2I support and cleanup unused files

- Add complete Source-to-Image (S2I) deployment support
- Create .s2i/ directory with assemble/run scripts and environment config
- Add openshift-s2i.yaml template for S2I deployment
- Add scripts/deploy-s2i.sh for automated S2I deployment
- Add README-S2I.md with comprehensive S2I documentation
- Update README.md and AIAgents-Support.md with S2I information
- Clean up unused files: Dockerfile.simple, HTML backups, daemonset files
- Remove unused Makefile and openshift-git-deploy.yaml
- Update kustomization.yaml to use deployment instead of daemonset
- Update undeploy-complete.sh to remove deployment instead of daemonset
- Maintain clean and organized codebase structure
This commit is contained in:
2025-10-04 08:38:55 -03:00
parent 05915251c5
commit 34f4993510
18 changed files with 965 additions and 4916 deletions

193
scripts/deploy-s2i.sh Executable file
View File

@@ -0,0 +1,193 @@
#!/bin/bash
# Deploy ORU Analyzer using Source-to-Image (S2I)
# Alternative deployment method for OpenShift
set -e
echo "=== ORU Analyzer S2I Deployment Script ==="
echo "Deploying ORU Analyzer using Source-to-Image..."
# Colors for output
RED='\033[0;31m'
GREEN='\033[0;32m'
YELLOW='\033[1;33m'
BLUE='\033[0;34m'
NC='\033[0m' # No Color
# Default values
NAMESPACE="resource-governance"
APP_NAME="oru-analyzer"
GIT_REPO="https://github.com/andersonid/openshift-resource-governance.git"
GIT_REF="main"
PYTHON_VERSION="3.11"
# Function to print colored output
print_status() {
echo -e "${BLUE}[INFO]${NC} $1"
}
print_success() {
echo -e "${GREEN}[SUCCESS]${NC} $1"
}
print_warning() {
echo -e "${YELLOW}[WARNING]${NC} $1"
}
print_error() {
echo -e "${RED}[ERROR]${NC} $1"
}
# Function to check if command exists
command_exists() {
command -v "$1" >/dev/null 2>&1
}
# Check prerequisites
check_prerequisites() {
print_status "Checking prerequisites..."
if ! command_exists oc; then
print_error "OpenShift CLI (oc) is not installed or not in PATH"
exit 1
fi
# Check if logged in to OpenShift
if ! oc whoami >/dev/null 2>&1; then
print_error "Not logged in to OpenShift. Please run 'oc login' first"
exit 1
fi
print_success "Prerequisites check passed"
}
# Create namespace if it doesn't exist
create_namespace() {
print_status "Creating namespace '$NAMESPACE' if it doesn't exist..."
if oc get namespace "$NAMESPACE" >/dev/null 2>&1; then
print_warning "Namespace '$NAMESPACE' already exists"
else
oc new-project "$NAMESPACE"
print_success "Namespace '$NAMESPACE' created"
fi
}
# Deploy using S2I template
deploy_s2i() {
print_status "Deploying using S2I template..."
# Process template with parameters
oc process -f openshift-s2i.yaml \
-p NAME="$APP_NAME" \
-p NAMESPACE="$NAMESPACE" \
-p GIT_REPOSITORY="$GIT_REPO" \
-p GIT_REF="$GIT_REF" \
-p PYTHON_VERSION="$PYTHON_VERSION" \
-p CPU_REQUEST="100m" \
-p CPU_LIMIT="500m" \
-p MEMORY_REQUEST="256Mi" \
-p MEMORY_LIMIT="1Gi" \
-p REPLICAS="1" \
| oc apply -f -
print_success "S2I template applied successfully"
}
# Wait for build to complete
wait_for_build() {
print_status "Waiting for build to complete..."
# Wait for build to start
print_status "Waiting for build to start..."
oc wait --for=condition=Running buildconfig/"$APP_NAME" --timeout=60s || true
# Get the latest build
BUILD_NAME=$(oc get builds -l buildconfig="$APP_NAME" --sort-by=.metadata.creationTimestamp -o jsonpath='{.items[-1].metadata.name}')
if [ -n "$BUILD_NAME" ]; then
print_status "Waiting for build '$BUILD_NAME' to complete..."
oc logs -f build/"$BUILD_NAME" || true
# Wait for build to complete
oc wait --for=condition=Complete build/"$BUILD_NAME" --timeout=600s || {
print_error "Build failed or timed out"
print_status "Build logs:"
oc logs build/"$BUILD_NAME"
exit 1
}
print_success "Build completed successfully"
else
print_warning "No build found, continuing..."
fi
}
# Wait for deployment to be ready
wait_for_deployment() {
print_status "Waiting for deployment to be ready..."
# Wait for deployment to complete
oc rollout status deploymentconfig/"$APP_NAME" --timeout=300s || {
print_error "Deployment failed or timed out"
print_status "Deployment logs:"
oc logs deploymentconfig/"$APP_NAME"
exit 1
}
print_success "Deployment completed successfully"
}
# Get application URL
get_application_url() {
print_status "Getting application URL..."
ROUTE_URL=$(oc get route "$APP_NAME" -o jsonpath='{.spec.host}' 2>/dev/null || echo "")
if [ -n "$ROUTE_URL" ]; then
print_success "Application deployed successfully!"
echo ""
echo "=========================================="
echo "🚀 ORU Analyzer is now available at:"
echo " https://$ROUTE_URL"
echo "=========================================="
echo ""
echo "📊 To check the application status:"
echo " oc get pods -n $NAMESPACE"
echo " oc logs -f deploymentconfig/$APP_NAME -n $NAMESPACE"
echo ""
echo "🔧 To check the build status:"
echo " oc get builds -n $NAMESPACE"
echo " oc logs build/<build-name> -n $NAMESPACE"
echo ""
else
print_warning "Could not determine application URL"
print_status "Check the route manually:"
echo " oc get route -n $NAMESPACE"
fi
}
# Main deployment function
main() {
echo "Starting ORU Analyzer S2I deployment..."
echo "=========================================="
echo "Namespace: $NAMESPACE"
echo "App Name: $APP_NAME"
echo "Git Repository: $GIT_REPO"
echo "Git Reference: $GIT_REF"
echo "Python Version: $PYTHON_VERSION"
echo "=========================================="
echo ""
check_prerequisites
create_namespace
deploy_s2i
wait_for_build
wait_for_deployment
get_application_url
print_success "ORU Analyzer S2I deployment completed!"
}
# Run main function
main "$@"