(十六)Linux文件备份

(十六)Linux文件备份,第1张

1.Linux系统需要备份数据

/root/目录:

/home/目录:

/var/spool/mail/目录:

/etc/目录:

其他目录:

数据备份的原则: 不要把鸡蛋放在同一个篮子里

2.安装服务的数据

apache需要备份的数据

配置文件

网页主目录

日志文件

mysql需要备份的数据

源码包安装的mysql:/usr/local/mysqld/data/

RPM包安装的mysql:/var/lib/mysql/

3.备份策略

完全备份: 完全备份就是指把所有需要备份的数据全部备份,当然完全备份可以备份整块硬盘,整个分区或某个具体的记录(需要更大的硬盘空间和时间)

增量备份: 第一天完全备份,第二天备份当天新增数据,第三天备份当天数据,即每次都是备份新增数据,每次备份后数据要进行压缩(需要较小的硬盘空间恢复麻烦)

差异备份: 第一天完全备份,第二天备份当天新增数据,第三天备份相比原始备份新增数据,即每次都是备份与原始数据相比的新增数据(比完全备份需要的空间小一点,比增量备份恢复容易一点)

1.dump命令

dump [选项] 备份之后的文件名 原文件或目录

选项

-level                    就是我们说的0-9十个备份级别

-f 文件名              指定备份之后的文件名

-u                          备份成功之后,把备份时间记录在/etc/dumpdates文件

-v                          显示备份过程中更多的输出信息

-j                          调用bzib库压缩备份文件,其实就是把备份文件压缩为.bz2格式

-W                        显示允许被dump的分区的备份等级及备份时间

备份分区实例

dump -0uj -f /root/boot.bak.bz2 /boot/        备份命令,先执行一次完全备份,并压缩和更新备份时间

cat /etc/dumpdates                查看备份时间文件

cp install.log /boot/                复制日志文件到boot分区

dump -luj -f /root/boot.bak1.bz2              增量备份/boot分区,并压缩

dump -W                  查询分区的备份时间及备份级别的

备份文件或目录实例

dump -0j /root/etc.dump.bz2 /etc/        完全备份/etc/目录,只能使用0级别进行完全备份,而不再支持增量备份

注意: dump只能针对分区做增量备份,对文件或目录不能进行增量备份

2.restore命令

restore [模式选项] [选项]

模式选项:restore命令常用的模式有一下四种,这四个模式不能混用

-C            比较备份数据和实际数据的变化

-i             进入交互模式,手工选择需要恢复的文件

-t             查看模式,用于查看备份文件中拥有哪些数据

-r             还原模式,用于数据还原

选项

-f            指定备份文件的文件名

比较备份数据和实际数据的变化

mv /boot/vmlinuz-2.3.32--279.el6.i686 /boot/vmlinuz-2.6.32-279.el6.i686.bak

把boot目录中内核镜像文件改个名字

restore -C -f /root/boot.bak.bz2

restore发现内核镜像文件丢失

查看模式

restore -t -f boot.bak.bz2

还原模式

还原boot.bak.bz2分区备份

mkdir boot.test

cd boot.test/

先还原完全备份的数据

restore -r -f /root/boot.bak.bz2

再恢复增量备份的数据

restore -r -f /root/boot.bak1.bz2

还原/etc/目录的备份etc.dump.bz2

restore -r -f etc.dump.bz2

还原etc.dump.bz2备份

首先建议你作业自己做。这些问题其实用google一查就查到了。

1. 用cron做定时作业。具体cron定时格式网上有专门的工具来生成。不过也不难理解

五个星号依次是 分钟、小时、日期(1-31)、月份、周日(0-6,0为星期日)

crontab -e 是编辑cron,用的是vi,然后添加

1 0 1 * * mysqldump --add-drop-table -h <dbhost>-u <dbuser>-p<dbpassword>--database <dbname>>backup.sql

1 0 15 * * mysqldump --add-drop-table -h <dbhost>-u <dbuser>-p<dbpassword>--database <dbname>>backup.sql

2. 如果在linux下,可以直接安装LAMP - Linux+Apache+MySQL+PHP,基本服务器环境就搭建好了。具体步骤在这里全列出来不实际。

<?php

$db = mysql_connect("localhost", "username", "password")

mysql_select_db("dbname")

$query = mysql_query("SELECT * FROM test_table")

if ($query !== false) {

while ($row = mysql_fetch_array($query)) {

print_r($row)

}

}

?>

我不会给你详细的方法,因为系统版本和具体需求的问题,最好是你在你的社区找方法,并且参照你自己的man page,以免版本间不同造成混乱。

备份有dd,dump,和tar

前两者可以备份分区,tar只能备份文件

如果说linux开机备份,那么我想是增量备份么?那么最好用dump

如果你只是想ghost那样的备份,最好是dd

所以从你的提问中我没看懂你需要的是哪种备份

至于具体用法,goole一下满世界都是了,不麻烦的^^,写在这里反而不好排版呢

dump用法:http://betterliu.blog.51cto.com/339062/131224

dd用法:http://www.linuxdiyf.com/viewarticle.php?id=104773

把dump放入开机启动进程就可以了

不过整个备份太可怕了,如果只是备份软件,tar很不错

sudo tar -czvf xxx.tar.gz oooo

xxx是备份后文件明oooo是要备份的目录或者文件


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/9027106.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-24
下一篇 2023-04-24

发表评论

登录后才能评论

评论列表(0条)

保存