详解MySQ如何实现数据备份
本文给大家介绍MySQ什么是数据备份,让大家了解MySQ实现数据备份的方法,有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。
MySQL备份概述
问题:备份和冗余有什么区别?
备份:能够防止由于机械故障以及人为操作带来的数据丢失,例如将数据库文件保存在了其它地方。
冗余:数据有多份冗余,但不等于备份,只能防止机械故障带来的数据丢失,例如主备模式、数据库集群。
备份是什么?
databases Binlog my.cnf /data/xxx(数据目录)
备份数据库,还有日志文件,还有配置文件,尽可能将数据目录里面的文件全部备份。
备份过程中必须考虑因素:
1、必须制定详细的备份计划(备份频率、时间点、周期)(根据当前的业务情况,需要考虑备份的时间和备份数据的大小。数据量太大的话就使用冗灾)。
2、备份数据应该放在非数据库本地,并建议有多份副本
3、必须做好数据恢复的演练(每隔一段时间,对备份的数据在测试环境中进行模拟恢复,保证当出现数据灾难的时候能够及时恢复数据。)(保证数据的可用性)备份完成后进行断电模拟演练。测试数据库是否可以正常启动,数据能否正常进行恢复。
4、根据数据应用的场合、特点选择正确的备份工具。
5、数据的一致性。
6、数据的可用性。
备份类型
逻辑备份
逻辑备份就是在不停业务的情况下进行备份。
备份的是建表、建库、插入等操作所执行SQL语句(DDL DML DCL),适用于中小型数据库,效率相对较低。
(一般在数据库正常提供服务的前提下进行的);如:mysqldump、mydumper、 into outfile(表的导出导入)等
物理备份
直接复制数据库文件,适用于大型数据库环境,不受存储引擎的限制,但不能恢复到不同的MySQL版本。
(一般在数据库彻底关闭或者不能完成正常提供服务的前提下进行的备份);如:tar、cp、xtrabackup、lvm snapshot等
在线热备
在线热备:AB复制(在线实时)(指的是对数据的冗余)
M-S
M-Sn
M-S1-S2
M-M-Sn
备份工具
社区版安装包中的备份工具
mysqldump
企业版和社区版都包含
本质上使用SQL语句描述数据库及数据并导出
在MYISAM引擎上锁表,Innodb引擎上锁行
数据量很大时不推荐使用
mysqlhotcopy
企业版和社区版都包含
perl写的一个脚本,本质上是使用锁表语句再拷贝数据
只支持MYISAM数据引擎
企业版安装包中的备份工具
mysqlbackup
在线备份
增量备份
部分备份
在某个特定时间的一致性状态的备份
第三方备份工具
XtraBackup和innobackupex
Xtrabackup是一个对InnoDB做数据备份的工具,支持在线热备份(备份时不影响数据读写),是商业备份工具InnoDB Hotbackup的一个很好的替代品
Xtrabackup有两个主要的工具:xtrabackup、innobackupex
xtrabackup只能备份InnoDB和XtraDB两种数据表,不能备份myisam类型的表,也不能备份数据表结构。
innobackupex是将Xtrabackup进行封装的perl脚本,所以能同时备份处理innodb和myisam的存储引擎,但在处理myisam时需要加一个读锁
mydumper
mydumper 多线程备份工具
https://launchpad.net/mydumper/mydumper-0.9.1.tar.gz
备份方法
完全备份
增量备份
差异备份
差异增量备份
• Sunday
An incremental level 0 backup backs up all blocks that have ever been in use in this database.
• Monday through Saturday
On each day from Monday through Saturday, a differential incremental level 1 backup backs up all blocks that have changed since the most recent incremental backup at level 1 or 0. The Monday backup copies blocks changed since Sunday level 0 backup, the Tuesday backup copies blocks changed since the Monday level 1 backup, and so forth.
累计增量备份
• Sunday
An incremental level 0 backup backs up all blocks that have ever been in use in this database.
• Monday - Saturday
A cumulative incremental level 1 backup copies all blocks changed since the most recent level 0 backup. Because the most recent level 0 backup was created on Sunday, the level 1 backup on each day Monday through Saturday backs up all blocks changed since the Sunday backup.
需要掌握的备份方法:
逻辑数据的导入导出(into outfile)、mysqldump、mysqlhotcopy、xtrabackup和innobackupex
lvm-snapshot、mysqlbackup
总结:以上就是本篇文的全部内容,希望能对大家的学习有所帮助。更多相关教程请访问mysql数据库图文教程 ,MySQL视频教程,bootstrap视频教程!
Atas ialah kandungan terperinci 详解MySQ如何实现数据备份. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Sandaran dan pemulihan data ThinkPHP6: memastikan keselamatan data Dengan perkembangan pesat Internet, data telah menjadi aset yang sangat penting. Oleh itu, keselamatan data amat membimbangkan. Dalam pembangunan aplikasi web, sandaran dan pemulihan data adalah bahagian penting dalam memastikan keselamatan data. Dalam artikel ini, kami akan memperkenalkan cara menggunakan rangka kerja ThinkPHP6 untuk sandaran dan pemulihan data bagi memastikan keselamatan data. 1. Sandaran data Sandaran data merujuk kepada menyalin atau menyimpan data dalam pangkalan data dalam beberapa cara. Dengan cara ini walaupun data

Sandaran data dan pemulihan aplikasi PHP melalui DockerCompose, Nginx dan MariaDB Dengan perkembangan pesat teknologi pengkomputeran awan dan kontena, semakin banyak aplikasi memilih untuk menggunakan Docker untuk digunakan dan dijalankan. Dalam ekosistem Docker, DockerCompose ialah alat yang sangat popular yang boleh menentukan dan mengurus berbilang bekas melalui satu fail konfigurasi. Artikel ini akan memperkenalkan cara menggunakan DockerCompose, Ng

Sandaran adalah tugas yang sangat penting semasa operasi laman web. Sekiranya terdapat kehilangan atau kehilangan data pada laman web, sandaran boleh memudahkan pemulihan laman web. PHP ialah bahasa pengaturcaraan sisi pelayan yang biasa digunakan Fungsi sandaran laman web boleh dilaksanakan dengan menulis skrip PHP. Artikel ini akan memperkenalkan cara menggunakan PHP untuk melaksanakan fungsi sandaran tapak web. 1. Jenis fail sandaran Apabila membuat sandaran tapak web, anda perlu membuat sandaran pangkalan data dan fail tapak web. Biasanya fail tapak web termasuk fail statik, fail program, gambar dan lampiran yang dimuat naik, dsb., manakala pangkalan data mengandungi semua maklumat tapak web.

Dalam proses pembangunan web, penyimpanan data dan sandaran sudah pasti merupakan bahagian yang sangat penting. Dalam kes kehilangan data atau keperluan pemulihan, sandaran sangat diperlukan. Untuk PHP, bahasa back-end sumber terbuka, terdapat juga banyak pilihan untuk sandaran data Mari kita lihat dengan lebih dekat pada sandaran data dalam PHP. 1. Sandaran pangkalan data 1.1 Alat MYSQLdump MYSQLdump ialah alat baris arahan untuk membuat sandaran pangkalan data MYSQL Ia menyalin keseluruhan pangkalan data atau pangkalan data dengan melaksanakan pernyataan SQL.

Cara menggunakan Java untuk menulis fungsi sandaran data sistem CMS Dalam sistem pengurusan kandungan (ContentManagementSystem, CMS), sandaran data adalah fungsi yang sangat penting dan penting. Melalui sandaran data, kami boleh memastikan bahawa data dalam sistem boleh dipulihkan tepat pada masanya sekiranya berlaku kerosakan, kehilangan atau operasi yang salah, dengan itu memastikan kestabilan dan kebolehpercayaan sistem. Artikel ini akan memperkenalkan cara menggunakan Java untuk menulis fungsi sandaran data sistem CMS dan memberikan contoh kod yang berkaitan.

Bagaimana untuk melaksanakan fungsi sandaran dan pemulihan data dalam projek PHP? Dalam proses membangunkan dan mengurus projek PHP, sandaran data dan fungsi pemulihan adalah sangat penting. Sama ada untuk mengelakkan kehilangan data secara tidak sengaja atau untuk memastikan keselamatan data semasa pemindahan dan peningkatan projek, kita perlu menguasai kaedah sandaran dan pemulihan data. Artikel ini akan memperkenalkan cara melaksanakan fungsi sandaran dan pemulihan data dalam projek PHP. 1. Laluan sandaran definisi sandaran data: Pertama, kita perlu menentukan laluan yang digunakan untuk menyimpan fail sandaran. Boleh ditakrifkan dalam fail konfigurasi projek

Menggunakan PHP dan SQLite untuk melaksanakan strategi sandaran dan pemulihan data Sandaran dan pemulihan ialah aspek yang sangat penting dalam pengurusan pangkalan data, yang boleh melindungi data kami daripada kerosakan atau kehilangan yang tidak disengajakan. Artikel ini akan memperkenalkan cara menggunakan PHP dan SQLite untuk melaksanakan strategi sandaran dan pemulihan data, membantu kami mengurus dan melindungi data dalam pangkalan data dengan lebih baik. Pertama, kita perlu mencipta pangkalan data menggunakan SQLite dan mewujudkan beberapa data ujian untuk operasi seterusnya. Berikut ialah contoh mudah: <?php

Apabila jumlah data terus meningkat, sandaran pangkalan data menjadi semakin sukar. Sandaran bukan sahaja memerlukan integriti dan konsistensi data, tetapi juga memerlukan kelajuan sandaran dan saiz fail sandaran untuk memenuhi keperluan sebenar. Teknologi sandaran pemampatan data muncul mengikut keperluan masa dan telah menjadi salah satu cara teknikal yang sangat diperlukan untuk sandaran pangkalan data. MySQL kini merupakan salah satu pangkalan data hubungan yang paling popular Alat sandaran rasmi mysqldump tidak dapat memenuhi keperluan sandaran termampat. Oleh itu, artikel ini akan memperkenalkan penggunaan arahan mampatan pada sistem Linux ta
