Compare commits
No commits in common. "d3263e6da53b6af51e39d8cae31b85e12c9319a9" and "a6e0696e31d42eab988a41907bad4e58c87bfa93" have entirely different histories.
d3263e6da5
...
a6e0696e31
11
Makefile
11
Makefile
@ -1,7 +1,4 @@
|
|||||||
# Autogenerated at 12.07.2022 23:14 using ./gen-makefile
|
# Autogenerated at 05.07.2022 10:52 using ./gen-makefile
|
||||||
|
|
||||||
##composer: [PACK] php + composer
|
|
||||||
composer: php composer-clean
|
|
||||||
|
|
||||||
##flameshot: [TODO] [PACK] qt5 + flameshot from source
|
##flameshot: [TODO] [PACK] qt5 + flameshot from source
|
||||||
flameshot: qt5 flameshot-build
|
flameshot: qt5 flameshot-build
|
||||||
@ -24,9 +21,9 @@ apt:
|
|||||||
chrome:
|
chrome:
|
||||||
./install/chrome
|
./install/chrome
|
||||||
|
|
||||||
##composer-clean: Install composer (latest)
|
##composer: Install composer (latest)
|
||||||
composer-clean:
|
composer:
|
||||||
./install/composer-clean
|
./install/composer
|
||||||
|
|
||||||
##docker: Install docker (latest) + docker-compose (latest) + ppa
|
##docker: Install docker (latest) + docker-compose (latest) + ppa
|
||||||
docker:
|
docker:
|
||||||
|
@ -1,13 +1,12 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
##makedesc: Install composer (latest)
|
##makedesc: Install composer (latest)
|
||||||
|
|
||||||
echo
|
echo
|
||||||
echo "==============================================="
|
echo "==============================================="
|
||||||
echo "Installing composer (latest)..."
|
echo "Installing composer (latest)..."
|
||||||
echo "==============================================="
|
echo "==============================================="
|
||||||
echo
|
echo
|
||||||
|
|
||||||
# https://getcomposer.org/doc/faqs/how-to-install-composer-programmatically.md
|
|
||||||
|
|
||||||
installed() {
|
installed() {
|
||||||
command -v "$1" >/dev/null 2>&1
|
command -v "$1" >/dev/null 2>&1
|
||||||
}
|
}
|
||||||
@ -17,19 +16,18 @@ installed() {
|
|||||||
if installed "composer"; then
|
if installed "composer"; then
|
||||||
echo "WARNING: Removing current composer to install its actual version"
|
echo "WARNING: Removing current composer to install its actual version"
|
||||||
sudo apt remove -y --autoremove composer
|
sudo apt remove -y --autoremove composer
|
||||||
sudo rm /bin/composer
|
sudo rm -f /bin/composer
|
||||||
sudo rm /usr/bin/composer
|
sudo rm -f /usr/bin/composer
|
||||||
sudo rm /usr/local/bin/composer
|
sudo rm -f /usr/local/bin/composer
|
||||||
sudo rm /usr/src/composer
|
sudo rm -rf /usr/src/composer
|
||||||
rm $HOME/.local/bin/composer
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
mkdir -p $HOME/install && cd $HOME/install
|
sudo mkdir -m 0777 -p /usr/src/composer
|
||||||
# mkdir -p $HOME/.local/bin
|
cd /usr/src/composer
|
||||||
|
|
||||||
|
# https://getcomposer.org/doc/faqs/how-to-install-composer-programmatically.md
|
||||||
EXPECTED_CHECKSUM="$(php -r 'copy("https://composer.github.io/installer.sig", "php://stdout");')"
|
EXPECTED_CHECKSUM="$(php -r 'copy("https://composer.github.io/installer.sig", "php://stdout");')"
|
||||||
# php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
|
sudo php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
|
||||||
wget https://getcomposer.org/installer -O composer-setup.php
|
|
||||||
ACTUAL_CHECKSUM="$(php -r "echo hash_file('sha384', 'composer-setup.php');")"
|
ACTUAL_CHECKSUM="$(php -r "echo hash_file('sha384', 'composer-setup.php');")"
|
||||||
if [ "$EXPECTED_CHECKSUM" != "$ACTUAL_CHECKSUM" ]; then
|
if [ "$EXPECTED_CHECKSUM" != "$ACTUAL_CHECKSUM" ]; then
|
||||||
>&2 echo 'ERROR: Invalid installer checksum'
|
>&2 echo 'ERROR: Invalid installer checksum'
|
||||||
@ -37,6 +35,7 @@ if [ "$EXPECTED_CHECKSUM" != "$ACTUAL_CHECKSUM" ]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
php composer-setup.php --quiet
|
php composer-setup.php --quiet
|
||||||
cp $HOME/install/composer.phar $HOME/.local/bin/composer
|
sudo cp /usr/src/composer/composer.phar /usr/local/bin/composer
|
||||||
cd - >/dev/null
|
cd - >/dev/null
|
||||||
|
sudo rm -rf /usr/src/composer/
|
||||||
installed "composer" && composer --version
|
installed "composer" && composer --version
|
@ -1,2 +0,0 @@
|
|||||||
##composer: [PACK] php + composer
|
|
||||||
composer: php composer-clean
|
|
120
scripts/db_backup.sh
Executable file
120
scripts/db_backup.sh
Executable file
@ -0,0 +1,120 @@
|
|||||||
|
##############################################################
|
||||||
|
# Скрипт для автоматического резервного копирования
|
||||||
|
# базы данных.
|
||||||
|
#
|
||||||
|
# Автор: Антон Аксенов
|
||||||
|
# URL: anthonyaxenov.ru
|
||||||
|
# Email: anthonyaxenov@gmail.com
|
||||||
|
#
|
||||||
|
# Подробности о скрипте, подготовка к работе:
|
||||||
|
# https://anthonyaxenov.blogspot.ru/2017/05/cron-1.html
|
||||||
|
#
|
||||||
|
##############################################################
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Данные для работы с БД
|
||||||
|
DBHOST=
|
||||||
|
DBUSER=
|
||||||
|
DBPASS=
|
||||||
|
DBNAME=
|
||||||
|
DBCHARSET="utf8"
|
||||||
|
|
||||||
|
# Даты
|
||||||
|
FMT_DT_DIR="%d-%m-%Y" # формат даты для директорий | 19-03-2021
|
||||||
|
FMT_DT_FILE="%H%M%S-%d%m%y" # формат даты для файлов | 082456-190321
|
||||||
|
FMT_DT_LOG="%H:%M:%S" # формат даты для лога | 08:24:15.168149413
|
||||||
|
|
||||||
|
# Локальное хранилище
|
||||||
|
LOCALDIR=/backup # полный путь директории для бэкапов
|
||||||
|
LOCALPATH=$LOCALDIR/$(date +$FMT_DT_DIR) # полный путь директории за сегодня
|
||||||
|
LOCALFILE=$LOCALPATH/$DBNAME-$(date +$FMT_DT_FILE).sql # полный путь к файлу дампа
|
||||||
|
|
||||||
|
# Облачное хранилище
|
||||||
|
CLOUDUSE=1 # Копировать ли в облако? Закомментировать строку, если не надо
|
||||||
|
CLOUDMNT=/mnt/yadisk # Точка монтирования облака относительно корня
|
||||||
|
CLOUDDIR=db_backup # Папка в облаке, куда будут лететь файлы (внутри папки CLOUDMNT, т.е. без / в начале)
|
||||||
|
CLOUDPATH=$CLOUDMNT/$CLOUDDIR/$DATE # полный путь к папке текущей даты в облаке относительно корня
|
||||||
|
CLOUDFILE=$CLOUDPATH/$DBNAME-$DATETIME.sql # полный путь к файлу дампа в облаке
|
||||||
|
CLOUDFILEGZ=$CLOUDFILE.gz # полный путь к архиву в облаке
|
||||||
|
|
||||||
|
# Путь к бекапу на примонтированном хранилище будет выглядеть так:
|
||||||
|
# /mnt/yadisk/db_backup/2017-01-01/mybigdatabase-2017-01-01-12-23-34.sql.gz
|
||||||
|
|
||||||
|
log() {
|
||||||
|
echo "[$(date +$FMT_DT_LOG)] $*"
|
||||||
|
}
|
||||||
|
|
||||||
|
is_dir() {
|
||||||
|
[ -d "$1" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
# Начало процесса
|
||||||
|
echo "[--------------------------------[$(date +$FMT_DT_LOG)]--------------------------------]"
|
||||||
|
log $LOCALPATH
|
||||||
|
if ! is_dir $LOCALPATH; then # Если нет папки за сегодня
|
||||||
|
sudo mkdir -p $LOCALPATH # создаём её, ошибки игнорируем
|
||||||
|
[ $? -eq 0 ] && log "New directory: $LOCALPATH"
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
log "Generate a database dump: '$DBNAME'..."
|
||||||
|
mysqldump \
|
||||||
|
-q \
|
||||||
|
--user=$DBUSER \
|
||||||
|
--host=$DBHOST \
|
||||||
|
--password=$DBPASS \
|
||||||
|
--opt \
|
||||||
|
--default-character-set=$DBCHARSET $DBNAME \
|
||||||
|
> $LOCALFILE
|
||||||
|
exit
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if [[ $? -gt 0 ]]; then
|
||||||
|
# если дамп сделать не удалось (код завершения предыдущей команды больше нуля) - прерываем весь скрипт
|
||||||
|
log "Dumping failed! Script aborted."
|
||||||
|
exit 1
|
||||||
|
else # иначе - упаковываем его
|
||||||
|
log "Dumping successfull! Packing in GZIP..."
|
||||||
|
gzip $LOCALFILE # Упаковка
|
||||||
|
if [[ $? -ne 0 ]]; then # Если не удалась
|
||||||
|
log "GZipping failed! SQL-file will be uploaded."
|
||||||
|
GZIP_FAILED=1 # Создаём флажок, что упаковка сорвалась
|
||||||
|
else
|
||||||
|
log "Result file: $LOCALFILEGZ"
|
||||||
|
fi
|
||||||
|
if [[ $CLOUDUSE -eq 1 ]]; then # Если задано копирование в облако - делаем всякое такое
|
||||||
|
mount | grep "$CLOUDMNT" > /dev/null # Проверяем примонтировано ли уже у нас облако (вывод не важен)
|
||||||
|
if [[ $? -ne 0 ]]; then # Если нет
|
||||||
|
mount $CLOUDMNT # значит монтируем
|
||||||
|
fi
|
||||||
|
if [[ $? -eq 0 ]]; then # если монтирование успешно - копируем туда файл
|
||||||
|
log "Cloud: successfully mounted at $CLOUDMNT"
|
||||||
|
log "Cloud: copying started => $CLOUDFILEGZ"
|
||||||
|
if ! [[ -d $CLOUDPATH ]]; then # Если в облаке нет папки за сегодня
|
||||||
|
mkdir $CLOUDPATH 2> /dev/null # создаём её, ошибки игнорируем
|
||||||
|
fi
|
||||||
|
if [[ -f $LOCALFILEGZ && GZIP_FAILED -ne 1 ]]; then # Если у нас архивирование выше не сорвалось
|
||||||
|
cp -R $LOCALFILEGZ $CLOUDFILEGZ # Копируем архив
|
||||||
|
else
|
||||||
|
cp -R $LOCALFILE $CLOUDFILE # Иначе - копируем большой тяжёлый дамп
|
||||||
|
fi
|
||||||
|
if [[ $? -gt 0 ]]; then # Если не скопировался - просто сообщаем
|
||||||
|
log "Cloud: copy failed."
|
||||||
|
else # Если скопировался - сообщаем и размонтируем
|
||||||
|
log "Cloud: file successfully uploaded!"
|
||||||
|
umount $CLOUDMNT # Размонтирование облака
|
||||||
|
if [[ $? -gt 0 ]]; then # Сообщаем результат размонтирования (если необходимо)
|
||||||
|
log "Cloud: umount - failed!"
|
||||||
|
fi # Конец проверки успешного РАЗмонтирования
|
||||||
|
fi # Конец проверки успешного копирования
|
||||||
|
else # если монтирование НЕуспешно - сообщаем
|
||||||
|
log "Cloud: failed to mount cloud at $CLOUDMNT"
|
||||||
|
fi # Конец проверки успешного монтирования
|
||||||
|
fi # Конец проверки необходимости выгрузки в облако
|
||||||
|
fi # Конец проверки успешного выполнения mysqldump
|
||||||
|
log "Stat datadir space (USED): `du -h $LOCALPATH | tail -n1`" # вывод размера папки с бэкапами за текущий день
|
||||||
|
log "Free HDD space: `df -h /home|tail -n1|awk '{print $4}'`" # вывод свободного места на локальном диске
|
||||||
|
log "All operations completed!"
|
||||||
|
exit 0 # Успешное завершение скрипта
|
@ -1,4 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# https://gist.github.com/anthonyaxenov/c16e1181d4b8a8644c57ec8a1f6cf21c
|
||||||
|
|
||||||
#########################################################################
|
#########################################################################
|
||||||
# #
|
# #
|
||||||
# Set display resolution #
|
# Set display resolution #
|
||||||
@ -15,8 +18,6 @@
|
|||||||
# #
|
# #
|
||||||
#########################################################################
|
#########################################################################
|
||||||
|
|
||||||
# https://gist.github.com/anthonyaxenov/c16e1181d4b8a8644c57ec8a1f6cf21c
|
|
||||||
|
|
||||||
# Set display name to work with. You can get it via 'xrandr --listactivemonitors'
|
# Set display name to work with. You can get it via 'xrandr --listactivemonitors'
|
||||||
display="HDMI-2"
|
display="HDMI-2"
|
||||||
# Set width of this display in px
|
# Set width of this display in px
|
@ -1,108 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
#####################################################################
|
|
||||||
# #
|
|
||||||
# Stupidly simple backup script for own projects #
|
|
||||||
# #
|
|
||||||
# Author: Anthony Axenov (Антон Аксенов) #
|
|
||||||
# Version: 1.0 #
|
|
||||||
# License: WTFPLv2 More info (RU): https://axenov.dev/?p=1234 #
|
|
||||||
# #
|
|
||||||
#####################################################################
|
|
||||||
|
|
||||||
# https://gist.github.com/anthonyaxenov/b8336a2bc9e6a742b5a050fa2588d71e
|
|
||||||
|
|
||||||
# database credentials ==============================================
|
|
||||||
|
|
||||||
DBUSER=
|
|
||||||
DBPASS=
|
|
||||||
DBNAME=
|
|
||||||
DBCHARSET="utf8"
|
|
||||||
|
|
||||||
# date formats ======================================================
|
|
||||||
|
|
||||||
FMT_DT_DIR="%Y.%m.%d" # 2021.03.19
|
|
||||||
FMT_DT_FILE="%H.%M" # 08.24
|
|
||||||
FMT_DT_LOG="%H:%M:%S" # 08:24:15.168149413
|
|
||||||
|
|
||||||
# local storage =====================================================
|
|
||||||
|
|
||||||
LOCAL_BAK_DIR="/backup/$(date +$FMT_DT_DIR)"
|
|
||||||
|
|
||||||
# database backup file
|
|
||||||
LOCAL_SQL_FILE="$(date +$FMT_DT_FILE)-db.sql.gz"
|
|
||||||
LOCAL_SQL_PATH="$LOCAL_BAK_DIR/$LOCAL_SQL_FILE"
|
|
||||||
|
|
||||||
# project path and backup file
|
|
||||||
LOCAL_SRC_DIR="/var/www/"
|
|
||||||
LOCAL_SRC_FILE="$(date +$FMT_DT_FILE)-src.tar.gz"
|
|
||||||
LOCAL_SRC_PATH="$LOCAL_BAK_DIR/$LOCAL_SRC_FILE"
|
|
||||||
|
|
||||||
# log file
|
|
||||||
LOG_FILE="$(date +$FMT_DT_FILE).log"
|
|
||||||
LOG_PATH="$LOCAL_BAK_DIR/$LOG_FILE"
|
|
||||||
|
|
||||||
log() {
|
|
||||||
echo -e "[$(date +$FMT_DT_LOG)] $*" | tee -a "$LOG_PATH"
|
|
||||||
}
|
|
||||||
|
|
||||||
# remote storage ====================================================
|
|
||||||
|
|
||||||
REMOTE_HOST="user@example.com"
|
|
||||||
REMOTE_BAK_DIR="/backup/$(date +$FMT_DT_DIR)"
|
|
||||||
REMOTE_SQL_PATH="$REMOTE_BAK_DIR/$LOCAL_SQL_FILE"
|
|
||||||
REMOTE_SRC_PATH="$REMOTE_BAK_DIR/$LOCAL_SRC_FILE"
|
|
||||||
REMOTE_LOG_PATH="$REMOTE_BAK_DIR/$LOG_FILE"
|
|
||||||
|
|
||||||
# start =============================================================
|
|
||||||
|
|
||||||
echo
|
|
||||||
log "Start ----------------------------------------------------------------"
|
|
||||||
log "Initialized parameters:"
|
|
||||||
log "\tDB_USER\t\t= $DB_USER"
|
|
||||||
log "\tDB_NAME\t\t= $DB_NAME"
|
|
||||||
log "\tDB_CHARSET\t= $DB_CHARSET"
|
|
||||||
log "\tLOCAL_SRC_DIR\t= $LOCAL_SRC_DIR"
|
|
||||||
log "\tLOCAL_SRC_PATH\t= $LOCAL_SRC_PATH"
|
|
||||||
log "\tLOCAL_SQL_PATH\t= $LOCAL_SQL_PATH"
|
|
||||||
log "\tLOG_PATH\t= $LOG_PATH"
|
|
||||||
log "\tREMOTE_HOST\t= $REMOTE_HOST"
|
|
||||||
log "\tREMOTE_SQL_PATH\t= $REMOTE_SQL_PATH"
|
|
||||||
log "\tREMOTE_SRC_PATH\t= $REMOTE_SRC_PATH"
|
|
||||||
log "\tREMOTE_LOG_PATH\t= $REMOTE_LOG_PATH"
|
|
||||||
|
|
||||||
mkdir -p $LOCAL_BAK_DIR
|
|
||||||
log "Created local dir: $LOCAL_BAK_DIR"
|
|
||||||
|
|
||||||
ssh $REMOTE_HOST mkdir -p $REMOTE_BAK_DIR
|
|
||||||
log "Created remote dir: $REMOTE_BAK_DIR"
|
|
||||||
|
|
||||||
log "1/4 Dumping DB: $DBNAME..."
|
|
||||||
mysqldump \
|
|
||||||
--user="$DBUSER" \
|
|
||||||
--password="$DBPASS" \
|
|
||||||
--default-character-set="$DBCHARSET" \
|
|
||||||
--opt \
|
|
||||||
--quick \
|
|
||||||
"$DBNAME" | gzip > "$LOCAL_SQL_PATH"
|
|
||||||
# --opt Same as --add-drop-table, --add-locks, --create-options,
|
|
||||||
# --quick, --extended-insert, --lock-tables, --set-charset,
|
|
||||||
# and --disable-keys
|
|
||||||
[ $? -gt 0 ] && log "ERROR: failed to create dump. Exit-code: $?" || log "\t- OK"
|
|
||||||
|
|
||||||
log "2/4 Sending database backup to $REMOTE_HOST..."
|
|
||||||
rsync --progress "$LOCAL_SQL_PATH" "$REMOTE_HOST:$REMOTE_SQL_PATH"
|
|
||||||
[ $? -gt 0 ] && log "ERROR: failed to send database backup. Exit-code: $?" || log "\t- OK"
|
|
||||||
|
|
||||||
log "3/4 Compressing project dir: $LOCAL_SRC_DIR..."
|
|
||||||
tar -zcf "$LOCAL_SRC_PATH" "$LOCAL_SRC_DIR"
|
|
||||||
[ $? -gt 0 ] && log "ERROR: failed to compress project. Exit-code: $?" || log "\t- OK"
|
|
||||||
|
|
||||||
log "4/4 Sending project backup to ${REMOTE_HOST}..."
|
|
||||||
rsync --progress "$LOCAL_SRC_PATH" "$REMOTE_HOST:$REMOTE_SRC_PATH"
|
|
||||||
[ $? -gt 0 ] && log "ERROR: failed to send project backup. Exit-code: $?" || log "\t- OK"
|
|
||||||
|
|
||||||
rsync --progress "$LOG_PATH" "$REMOTE_HOST:$REMOTE_LOG_PATH"
|
|
||||||
|
|
||||||
log "Finish!"
|
|
||||||
log "Used space: $(du -h "$LOCAL_BAK_DIR" | tail -n1)"
|
|
||||||
log "Free space: $(df -h | tail -n1 | awk '{print $4}')"
|
|
Loading…
Reference in New Issue
Block a user