/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是要备份的目录或者文件
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)