From 755c6e641dbf662f7f603c0ead2f5a416814ec24 Mon Sep 17 00:00:00 2001 From: Kevin Reynolds Date: Tue, 30 Apr 2024 07:25:58 -0400 Subject: [PATCH] refactor services to not start on install --- labapp/labapp_installer.sh | 68 ++++++++++++++++++-------------------- labapp/service_install.sh | 49 --------------------------- 2 files changed, 33 insertions(+), 84 deletions(-) delete mode 100644 labapp/service_install.sh diff --git a/labapp/labapp_installer.sh b/labapp/labapp_installer.sh index a162229..296e9ba 100644 --- a/labapp/labapp_installer.sh +++ b/labapp/labapp_installer.sh @@ -1,57 +1,54 @@ #!/bin/bash -# Check if Docker is installed, install it if it's not -if ! command -v pip &> /dev/null -then - # Update apt - sudo DEBIAN_FRONTEND=noninteractive apt-get update --yes - echo "pip could not be found, installing..." - sudo apt-get install -y python3-pip +# Ensure the script is run with root privileges +if [ "$EUID" -ne 0 ]; then + echo "Please run as root" + exit +fi + +# Check for Python3 pip and install if it's missing +if ! command -v pip3 &> /dev/null; then + echo "pip3 could not be found, updating repositories and installing..." + sudo apt-get update --quiet + sudo apt-get install --quiet --yes python3-pip fi # Variable Declarations -IMAGE=ghcr.io/f5devcentral/f5xc-lab-mcn-practical/labapp:latest -SERVICE=mcn-practical-labapp.service -APPDIR=/opt/mcn-practical-labapp/app -SCRIPTDIR=/opt/mcn-practical-labapp/script -REPO_URL=https://github.com/f5devcentral/f5xc-lab-mcn-practical.git -BRANCH=dev +REPO_URL="https://github.com/f5devcentral/f5xc-lab-mcn-practical.git" +BRANCH="main" +APPDIR="/opt/mcn-practical-labapp/app" +SCRIPTDIR="/opt/mcn-practical-labapp/scripts" -# Create directories -mkdir -p $SCRIPTDIR -mkdir -p $APPDIR +# Create necessary directories +mkdir -p "$APPDIR" "$SCRIPTDIR" -# Create the start_labapp.sh script -cat <$SCRIPTDIR/start_app.sh +# Create the start script +cat <"$SCRIPTDIR/start_app.sh" #!/bin/bash -if [ ! -d "$APPDIR/.git" ]; then - git clone -b $BRANCH $REPO_URL $APPDIR +# Ensure the directory exists and pull or clone repo +if [ ! -d "\$APPDIR/.git" ]; then + git clone --branch $BRANCH $REPO_URL "$APPDIR" else - cd $APPDIR - # Ensure that the local repository is tracking the correct remote and branch + cd "$APPDIR" git remote set-url origin $REPO_URL - git fetch --all - # Reset to the specified branch forcefully + git fetch --prune git checkout $BRANCH - git reset --hard origin/$BRANCH + git reset --hard "origin/$BRANCH" git clean -fdx - git pull origin $BRANCH fi # Install required Python packages -cd $APPDIR/labapp/app -pip install -r requirements.txt +pip3 install -r requirements.txt # Start the Gunicorn server gunicorn --workers 4 --bind 0.0.0.0:1337 app:app EOF -# Make the script executable -chmod +x $SCRIPTDIR/start_app.sh +chmod +x "$SCRIPTDIR/start_app.sh" # Create systemd service file -cat </etc/systemd/system/$SERVICE +cat <"/etc/systemd/system/mcn-practical-labapp.service" [Unit] Description=MCN Practical Lab App After=network.target @@ -60,14 +57,15 @@ After=network.target WorkingDirectory=$APPDIR ExecStart=/bin/bash $SCRIPTDIR/start_app.sh Restart=always +Type=simple [Install] WantedBy=multi-user.target EOF -# Reload systemd, enable and start the service +# Reload systemd to recognize new service, enable it systemctl daemon-reload -systemctl enable $SERVICE -systemctl start $SERVICE +systemctl enable mcn-practical-labapp.service +systemctl start mcn-practical-labapp.service -echo "$SERVICE has been installed and started as a systemd service." +echo "mcn-practical-labapp.service has been installed." diff --git a/labapp/service_install.sh b/labapp/service_install.sh deleted file mode 100644 index 6901895..0000000 --- a/labapp/service_install.sh +++ /dev/null @@ -1,49 +0,0 @@ -#!/bin/bash - -# Update apt -sudo DEBIAN_FRONTEND=noninteractive apt-get update --yes - -# Check if Docker is installed, install it if it's not -if ! command -v docker &> /dev/null -then - echo "Docker could not be found, installing..." - sudo apt-get install -y docker.io -fi - -# Enable and start Docker -sudo systemctl enable docker -sudo systemctl start docker - -# Variable Declarations -IMAGE=ghcr.io/f5devcentral/f5xc-lab-mcn-practical/labapp:latest -SERVICE=mcn-practical-labapp.service -CONTAINER=mcn-practical-labapp - -# Create the systemd service file -sudo bash -c "cat > /etc/systemd/system/$SERVICE <