heavy_script
Table of contents:
Arguments
| Flag | Example | Parameter | Description | 
|---|---|---|---|
| --restore | --restore | None | Restore HeavyScript specific ix-applications datasetsnapshot | 
| --mount | --mount | None | Initiates mounting feature Choose between unmounting and mounting PVC data | 
| --dns | --dns | None | list all of your applications DNS names and their web port | 
| -U | -U | None | Update applications, ignoring major version changes | 
| -u | -u | None | Update applications, do NOT update if there was a major version change | 
| -b | -b 14 | Integer | Backup ix-appliactionsdataset Creates backups up to the number you've chosen | 
| -i | -i nextcloud -i sonarr | String | Applications listed will be ignored during updating List one application after another as shown in the example | 
| (-R|-r) | -r | None | Monitors applications after they update If the app does not become "ACTIVE" after either: The custom Timeout, or Default Timeout, rollback the application. Warning: deprecating -Rplease begin using-rinstead | 
| -v | -v | None | Verbose Output Look at the bottom of this page for an example | 
| -S | -S | None | Shutdown the application prior to updating it | 
| -t | -t 150 | Integer | Set a custom timeout to be used with either: -m- Time the script will wait for application to be "STOPPED" or-(u|U)- Time the script will wait for application to be either "STOPPED" or "ACTIVE" | 
| -s | -s | None | Sync Catalogs prior to updating | 
| -p | -p | None | Prune old/unused docker images | 
Examples
Typical Cron Job
bash heavy_script.sh -b 14 -i portainer -i arch -i sonarr -i radarr -t 600 -rsup
- -b is set to 14. Up to 14 snapshots of your ix-applications dataset will be saved
- -i is set to ignore portainer, arch, sonarr, and radarr. These applications will be ignored when it comes to updates.
- -t I set it to 600 seconds, this means the script will wait 600 seconds for the application to become ACTIVE before timing out and continuing to a different application.
- -r Will rollback applications if they fail to deploy after updating.
- -s will just sync the repositories, ensuring you are downloading the latest updates.
- -u update applications as long as the major version has absolutely no change, if it does have a change it will ask the user to update manually.
- -p Prune docker images.
Mounting PVC Data
bash /mnt/tank/scripts/heavy_script.sh -t 300 --mount
Restoring ix-applications dataset
bash /mnt/tank/scripts/heavy_script/heavy_script.sh --restore
My personal Cron Job
git -C /mnt/speed/scripts/heavy_script pull && bash /mnt/speed/scripts/heavy_script/heavy_script.sh -b 14 -rsup
How to Install
Create a Scripts Dataset
I created a scripts dataset on my Truenas SCALE system, this is where all my scripts will remain.
Open a Terminal
Change Directory to your scripts folder
cd /mnt/speed/scripts
Git Clone Heavy_Script
git clone https://github.com/Heavybullets8/heavy_script.git
Change Directory to Heavy_Script folder
cd heavy_script
From here, you can just run Heavy_Script with bash heavy_script.sh -ARGUMENTS
Note:
chmod +xis NOT required. Doing this will break thegit pullfunction. Just run the script withbash heavy_script.sh
How to Update
Manually
Open a Terminal
Change Directory to your heavy_script folder
cd /mnt/speed/scripts/heavy_script
git pull
git pull
Update with your Cron Job
Here, we will update the script prior to running it, incase there is a bugfix, or any new additions to the script
Cron Job Command
git -C /mnt/speed/scripts/heavy_script pull && bash /mnt/speed/scripts/heavy_script/heavy_script.sh -b 14 -rsup
The important command here is the
git -C /PATH/TO/HEAVY_SCRIPT_DIRECTORY pull
This command will allow you to preform a
git pullon a remote directory, which will ensure your script is udated prior to running it
&&Is used to run a command AFTER the previous command completed successfullySo once the
git -C /PATH/TO/HEAVY_SCRIPT_DIRECTORY pullcommand completes, THEN it will run thebash /PATH/TO/HEAVY_SCRIPT_DIRECTORY/heavy_script.sh -b 14 -rsupcommand
Creating a Cron Job
- TrueNAS SCALE GUI
- System Settings
- Advanced
- Cron Jobs
- Click Add
 
| Name | Value | Reason | 
|---|---|---|
| Description | HeavyScript git pull and Update apps | This is up to you, put whatever you think is a good description in here | 
| Command | git -C /PATH/TO/HEAVY_SCRIPT_DIRECTORY pull && bash /PATH/TO/HEAVY_SCRIPT_DIRECTORY/heavy_script.sh -b 14 -rsup | This is the command you will be running on your schedule  I personally use: git -C /mnt/speed/scripts/heavy_script pull && bash /mnt/speed/scripts/heavy_script/heavy_script.sh -b 14 -rsup | 
| Run As User | root | Running the script as rootis REQUIRED. You cannot access all of the kubernetes functions without this user. | 
| Schedule | Up to you, I run mine everyday at 0400 | Again up to you | 
| Hide Standard Output | Falseor Unticked | I like to receive an email report of how the script ran, what apps updated etc. | 
| Hide Standard Error | Falseor Unticked | I want to see any errors that occur | 
| Enabled | Trueor Ticked | This will Enable the script to run on your schedule | 
Additional Information
Verbose vs Non-Verbose
- Verbose used bash heavy_script.sh -b 5 -Srupv
- Non-Verbose used bash heavy_script.sh -b 5 -Srup
| Verbose | Non-Verbose | 
|---|---|
|  |  |