Nextcloud Purge Script, Hyperling.com Static Media Volume, Memory Tweaks (#19)

* Fix memory; was accidentally done in `docker-compose.yml`.

* Fix bad path.

* Prevent DB from crashing during `fixes.sh`.

* Bump the DB up a little more.

* Add photos directory.

* Log files as they copy.

* Increase certbot by a little, was maxing near 15MB after an image update.

* Add a HUGE space saver to the cleanup crew.

* Add the beginnings of a purge script. Helps try to bring down the DB size.

* Enhance output.

* Further enhance output.

* Fix loading of ENV.

* Enhance output. Purge file previews.

* Fix extra newline.

* Add sourcing of main ENV, use RM instead of MV to reduce steps.

* Fix rm command.

* Ensure maintenance mode is off when starting.

* Add volume rather than duplicating all media.

* Ignore media.

* Check space before as well.
This commit is contained in:
2024-01-25 02:49:00 +00:00
committed by GitHub
parent fa892cb3bd
commit cf0d028a58
10 changed files with 122 additions and 21 deletions

View File

@ -40,7 +40,7 @@ services:
resources:
limits:
cpus: '0.20'
memory: 64M
memory: 192M
## Redis ##
nc-redis:

View File

@ -6,38 +6,61 @@
DIR="$(dirname -- "${BASH_SOURCE[0]}")"
PROG="$(basename -- "${BASH_SOURCE[0]}")"
source $DIR/../source.env
source $DIR/../../source.env
## Main ##
echo -e "\n*** APT ***\n"
echo -e "\n*** APT ***"
echo -e "\n`date` - Update Apt Cache"
docker exec -it nc-app apt update -y
echo -e "\n`date` - Install Additonal Software"
docker exec -it nc-app apt install -y sudo libmagickcore-6.q16-6-extra htop \
iputils-ping dnsutils vim
# 2023-12-04 Make sure cron and chmod commands get run.
echo -e "\n*** CRON ***\n"
echo -e "\n*** CRON ***"
echo -e "\n`date` - Run Cron Job"
$DOCKER_HOME/Config/Nextcloud/cron.sh && echo "Success!"
# 2022-10-30 More additions after moving to Nextcloud version 25.
echo -e "\n*** DATABASE ***\n"
echo -e "\n*** DATABASE ***"
echo -e "\n`date` - Add Missing Columns"
docker exec -itu www-data nc-app ./occ db:add-missing-columns
echo -e "\n`date` - Add Missing Indexes"
docker exec -itu www-data nc-app ./occ db:add-missing-indices
echo -e "\n`date` - Add Missing PKs"
docker exec -itu www-data nc-app ./occ db:add-missing-primary-keys
echo -e "\n`date` - Convert Filecache BigInt"
docker exec -itu www-data nc-app ./occ db:convert-filecache-bigint
# 2023-07-02
echo -e "\n*** FILES ***\n"
echo -e "\n*** FILES ***"
# This maybe used to exist, but make sure that Files app is correct.
echo -e "\n`date` - Scanning All Files"
docker exec -itu www-data nc-app ./occ files:scan --all
# This one takes a while.
echo -e "\n`date` - Scanning App Data"
docker exec -itu www-data nc-app ./occ files:scan-app-data
# Extras? Have used the commands in the past and may help in the future.
echo -e "\n`date` - Theme Update"
docker exec -itu www-data nc-app ./occ maintenance:theme:update
echo -e "\n`date` - Repair"
docker exec -itu www-data nc-app ./occ maintenance:repair
# May alsp be useful but do not have much experience with them.
# May also be useful but do not have much experience with them.
echo -e "\n`date` - Clean Versions"
docker exec -itu www-data nc-app ./occ versions:cleanup
echo -e "\n`date` - Clean Files"
docker exec -itu www-data nc-app ./occ files:cleanup
exit 0

68
Config/Nextcloud/purge.sh Executable file
View File

@ -0,0 +1,68 @@
#!/bin/bash
# 2024-01-24 Hyperling
# Commands to purge space from both Nextcloud and its database.
## Setup ##
DIR="$(dirname -- "${BASH_SOURCE[0]}")"
PROG="$(basename -- "${BASH_SOURCE[0]}")"
source $DIR/.env
source $DIR/../../source.env
## Main ##
echo -e "\n*** Files ***"
# Files commands only work during normal operations.
echo -e "\n`date` - Disable Maintenance Mode."
docker exec -itu www-data nc-app ./occ maintenance:mode --off
echo -e "\n`date` - Scanning Files"
time docker exec -itu www-data nc-app ./occ files:scan --all
echo -e "\n`date` - Clean Files"
time docker exec -itu www-data nc-app ./occ files:cleanup
echo -e "\n`date` - Clean Versions"
time docker exec -itu www-data nc-app ./occ files:cleanup
echo -e "\n`date` - Clean Trash"
time docker exec -itu www-data nc-app ./occ trashbin:cleanup --all-users
echo -e "\n`date` - Trash Previews"
rm -rfv $DOCKER_HOME/Volumes/Nextcloud/nextcloud/data/appdata_*/preview/*
echo -e "\n*** Database ***"
# Prevent any catastrophic collisions.
echo -e "\n`date` - Enable Maintenance Mode"
docker exec -itu www-data nc-app ./occ maintenance:mode --on
echo -e "\n`date` - Delete Preview Records"
docker exec -itu www-data nc-db /bin/bash -c \
"echo 'delete from oc_filecache where path like \"appdata_%/preview/%\";' | \
mysql --user=\"$MYSQL_USER\" --password=\"$MYSQL_PASSWORD\" $MYSQL_DATABASE"
# https://mariadb.com/kb/en/mariadb-check/
echo -e "\n`date` - Checking DB Tables"
time docker exec -it nc-db mariadb-check \
-Ac --user="$MYSQL_USER" --password="$MYSQL_PASSWORD"
echo -e "\n`date` - Analyzing DB Tables"
time docker exec -it nc-db mariadb-check \
-Aa --user="$MYSQL_USER" --password="$MYSQL_PASSWORD"
echo -e "\n`date` - Optimizing DB Tables -- May take some time!!"
time docker exec -itu www-data nc-db mariadb-check \
-Ao --user="$MYSQL_USER" --password="$MYSQL_PASSWORD"
# Purge Spreed Messages?
# Purge Anything Else?
# Return to normal.
echo -e "\n`date` - Disable Maintenance Mode."
docker exec -itu www-data nc-app ./occ maintenance:mode --off
exit 0