ホームページ データベース mysql チュートリアル mysql数据库自动备份且恢复破坏数据方法

mysql数据库自动备份且恢复破坏数据方法

Jun 07, 2016 pm 05:51 PM
mysqlバックアップ 自動バックアップ

介绍数据库自动备份以及数据库被破坏后的恢复的方法。在这里,我们使用mysqlhotcopy,并且定义一段Shell脚本来实现数据库的自动备份,并且,让整个数据自动备份与数据恢复过程都基于Shell。

建立备份所需条件

[1] 建立自动备份脚本

在这里,为了使数据库备份和恢复的符合我们的实际要求,用一段符合要求的Shell脚本来实现整个备份过程的自动化。

 代码如下 复制代码
[root@CentOS ~]# vi -backup.sh ← 建立数据库自动备份脚本,如下:
#!/bin/bash
PATH=/usr/local/sbin:/usr/bin:/bin
# The Directory of Backup
BACKDIR=/backup/mysql
# The Password of MySQL
ROOTPASS=******** 此处请将星号替换成MySQL的root密码
# Remake the Directory of Backup
rm -rf $BACKDIR
mkdir -p $BACKDIR
# Get the Name of Database
DBLIST=`ls -p /var/lib/mysql | grep / | tr -d /`
# Backup with Database
for dbname in $DBLIST
do
mysqlhotcopy $dbname -u root -p $ROOTPASS $BACKDIR | logger -t mysqlhotcopy
done

[2] 运行数据库自动备份脚本

 代码如下 复制代码

[root@CentOS ~]# chmod 700 mysql-backup.sh 改变脚本属性,让其只能让root用户执行
[root@CentOS ~]# ./mysql-backup.sh 运行脚本
[root@CentOS ~]# ls -l /backup/mysql/ 确认一下是否备份成功
total 8
drwxr-x--- 2 mysql mysql 4096 Sep 1 16:54 mysql 已成功备份到/backup/mysql目录中

[3] 让数据库备份脚本每天自动运行

[root@sample ~]# crontab -e ← 编辑自动运行规则(然后会出现编辑窗口,操作同vi)
00 03 * * * /root/mysql-backup.sh 添加这一行到文件中,让数据库备份每天凌晨3点进行

 

测试自动备份正常运转与否(备份恢复的方法)

这里,以通过实际操作的过程来介绍问题出现后的恢复方法。

[1] 当数据库被删除后的恢复方法

首先建立一个测试用的数据库。

 代码如下 复制代码
[root@CentOS ~]# mysql -u root -p ← 用root登录到MySQL服务器
Enter password: ← 输入MySQL的root用户密码
Welcome to the MySQL monitor. Commands end with ; or g.
Your MySQL connection id is 8 to server version: 4.1.20
Type 'help;' or 'h' for help. Type 'c' to clear the buffer.
mysql> create database test; ← 建立一个测试用的数据库test
Query OK, 1 row affected (0.00 sec)
mysql> use test ← 连接到这个数据库
Database changed
mysql> create table test(num int, name varchar(50)); ← 在数据库中建立一个表
Query OK, 0 rows affected (0.07 sec)
mysql> insert into test values(1,'Hello,CentOS'); ← 插入一个值到这个表(这里以“Hello,CentOS”为例)
Query OK, 1 row affected (0.02 sec)
mysql> * from test; ← 查看数据库中的内容
+------+-----------------+
| num | name |
+------+-----------------+
|1 | Hello,Centos | ← 确认刚刚插入到表中的值的存在
+------+------------------+
1 row in set (0.01 sec)
mysql> exit ← 退出MySQL服务器
Bye

然后,运行刚才建立的数据库备份脚本,备份刚刚建立的测试用的数据库。

[root@sample ~]# cd ← 回到脚本所在的root用户的根目录
[root@sample ~]# ./mysql-backup.sh ← 运行脚本进行数据库备份

接下来,我们再次登录到MySQL服务器中,删除刚刚建立的测试用的数据库test,以便于测试数据恢复能否成功。

 代码如下 复制代码
[root@Centos ~]# mysql -u root -p ← 用root登录到MySQL服务器
Enter password: ← 输入MySQL的root用户密码
Welcome to the MySQL monitor. Commands end with ; or g.
Your MySQL connection id is 13 to server version: 4.1.20
Type 'help;' or 'h' for help. Type 'c' to clear the buffer.
mysql> use test ← 连接到测试用的test数据库
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> drop table test; ← 删除数据中的表
Query OK, 0 rows affected (0.04 sec)
mysql> drop database test; ← 删除测试用数据库test
Query OK, 0 rows affected (0.01 sec)
mysql> show databases;
+---------------+
| Database |
+---------------+
| mysql | ← 确认测试用的test数据库已不存在、已被删除
+---------------+
1 row in set (0.01 sec)
mysql> exit ← 退出MySQL服务器
Bye

以上,我们就等于模拟了数据库被破坏的过程。接下来,是数据库被“破坏”后,用备份进行恢复的方法。

[root@Centos ~]# /bin/cp -Rf /backup/mysql/test/ /var/lib/mysql/ ← 复制备份的数据库test到相应目录
[root@Centos ~]# chown -R mysql:mysql /var/lib/mysql/test/ ← 改变数据库test的归属为mysql
[root@Centos ~]# chmod 700 /var/lib/mysql/test/ ← 改变数据库目录属性为700
[root@Centos ~]# chmod 660 /var/lib/mysql/test/* ← 改变数据库中数据的属性为660

然后,再次登录到MySQL服务器上,看是否已经成功恢复了数据库。

 代码如下 复制代码

[root@CentOS ~]# mysql -u root -p ← 用root登录到MySQL服务器
Enter password: ← 输入MySQL的root用户密码
Welcome to the MySQL monitor. Commands end with ; or g.
Your MySQL connection id is 14 to server version: 4.1.20
Type 'help;' or 'h' for help. Type 'c' to clear the buffer.
mysql> show databases; ← 查看当前存在的数据库
+-------------+
| Database |
+-------------+
| mysql |
| test | ← 确认刚刚被删除的test数据库已经成功被恢复回来!
+------------+
2 rows in set (0.00 sec)
mysql> use test ← 连接到test数据库
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> show tables; ← 查看test数据库中存在的表
+-------------------+
| Tables_in_test |
+-------------------+
| test |
+-------------------+
1 row in set (0.00 sec)
mysql> select * from test; ← 查看数据库中的内容
+------+---------------------+
| num | name |
+------+---------------------+
| 1 | Hello,CentOS | ← 确认数据表中的内容与删除前定义的“Hello,CentOS”一样!
+------+---------------------+
1 row in set (0.01 sec)
mysql> exit ← 退出MySQL服务器
Bye

以上结果表示,数据库被删除后,用备份后的数据库成功的将数据恢复到了删除前的状态

 

2] 当数据库被修改后的恢复方法

数据库被修改,可能存在着多方面的原因,被入侵、以及相应程序存在Bug等等,这里不作详细介绍。这里将只介绍在数据库被修改后,如果恢复到被修改前状态的方法。

具体和上面所述的“数据库被删除后的恢复方法”相类似。这里,测试用数据库接着使用刚刚在前面用过的test。这里为了使刚刚接触数据库的朋友不至于理解混乱,我们再次登录到MySQL服务器上确认一下刚刚建立的测试用的数据库test的相关信息。

 代码如下 复制代码
[root@CentOS ~]# mysql -u root -p ← 用root登录到MySQL服务器
Enter password: ← 输入MySQL的root用户密码
Welcome to the MySQL monitor. Commands end with ; or g.
Your MySQL connection id is 14 to server version: 4.1.20
Type 'help;' or 'h' for help. Type 'c' to clear the buffer.
mysql> show databases; ← 查看当前存在的数据库
+-------------+
| Database |
+-------------+
| mysql |
| test |
+------------+
2 rows in set (0.00 sec)
mysql> use test ← 连接到test数据库
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> show tables; ← 查看test数据库中存在的表
+-------------------+
| Tables_in_test |
+-------------------+
| test |
+-------------------+
1 row in set (0.00 sec)
mysql> select * from test; ← 查看数据库中的内容
+------+--------------------+
| num | name |
+------+--------------------+
| 1 | Hello,CentOS|
+------+--------------------+
1 row in set (0.01 sec)
mysql> exit ← 退出MySQL服务器
Bye

然后,我们再次运行数据库备份脚本,将当前状态的数据库,再做一次备份。

[root@CentOS ~]# cd ← 回到脚本所在的root用户的根目录
[root@CentOS ~]# ./mysql-backup.sh ← 运行脚本进行数据库备份

接下来,我们再次登录到MySQL服务器中,对测试用的数据库test进行一些修改,以便于测试数据恢复能否成功。

 代码如下 复制代码
[root@sample ~]# mysql -u root -p ← 用root登录到MySQL服务器
Enter password: ← 输入MySQL的root用户密码
Welcome to the MySQL monitor. Commands end with ; or g.
Your MySQL connection id is 15 to server version: 4.1.20
Type 'help;' or 'h' for help. Type 'c' to clear the buffer.
mysql> use test ← 连接到test数据库
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> update test set name='Shit,Windows'; ← 然后将test中表的值重新定义为“Shit,Windows”(原来为“Hello,CentOS”)
Query OK, 1 row affected (0.07 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> select * from test; ← 确认test中的表被定义的值
+------+--------------------+
| num | name |
+------+-------------------+
| 1 | Shit,Windows | ← 确认已经将原test数据库表中的值修改为新的值“Shit,Windows”
+------+-------------------+
1 row in set (0.00 sec)
mysql> exit ← 退出MySQL服务器
Bye

以上,我们就等于模拟了数据库被篡改的过程。接下来,是数据库被“篡改”后,用备份进行恢复的方法。

[root@CentOS ~]# /bin/cp -Rf /backup/mysql/test/ /var/lib/mysql/ ← 复制备份的数据库test到相应目录

然后,再次登录到MySQL服务器上,看数据库是否被恢复到了被“篡改”之前的状态。

 代码如下 复制代码
[root@CentOS ~]# mysql -u root -p ← 用root登录到MySQL服务器
Enter password: ← 输入MySQL的root用户密码
Welcome to the MySQL monitor. Commands end with ; or g.
Your MySQL connection id is 16 to server version: 4.1.20
Type 'help;' or 'h' for help. Type 'c' to clear the buffer.
mysql> use test ← 连接到test数据库
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> select * from test; ← 查看数据库中的内容
+------+----------------+
| num | name |
+------+----------------+
| 1| Hello,CentOS | ← 确认数据表中的内容与被修改前定义的“Hello,CentOS”一样!
+------+----------------+
1 row in set (0.01 sec)
mysql> exit ← 退出MySQL服务器
Bye

以上结果表示,数据库被修改后,用备份后的数据库成功的将数据恢复到了被“篡改”前的状态。

测试后…

测试完成后,将测试用过的遗留信息删除。

 代码如下 复制代码
[root@CentOS ~]# mysql -u root -p ← 用root登录到MySQL服务器
Enter password: ← 输入MySQL的root用户密码
Welcome to the MySQL monitor. Commands end with ; or g.
Your MySQL connection id is 19 to server version: 4.1.20
Type 'help;' or 'h' for help. Type 'c' to clear the buffer.
mysql> use test ← 连接到test数据库
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> drop table test; ← 删除test数据库中的表
Query OK, 0 rows affected (0.01 sec)
mysql> drop database test; ← 删除测试用数据库test
Query OK, 0 rows affected (0.00 sec)
mysql> show databases; ← 查看当前存在的数据库
+-------------+
| Database |
+-------------+
| mysql | ← 确认测试用数据库test不存在、已被删除
+-------------+
1 row in set (0.00 sec)
mysql> exit ← 退出MySQL服务器
Bye

以上介绍了用我们自己建立的一段Shell脚本,通过mysqlhotcopy来备份数据库的方法。

对于许多个人爱好者来说,组建服务器可能不是很考虑数据被破坏以及数据被破坏后的恢复工作。但不能不说,对于服务器来说,数据破坏后的恢复效率也是区 别业余和专业的因素之一。所以笔者建议,在您配置好了Web服务器以及MySQL服务器等等的时候,千万不要急于应用它,而要想办法在有限的(硬件、软件)条件下使它“坚不可摧”之后,再考虑应用的问题。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Windows 10で自動バックアップを無効にする方法 Windows 10で自動バックアップを無効にする方法 Apr 18, 2024 pm 07:49 PM

一部の Windows 10 ユーザーは、システムの組み込みの自動バックアップ機能が使用中に有効になっていることに気づきましたが、この機能はデータのセキュリティを確保するのに役立ちますが、ストレージ容量の考慮事項やその他の理由により、この機能を有効にし続ける必要性を感じない場合があります。 。したがって、Windows 10システムで自動バックアップ機能をオフにする場合は、正しい操作手順が特に重要です。次に、この記事では、このニーズを持つユーザーの参考実装のために、Win10 システムの自動バックアップ機能をオフにする方法を詳しく紹介します。閉じる方法 1. 「win+i」ショートカットキーを使用して「設定」ページをすばやく開きます。新しいページに入ったら、「更新とセキュリティ」オプションをクリックする必要があります。 2. 開いた新しいインターフェイスで、左側の列をクリックします。

PHPでMySQLデータベースの自動バックアップを実装する方法 PHPでMySQLデータベースの自動バックアップを実装する方法 May 16, 2023 am 08:54 AM

インターネット アプリケーションの普及に伴い、データベースのバックアップは Web サイトの運用と保守、およびデータのセキュリティにとって特に重要です。手動バックアップは確かに一定の保護を提供しますが、大量のデータを含む Web サイトの場合、手動バックアップは明らかに面倒で時間がかかります。現在、自動バックアップ方法は不可欠な選択肢となっており、最も一般的でわかりやすい自動バックアップ方法の 1 つは、PHP スクリプトを使用して MySQL データベースを自動的にバックアップする方法です。この記事では、PHP を使用して MySQL データベースの自動バックアップを実装する方法を紹介します。 1.私のバックアップ

Quark Network Diskを自動的にバックアップする方法 - Quark Network Diskを自動的にバックアップする方法 Quark Network Diskを自動的にバックアップする方法 - Quark Network Diskを自動的にバックアップする方法 Mar 04, 2024 pm 11:00 PM

Quark Network Disk ソフトウェアも使用していますか? しかし、Quark Network Disk を自動的にバックアップする方法を知っていますか? 以下のエディタでは、Quark Network Disk の自動バックアップ方法が提供されます。デスクトップでQuark Network Diskを開きます。私のアバターをクリックしてメインインターフェイスに入ります。 [Quark Network Disk 自動バックアップ] オプションをクリックしてオンにします。

Xiaomi Wi-Fi でルーター設定の自動バックアップを有効にする場所_Xiaomi Wi-Fi でルーター設定の自動バックアップを有効にする方法 Xiaomi Wi-Fi でルーター設定の自動バックアップを有効にする場所_Xiaomi Wi-Fi でルーター設定の自動バックアップを有効にする方法 Mar 25, 2024 pm 06:11 PM

1. Xiaomi WiFi に入り、右下隅のツールボックスをクリックします。 2. ルーティング設定を見つけます。 3. ルーター設定のバックアップを入力します。 4. クリックしてルーター設定の自動バックアップをオンにします。

Windows 7で指定したフォルダーを自動的にバックアップする方法 Windows 7で指定したフォルダーを自動的にバックアップする方法 Mar 26, 2024 pm 06:01 PM

1. 図に示すように、[Win+R] キーを押して実行を開きます: 2. 次のウィンドウに cmd と入力して、コマンド ライン ウィンドウを開きます (図に示すように)。対応するパラメータの説明 (図に示すように) 4. たとえば、E ドライブのデモ フォルダを H ドライブのデモ フォルダに 10 分ごとに自動的にバックアップするには、次のコマンドを使用します: robocopyE: demoD:demo/R:0/ W:0/MOT:10; 図に示すように: 5. 上記のパラメータ R はバックアップ失敗後の再試行回数を表し、W は再試行間隔、MOT は時間間隔を表します。図に示すように: 6 . 自動バックアップが完了すると、D ドライブの下に自動バックアップされたフォルダーが表示されます。

PHPでRedisデータベースの自動バックアップを実装する方法 PHPでRedisデータベースの自動バックアップを実装する方法 May 15, 2023 pm 06:33 PM

インターネット アプリケーションにおける Redis データベースの幅広い用途に伴い、ますます多くの企業や開発者が Redis データベースのバックアップと保護に注目し始めています。 Redis のセキュリティを確保するには自動バックアップが有効ですので、この記事では PHP を使用して Redis データベースの自動バックアップを実装する方法を紹介します。 1. Redis データベースのバックアップ Redis はオープン ソースのキーと値のデータベースであり、基本的なデータ型だけでなく、リスト、ハッシュ テーブル、セットなどの複雑なデータ構造もサポートします。 Redis のバックアップは可能です

Baidu Netdisk を自動的にバックアップする方法 Baidu Netdisk を自動的にバックアップする方法 Mar 01, 2024 pm 05:01 PM

Baidu Netdisk を使用する過程で、写真を自動的にバックアップできる機能を設定できます。以下にその操作方法を紹介します。興味のある友人が一緒に見に来てください。携帯電話で Baidu Netdisk アプリケーションを開いた後、メイン インターフェイスに入り、右下隅にある [My] ボタンをクリックしてパーソナル センター ページに入ります。次に、ページの下部にある「設定とサービス」オプションを見つけ、クリックして入力し、「設定」機能を選択して設定ページを開きます。 2. 設定ページに「自動バックアップ設定」があるので、クリックして入力します。 3. 次に、入力されたページの「アルバムバックアップ」項目をクリックして入力します。 4. 新しいページに移動すると、「写真を自動的にバックアップする」の後ろにスイッチボタンが表示されるので、その上の円形のスライダーをクリックして設定します。

PHP で MongoDB データベースの自動バックアップを実装する方法 PHP で MongoDB データベースの自動バックアップを実装する方法 May 15, 2023 pm 05:01 PM

インターネット技術の継続的な発展に伴い、データベースの重要性がますます高まっています。データベースはデータを保存する重要なキャリアであり、データベースに障害が発生すると、データの損失やデータの不整合などの問題が企業に多大な損失をもたらします。データのセキュリティと整合性を確保するには、バックアップ ソリューションを採用する必要があります。この記事では、PHP を使用して MongoDB データベースの自動バックアップを実現し、企業のデータ セキュリティの向上を支援する方法を紹介します。 1. MongoDB バックアップの概要 MongoDB は、海を保存できるまったく新しい非リレーショナル データベースです。

See all articles