پشتیبان گیری چند پایگاه داده MySQL یا MariaDB به صورت خودکار

معرفی

در این نوشتن ، ما به چگونگی تهیه نسخه پشتیبان از چندین پایگاه داده MySQL یا MariaDB که در همان دستگاه قرار دارند با استفاده از یک اسکریپت bash سفارشی و تنظیم یک کار cron ، پشتیبان می پردازیم.

تهیه نسخه پشتیبان از پایگاه داده

فرض خواهیم کرد که ما سه پایگاه داده MySQL در نمونه Vultr با نام db-vultr-site ، db-vultr-blog ، db-vultr-app داشته باشیم (از ایجاد این بانکهای داده نگران نباشید ، می توانید نام آنها را جایگزین کنید برای مورد شما از آنها در فیلمنامه مرحله 2 زیر استفاده می شود) .

  1. به پایگاه داده MySQL یا MariaDB خود وارد شوید و در زیر پرس و جو عمل کنید تا یک کاربر پایگاه داده db_user_backupsبرای تهیه نسخه پشتیبان تهیه کنید

    GRANT LOCK TABLES, SELECT, SHOW VIEW, REPLICATION CLIENT ON *.* TO 'db_user_backups'@'%' IDENTIFIED BY '{COMPLEX-PASSWORD}';
    

    همچنین زیر را اجرا کنید تا مطمئن شوید MySQL پیکربندی شده است تا به درستی روشهای ذخیره شده را بازیابی کند

    SET GLOBAL log_bin_trust_function_creators = 1;
    
  2. ساختار فهرست و پرونده های مورد نیاز را تنظیم کنید

    # create backup directory with environment and log file
    sudo mkdir /backups && cd /backups
    sudo touch .env db-backup.sh db-backup.log
    sudo chmod -R 775 /backups
    sudo chmod -R g+s /backups
    sudo chmod +x db-backup.sh
    
    # add mysql backup user credentials into environment file
    echo "export MYSQL_USER=db_user_backups" > /backups/.env
    echo "export MYSQL_PASS={COMPLEX-PASSWORD}" >> /backups/.env
    
  3. db-backup.sh را باز کنید nano /backups/db-backup.shو کد زیر آن را درون آن قرار دهید ، سپس پرونده را ذخیره کنید (Ctrl + X -> Y -> hit Enter) .

    DB_NAMES=( 'db-vultr-site' 'db-vultr-blog' 'db-vultr-app' ) #replace with your own database name(s)
    BKUP_NAMES=()
    BKUP_DIR="/backups"
    
    # get total number of directories
    total_dbs=${#DB_NAMES[@]}
    
    # create backup file names
    for (( i=0; i<${total_dbs}; i++ )); do
        BKUP_NAMES[$i]="`date +%Y%m%d%H%M`-backup-$${DB_NAMES[$i]}.sql.gz"
    done
    
    # get backup users credentials
    source $BKUP_DIR/.env
    
    # create backups
    for (( i=0; i<${total_dbs}; i++ )); do
        # NOTE: --routines flag makes sure stored procedures are also backed up
        mysqldump --routines -u ${MYSQL_USER} -p${MYSQL_PASS} | gzip > ${BKUP_DIR}/${BKUP_NAMES[$i]}
    done
    

    کد بالا از طریق یک آرایه با نام (های) پایگاه داده (های) مورد نظر برای تهیه نسخه پشتیبان و انجام این کار حلقه می کند.

تنظیم Cronjob

برای اجرای هر نیمه شب که اسکریپت پشتیبان را اجرا کرده و نتیجه / خروجی را برای ورود به سیستم تهیه پشتیبان ذخیره می کنید ، یک کاردستی تنظیم کنید.

  1. crontab را باز کنید

    crontab -e
    
  2. زیر ورودی را به crontab اضافه کنید

    0 0 * * * /usr/bin/env bash /backups/db-backup.sh &>> /backups/db-backup.log
    

    توجه: در حالی که می توانید تست کنید ، می توانید به جای زیر ، مثل هر زیر عمل کنید

    * * * * * /usr/bin/env bash /backups/db-backup.sh &>> /backups/db-backup.log
    

    -OR- هر 5 دقیقه (5 مورد را با تعداد دقایقی که می خواهید جایگزین کنید)

    */5 * * * * /usr/bin/env bash /backups/db-backup.sh &>> /backups/db-backup.log
    

بعدی چیست

شما به احتمال زیاد نمی خواهید پشتیبان (های) خود را در همان سرور (های) بانک اطلاعاتی (های) خود اجرا کنید ، بلکه در عوض روی یک سرور در یک موقعیت جغرافیایی مختلف قرار دهید. روش های مختلفی برای این کار وجود دارد ، از استفاده از SFTP ، استفاده از ابزارهای سفارشی ارائه شده توسط بی شمار ارائه دهندگان ذخیره سازی ابری که در آنجا وجود دارد. همانطور که در اینجا توضیح داده شده است ، گزینه جایگزین خوب Rsync است - vultr.com/docs/setup-file-mirroring-using-rsync-in-debian-ubuntu

نوشته شده توسط لامی آدابونیان

یک نظر بگذارید

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

با استفاده از یک سیستم متفاوت؟ Anchor CMS یک سیستم مدیریت محتوا (CMS) بسیار ساده و بسیار سبک ، بسیار آزاد و آزاد است.

اشتراک NFS را در Debian تنظیم کنید

اشتراک NFS را در Debian تنظیم کنید

NFS یک سیستم فایل مبتنی بر شبکه است که به رایانه ها اجازه می دهد تا از طریق شبکه رایانه ای به فایلها دسترسی پیدا کنند. این راهنما توضیح می دهد که چگونه می توانید پوشه ها را روی NF قرار دهید

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

هنگام راه اندازی سرور جدید لینوکس ، به روزرسانی سیستم های هسته و سایر بسته ها تا آخرین نسخه پایدار یک روش توصیه شده است. در این مقاله

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

LiteCart یک بستر سبد خرید آزاد و منبع باز است که به زبان های PHP ، jQuery و HTML 5 نوشته شده است. این نرم افزار ساده ، سبک و با کاربرد آسان است.

نحوه نصب Matomo Analytics در Fedora 28

نحوه نصب Matomo Analytics در Fedora 28

با استفاده از یک سیستم متفاوت؟ Matomo (سابقا پیویک) یک بستر تحلیلی منبع باز است ، یک جایگزین باز برای Google Analytics. منبع Matomo میزبان o

یک سرور TeamTalk را در لینوکس تنظیم کنید

یک سرور TeamTalk را در لینوکس تنظیم کنید

TeamTalk یک سیستم کنفرانس است که به کاربران امکان می دهد مکالمات صوتی / تصویری با کیفیت بالا ، چت متنی ، انتقال فایل ها و صفحه های به اشتراک بگذارند. من

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

Vultr یک ویژگی را فراهم می کند که به شما امکان می دهد با ایجاد یک نمونه جدید ، کلیدهای SSH را از قبل نصب کنید. این اجازه می دهد تا به کاربر root دسترسی داشته باشید ، با این حال ، th

نحوه نصب انجمن NodeBB در FreeBSD 12

نحوه نصب انجمن NodeBB در FreeBSD 12

با استفاده از یک سیستم متفاوت؟ NodeBB یک نرم افزار انجمن مبتنی بر Node.js است. از سوکت های وب برای تعامل فوری و اعلامیه های زمان واقعی استفاده می کند. NodeB

نحوه نصب Ranger Terminal File Manager در لینوکس

نحوه نصب Ranger Terminal File Manager در لینوکس

رنجر یک مدیر فایل مبتنی بر خط فرمان است که دارای کلیدهای اتصال VI است. این برنامه یک رابط لعنتی مینیمالیستی و زیبا با نمای سلسله مراتب فهرست ارائه می دهد

نصب و راه اندازی ZNC در اوبونتو

نصب و راه اندازی ZNC در اوبونتو

ZNC یک پیشرانه پیشرفته شبکه IRC است که تمام وقت بهم متصل می شود تا مشتری IRC بتواند بدون از دست دادن جلسه گپ قطع یا وصل شود.