Pandangan tentang 26 Teknik Analisis Data Besar: Bahagian 1
Pandangan tentang 26 Teknik Analisis Data Besar: Bahagian 1
Dalam penulisan ini, kita akan membahas cara membuat sandaran beberapa pangkalan data MySQL atau MariaDB yang berada di mesin yang sama menggunakan skrip bash tersuai dan menyiapkan pekerjaan cron.
Kami akan menganggap bahawa kami mempunyai tiga pangkalan data MySQL pada contoh Vultr kami yang bernama db-vultr-site , db-vultr-blog , db-vultr-app (Jangan risau membuat pangkalan data ini, anda akan dapat mengganti namanya untuk anda adakah ia digunakan dalam skrip pada Langkah 2 di bawah) .
Log masuk ke pangkalan data MySQL atau MariaDB anda dan jalankan pertanyaan di bawah untuk membuat pengguna pangkalan data db_user_backups
untuk mengendalikan sandaran
GRANT LOCK TABLES, SELECT, SHOW VIEW, REPLICATION CLIENT ON *.* TO 'db_user_backups'@'%' IDENTIFIED BY '{COMPLEX-PASSWORD}';
Jalankan juga di bawah untuk memastikan MySQL dikonfigurasi untuk memulihkan prosedur yang disimpan dengan betul
SET GLOBAL log_bin_trust_function_creators = 1;
Sediakan struktur direktori dan fail yang diperlukan
# 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
Buka db-backup.sh nano /backups/db-backup.sh
dan tampal kod di bawahnya, kemudian simpan fail (Ctrl + X -> Y -> tekan 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
Kod di atas melengkapkan array dengan nama pangkalan data yang anda mahu sandarkan dan melakukannya.
Siapkan cronjob untuk dijalankan setiap tengah malam yang menjalankan skrip sandaran dan menyimpan hasil / output ke log sandaran.
Buka crontab
crontab -e
Tambahkan entri di bawah ke crontab
0 0 * * * /usr/bin/env bash /backups/db-backup.sh &>> /backups/db-backup.log
Catatan: Semasa menguji, anda boleh menetapkan cronjob berjalan setiap 1 minit seperti di bawah
* * * * * /usr/bin/env bash /backups/db-backup.sh &>> /backups/db-backup.log
-OR- setiap 5 minit (ganti 5 dengan bilangan minit yang anda mahukan)
*/5 * * * * /usr/bin/env bash /backups/db-backup.sh &>> /backups/db-backup.log
Anda mungkin tidak mahu sandaran anda pada pelayan yang sama menjalankan pangkalan data anda, tetapi sebaliknya pada pelayan di lokasi geografi yang berbeza. Ada beberapa cara untuk melakukannya, mulai dari menggunakan SFTP, hingga menggunakan alat khusus yang disediakan oleh banyak penyedia penyimpanan awan yang tersedia di luar sana. Salah satu alternatif yang baik adalah Rsync seperti yang dijelaskan di sini - vultr.com/docs/setup-file-mirroring-using-rsync-in-debian-ubuntu
Ditulis oleh Lami Adabonyan
Pandangan tentang 26 Teknik Analisis Data Besar: Bahagian 1
Ramai daripada anda tahu Switch akan keluar pada Mac 2017 dan ciri baharunya. Bagi yang tidak tahu, kami telah menyediakan senarai ciri yang menjadikan 'Tukar' sebagai 'gajet yang mesti ada'.
Adakah anda menunggu gergasi teknologi memenuhi janji mereka? semak apa yang masih belum dihantar.
Baca blog untuk mengetahui lapisan berbeza dalam Seni Bina Data Besar dan fungsinya dengan cara yang paling mudah.
Baca ini untuk mengetahui cara Kecerdasan Buatan semakin popular di kalangan syarikat berskala kecil dan cara ia meningkatkan kebarangkalian untuk menjadikan mereka berkembang dan memberikan pesaing mereka kelebihan.
CAPTCHA telah menjadi agak sukar untuk diselesaikan oleh pengguna dalam beberapa tahun kebelakangan ini. Adakah ia dapat kekal berkesan dalam pengesanan spam dan bot pada masa hadapan?
Apabila Sains Berkembang pada kadar yang pantas, mengambil alih banyak usaha kita, risiko untuk menundukkan diri kita kepada Ketunggalan yang tidak dapat dijelaskan juga meningkat. Baca, apakah makna ketunggalan bagi kita.
Apakah teleperubatan, penjagaan kesihatan jauh dan impaknya kepada generasi akan datang? Adakah ia tempat yang baik atau tidak dalam situasi pandemik? Baca blog untuk mencari paparan!
Anda mungkin pernah mendengar bahawa penggodam memperoleh banyak wang, tetapi pernahkah anda terfikir bagaimana mereka memperoleh wang seperti itu? Mari berbincang.
Baru-baru ini Apple mengeluarkan macOS Catalina 10.15.4 kemas kini tambahan untuk menyelesaikan masalah tetapi nampaknya kemas kini itu menyebabkan lebih banyak masalah yang membawa kepada pemusnahan mesin mac. Baca artikel ini untuk mengetahui lebih lanjut