This is a compilation of bash scripts that have been used for various needs. It's here for reference and as an archive.
====DokuWiki NameSpace Export====
#!/bin/bash -vx
#This script is for extracting all sub-namespaces under a specified namespace in Dokuwiki.
#Each sub-namespace directly after the specified namespace is copied as a seperate namespace from all other sub-namespaces.
#The associated pages and media folders are copied then combined with DokuWikiStick then compressed and encrypted.
#Finally they are copied to a remote server via SSH.
#All file operations are run in tmpfs mount point which is removed at the end of the script
#Variables for Dokuwiki root paths where sub name-spaces will be backed up
#Pages Path (include trailing / in path)
root_pages_path="/var/www/html/dataserver.server.com/dokuwiki-data/data/pages/server_data/"
#Corresponding Media Path (include trailing / in path)
root_media_path="/var/www/html/dataserver.server.com/dokuwiki-data/data/media/server_data/"
#Destination Backup Path
backup_destination="/var/www/html/dataserver.server.com/dokuwiki-data/backup_tmpfs"
#TMPFS where data will be copied to before archiving/encrypting
backup_tmpfs="/var/www/html/dataserver.server.com/dokuwiki-data/backup_tmpfs"
#Dokuwikistick Template Source Path
dokuwikistick_template="/var/www/html/dataserver.server.com/dokuwiki-data/dokuwikistick_template"
#Dokuwikistick Data Destination Path
dokuwikistick_destination="DokuWikiStick/dokuwiki/data"
#Dokuwikistick Pages/Media Variable
stick_pages="pages/server_data"
stick_media="media/server_data"
#SSH key for copying to remote host
ssh_key="/root/.ssh/root@dataserver.server.com-user@ht-sync01"
#SSH remote user@host
ssh_remote_user="user@remote.ip.addr.ess"
#SSH remote backup path
ssh_remote_backup="/home/user/xfer/server_data_backups"
#End of Variables
#Check if path exists for tmpfs mount point, create it if if doesn't exist
if [[ ! -d ${backup_tmpfs} ]];
then
mkdir -p ${backup_tmpfs}
fi
#Mount tmpfs filesystem
mount -t tmpfs -o size=100m,mode=700 tmpfs $backup_tmpfs
#Create backup of pages and media paths for each client folder where d represents the folder below server_data
for d in $root_pages_path*/ ; do
d=${d#"$root_pages_path"}
echo "$d"
if [[ ! -d ${backup_tmpfs}/${d} ]];
then
mkdir -p ${backup_tmpfs}/${d}/${dokuwikistick_destination}/${stick_pages}/${d}
mkdir -p ${backup_tmpfs}/${d}/${dokuwikistick_destination}/${stick_media}/${d}
fi
if [[ -d $root_pages_path/${d} ]];
then
rsync -av ${root_pages_path}/${d} ${backup_tmpfs}/${d}/${dokuwikistick_destination}/${stick_pages}/${d}
fi
if [[ -d $root_media_path/${d} ]];
then
rsync -av ${root_media_path}/${d} ${backup_tmpfs}/${d}/${dokuwikistick_destination}/${stick_media}/${d}
fi
rsync -av $dokuwikistick_template/ ${backup_tmpfs}/${d}/DokuWikiStick/
#Remove trailing slash from $d
d=${d%/}
7za a -r -mx=1 -pPassWordGoesHere $backup_destination/"$d"_encrypted.7z ${backup_tmpfs}/${d}/DokuWikiStick/
#Copy to remote host
scp -i ${ssh_key} $backup_destination/"$d"_encrypted.7z ${ssh_remote_user}:${ssh_remote_backup}/"$d"_encrypted.7z
#Remove all data from the backup tmpfs path
rm -rf ${backup_tmpfs}/*
done
#Unmount the backup tmpfs after all is done
sleep 5
umount ${backup_tmpfs}
====Rsync over SSH====
#!/bin/bash -vx
#This is copying the data exports from HT-SYNC01 to Backups directory in local home dir.
#It checks if the remote host is accessible before attempting the backup
#Rsync over SSH with keys is used
if ping -c 1 -W 1 "10.49.0.35"; then
echo "HT-SYNC01 is accessible"
rsync -Pav -e "ssh -i ~/.ssh/user@localcomputer-remoteuser@remotecomputer" remoteuser@10.49.0.35:~/xfer/data/ ~/Backups/HT-SYNC01/data/
else
echo "HT-SYNC01 is NOT accessible"
fi