Перезалив репозитория
This commit is contained in:
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 # Успешное завершение скрипта
|
||||
55
scripts/second-mon.sh
Executable file
55
scripts/second-mon.sh
Executable file
@@ -0,0 +1,55 @@
|
||||
#!/bin/bash
|
||||
|
||||
# https://gist.github.com/anthonyaxenov/c16e1181d4b8a8644c57ec8a1f6cf21c
|
||||
|
||||
#########################################################################
|
||||
# #
|
||||
# Set display resolution #
|
||||
# #
|
||||
# Author: Anthony Axenov (Антон Аксенов) #
|
||||
# Version: 1.0 #
|
||||
# License: WTFPL #
|
||||
# #
|
||||
#########################################################################
|
||||
# #
|
||||
# Using this script you can change your display resolution #
|
||||
# to any one you need. Just adjust some vars below and run script #
|
||||
# (chmod +x needed). #
|
||||
# #
|
||||
#########################################################################
|
||||
|
||||
# Set display name to work with. You can get it via 'xrandr --listactivemonitors'
|
||||
display="HDMI-2"
|
||||
# Set width of this display in px
|
||||
width=1600
|
||||
# Set height of this display in px
|
||||
height=900
|
||||
|
||||
# Sometimes cvt and gtf generates different modelines.
|
||||
# You can play around and look which of them gives best result:
|
||||
modeline=$(cvt ${width} ${height} | grep "Modeline")
|
||||
# modeline=$(gtf ${width} ${height} 60 | grep "Modeline")
|
||||
|
||||
# Some important data needed to xrandr:
|
||||
modename="${width}x${height}_my"
|
||||
params=$(echo "$modeline" | sed "s|^\s*Modeline\s*\"[0-9x_.]*\"\s*||")
|
||||
|
||||
echo "Set resolution ${width}x${height} on display $display:"
|
||||
echo "$modename $params"
|
||||
|
||||
# Simple logic:
|
||||
# 1. Switch display to safe mode which always exists (I believe) to avoid errors
|
||||
xrandr --output $display --mode 640x480
|
||||
# 2. If display aready have our mode -- we must delete it to avoid errors
|
||||
if $(xrandr | grep -q "$modename"); then
|
||||
# 2.1. Detach mode from display
|
||||
xrandr --delmode $display $modename
|
||||
# 2.2. Remove mode itself
|
||||
xrandr --rmmode $modename
|
||||
fi
|
||||
# 3. Create new mode with freshly generated parameters
|
||||
xrandr --newmode $modename $params
|
||||
# 4. Attach mode to our display
|
||||
xrandr --addmode $display $modename
|
||||
# 5. Switch display to this mode immidiately
|
||||
xrandr --output $display --mode $modename
|
||||
Reference in New Issue
Block a user