Chinaunix首页 | 论坛 | 博客
  • 博客访问: 104966547
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类: LINUX

2008-05-04 22:17:30

 

Amanda (Advanced Maryland Automatic Network Disk Archiver,马里兰高级自动网络磁盘存档工具) 是由马里兰大学的James da Silva在1991年所开发的。它是一个复杂的网络备份系统,能够把LAN中的所有计算机备份到一台服务器的磁带驱动器、磁盘或光盘上。

Amanda本身并不是备份程序,它其实只是管理其他备份软件的封装软件。它使用系统上的dump和restore命令作为底层的备份软件,同时也能够使用tar命令,针对于windows计算机,Amanda还能够使用smbtar命令来实现备份。

Amanda支持类型广泛的磁带驱动器,并且能够使用磁带驱动器中的硬件压缩功能,或者也可以在数据通过网络之前使用客户机的compress以及gzip命令来压缩备份。其次,Amanda能够使用临时保存磁盘作为备份存档的中间存储媒介,以优化磁带的写入性能并保证在磁带出错时也能备份数据。

Amanda是当前最流行的免费备份解决方案,目前Amanda最新的稳定版本是2.5.2p2。通过 站点可以免费获得。

Amanda 综合使用完全备份和增量备份来保存所负责的全部数据,使用最小的、有可能是每日的备份集。一台 Amanda 服务器可以备份任意数量执行 Amanda 的客户机或是将连上 Amanda 服务器的计算机上的数据备份到一台磁带机上。一个常见的问题是,数据写入磁带机的时间将超过取行数据的时间,而 Amanda 解决了这个问题。它使用一个 “holding disk” 来同时备份几个文件系统。 Amanda 建立 “archive sets” 的一组磁带,用来备份在 Amanda 的配置文件中所列出的完整的文件系统。

Amanda 的整体策略是:在每次周期中完成一次数据的完全备份,并且确保在两次完全转储之间备份所有更改的数据。传统的做法是先执行完全备份,然后在此期间执行增量备份。而Amanda 的工作方式不同的是,每次运行Amanda 都对部分数据进行完全备份,确切地说,就是在一个完整的备份周期内备份全部数据所需备份的其中一部分。例如,如果周期为 7 天,且一个周期内进行7次备份,则每天必须备份 1/7 的数据,以便在 7 天之内完成一次完全备份。除了这个“部分”完全备份外,Amanda 还对自最近一次完全备份后更改的数据进行增量备份。Amanda这种特有的备份策略,可以减少每次备份的数据量。

在安装GTES11时,如果使用典型或者完全安装,默认会安装amanda以及相关的软件包,进入系统后,可以在系统终端系统里使用如下命令来查看:

# rpm -qa|grep amanda
amanda-server-2.5.0p2-4
amanda-devel-2.5.0p2-4
amanda-2.5.0p2-4
amanda-client-2.5.0p2-4

如果没有安装amanda以及相关的软件包,那么可以将GTES11的第二张和第三张光盘/GTES目录下的amanda-2.5.0p2-4.i386.rpm、amanda-server-2.5.0p2-4.i386.rpm、amanda-client-2.5.0p2-4.i386.rpm、amanda-devel-2.5.0p2-4.i386.rpm文件拷贝到指定的目录下,使用“rpm -ivh amanda*”来安装。

Amanda系统包含如下组件:

1、客户端程序,是amandad 其中最重要的。此后台程序在备份运行时和 Amanda 服务器进行通信。在/usr/lib/amanda目录下,还有其它的一些客户端程序: amandad 处理客户机和中央服务器之间的所有通信;运行所有其它的客户端程序; selfcheck 验证本地Amanda 配置; sendsize 估计备份大小; sendbackup 执行备份操作; 这些程序是 Amanda 客户端系统的一部分。但是并不能通过手工去执行他们,是由客户端包的其他辅助程序来调用这些程序。

2、执行各阶段实际备份操作的服务器程序。amdump 程序启动 Amanda ,并且常常使用 cron 定期运行。它控制一些其他程序,包括: planner 决定备份哪些内容; driver 设备接口; dumper 与客户端 amandad 进程进行通信; taper 把数据写入媒介; amreport 准备 Amanda 运行的报告;

3、执行相关任务的管理工具,包括: amcheck 验证 Amanda 配置的有效性以及此工具是否准备运行; amlabel 在磁带上写入Amanda卷标,用于避免覆盖错磁带; amcleanup 在中断或系统崩溃后进行清理; amflush 强制把临时保存区的数据写入备份媒介; amadmin 查出要恢复的正确磁带,并执行各种其它管理任务;

4、 指定 Amanda 操作的配置文件。比如备份内容、频率、位置以及磁带设备特征等。这些文件为 amanda.conf 和 disklist,在/etc/amanda下每个子目录对应于一个 Amanda “配置”,默认为“DailySet1”,它是一套独特的设置和选项,由目录名来引用。

5、amrestore工具可用来恢复 Amanda 备份中的数据。此外,amrecover工具支持交互式的文件恢复。它依赖于后台amindexd和amidxtaped程序进行工作。

1、启动客户端服务 在客户端编辑/etc/xinetd.d/amanda文件,将其中的“disable=yes”改为“disable=no”,如下:

service amanda
{
        socket_type             = dgram
        protocol                = udp
        wait                    = yes
        user                    = amanda
        group                   = disk
        server                  = /usr/lib/amanda/amandad
        disable                 = no
}

保存退出,重启xinetd服务。

# service xinetd restart
停止 xinetd:                                              [确定]
启动 xinetd:                                              [确定]

2、授予备份此客户端的Amanda服务器和用户 编辑amanda用户主目录(/var/lib/amanda)下的“.amandahosts”文件,将服务器的主机名以及用于备份的用户名(默认为amanda),该文件的格式和“.rhost”类似,例如,Amanda服务器的主机名为turbolinux,用户是amanda,则在.amandahosts文件插入如下:

turbolinux  amanda
turbolinux  root

同时,也需要把服务器和root用户的对应关系加在里面,否则在恢复数据的时候将不能访问服务器。在这里设置完Amanda服务器的主机名后,同时也要在/etc/hosts文件里面指定Amanda服务器IP和主机名的对应关系,否则Amanda客户端将不能访问服务端。

Amanda配置文档默认路径在/etc/amanda/DailySet1,在前面提到过,Amanda一个目录对应一个配置,Amanda的所有备份策略和执行命令,均通过“DailySet1”这个目录下的几个配置文档来定义。 在amanda.conf里面通常需要设置的有如下部分:

org  "turbolinux"

设置使用amanda的单位或者机构的名称

mailto   "root@turbolinux.com.cn"

指定将报告发送的邮件地址

dumpuser    amanda

指定使用Amanda备份的用户,默认为amanda用户

dumpcycle   7days

设置备份周期的长度,单位也可以是weeks,在这里设置7days和1weeks的效果是一样的。

runspercycle   7

设置每个备份周期内amanda运行的次数

tapecycle 1 tapes

设定完成一个完整的备份周期最少所需要磁带,这个需要根据备份数据量的大小来设定

ctimeout   30

设置检测客户端超时时间,单位为秒

runtapes   1

amdump每次运行使用磁带最大数

tapedev "/dev/nst0"

指定使用磁带机的设备名称,“/dev/nst0”表示不倒带设备。

tpchanger " chg-manual"

更换下一个磁带的脚本。在disk-to-tape方式中它与tapedev只能使用其中一个,建议将该项注释掉。

tapetype HP-DAT

指定磁带类型,下面将讲到如何去定义磁带类型。

labelstr "^DailySet1-[0-9][0-9]*$"

设定磁带卷标格式,使用正则表达式去匹配卷标名称,磁带在使用之前,必须使用 amlabel 指定卷标,下面将会讲到amlabel的用法。

logdir "/var/log/amanda"  

指定日志文件存放的目录,默认存放在amanda配置目录下

indexdir "/var/adm/index"

指定存放备份集索引数据目录,默认为amanda配置目录下的index目录 在配置文件中包含了许多预定义的磁带类型,所以一般都不需要自己手工去定义磁带类型,关于定义磁带类型的格式以及参数见如下:

define tapetype HP-DAT {
    comment "DAT tape drives"   对于磁带类型的描述
    length 1930 mbytes   磁带的容量
    filemark 111 kbytes  文件标志大小
    speed 468 kbytes  磁带驱动器速度
}

上面的内容表示对HP-DAT这台磁带类型的定义,磁带类型的参数尤其重要,所以不要乱修改里面的参数。

    holdingdisk hd1 {
    directory "/dumps/amanda"    临时磁盘存放的路径
    use 5 Gb    临时磁盘总共可以使用的大小
    }

上面是对临时存储磁盘的定义,同时可以定义多个临时磁盘,在分配临时磁盘的大小有两种设定方法,一种是指定临时磁盘可以使用的大小,当值为0是则使用所有剩余空间;另一种是在临时磁盘这个文件系统上始终保留一定的空间,其余的则全部分配给临时磁盘使用。 在amanda.conf文件,最后需要配置的就是定义转储类型,转储类型里面主要定义备份时使用的程序,压缩的类型等。如下:

  define dumptype root-tar {
    global   调用前面定义的global类型
    program "GNUTAR"  使用GNU tar作为备份程序,默认是DUMP
    comment "root partitions dumped with tar"  描述该类型的信息
    compress none   不采用压缩
    exclude list "/etc/amanda/exclude.gtar"   排除备份文件的列表
    }

在每个转储类型的定义中,都可以调用前面定义好的类型。如果需要对备份的数据进行压缩,有两种方式可以实现,一种是在客户端压缩,那么可在compress项设置为“compress client fast”或“compress client best”,另一种是在服务器进行压缩,则设置为“compress server fast”或“compress server best”。

接下来需要修改的是disklist文件,该文件存放在配置目录下,disklist用于指定实际要备份的数据,里面的格式是: client partition/mountpoint dumptype client :需要备份的客户度计算机,可以是IP或者主机名; partition/mountpoint: 指定要备份的内容,可以是设备名或挂载点。 dumptype:指定备份数据时使用的转储类型,这是在amanda.conf文件里面所定义的。 例如:现在需要备份IP为192.168.1.100的客户端下面的/data目录,并使用“root-tar”的转储类型,那么只需要在disklist文件里插入如下即可。

192.168.1.100    /data    root-tar

tapelist文件用来记录当前可用的磁带列表,默认该文件不存在,创建该文件以及修改文件的权限的方法如下:

# > /etc/amanda/DailySet1/tapelist
# chown amanda.disk /etc/amanda/DailySet1/tapelist

注:凡是手工创建或指定给amanda的文件以及目录,包括前面所指定的临时磁盘存放的目录以及日志存放的目录等,其所属用户和组必须是amanda和disk,否则Amanda在备份的时候没有操作权限。 切换至amanda用户,执行amlabel命令设置卷标

# su – amanda
$ /usr/sbin/amlabel DailySet1 DailySet101

所设置的卷标一定要符合“labelstr”所指定的正则表达式,否则会报错。设置好可用卷标的磁带,会自动添加到tapelist列表里。

Amanda目前也可以基于磁盘来做备份,即disk-to-disk方式,也是一个相对比较复杂的方式,下面是一个基于磁盘备份以及恢复的详细过程。

1、客户端配置 在.amandahosts文件中指定备份服务器与用户以及在/etc/hosts文件设置IP与主机名的对应关系,同时在xinetd中启动amanda服务,具体操作见前面的说明。

# vi /var/lib/amanda/.amandahosts
holmes86 amanda
holmes86 root
# vi /etc/hosts
192.168.1.99 holmes86

此后的配置步骤都是在服务端进行。

2、创建虚拟磁带的文件系统 所谓基于磁盘的备份方式,就是在服务器上使用磁盘来作为一个虚拟的磁带机。所以需要准备一块容量较大的分区或磁盘,创建好文件系统后挂载在指定的目录下。

# mount /dev/hda6 /amanda

3、定义虚拟磁带类型 编辑amanda.conf文件,定义一个新的磁带类型,而磁带的大小可以根据自己的需要来设置。一块磁盘可以平均划分多个磁带,考虑到磁盘的性能,建议在使用中始终保留10%的空间。比如一块100G的磁盘,就按90G空间去划分磁带,如果在90G的空间里创建3个虚拟磁带,那每个磁带能够使用的大小就是30G。下面定义了每个虚拟磁带的大小为200M:

define tapetype HARD-DISK {
   comment "disk-to-disk"
   length 200 mbytes
}

4、修改amanda.conf文件 在amanda.conf配置文件中,其它需要修改的参数是:

dumpcycle 2 days     
runspercycle 2
tapecycle 2
tapetype HARD-DISK
labelstr "^DailySet1-[0-9][0-9]*$"
tpchanger "chg-disk"
changerfile "/etc/amanda/DailySet1/changer"
tapedev "file:/amanda/DailySet1"
define dumptype root-tar {
    global
    program "GNUTAR"
    comment "root partitions dumped with tar"
    compress none
    index yes
    priority low
}

其中tapedev中指定的“/amanda/DailySet1”,“DailySet1”是配置文件名,该目录名必须与配置文件名一致。同时一定要在定义转储类型的部分加上“index yes“,否则在恢复的时候将不能找到可恢复的索引信息。

5、创建虚拟磁带 虚拟磁带的目录结构如下:

slot_root_dir -|
               |- info
               |- data -> slot1/
               |- slot1/
               |- slot2/
               |- ...
               |- slotn/

slot_root_dir是tapedev所指定的路径,而slotn中的n的值应和tapecycle的值一致。如下:

# mkdir /amanda/DailySet1
# cd /amanda/DailySet1/
# mkdir slot1 slot2
# touch info
# ln -s slot1 data
# chown -R amanda.disk /amanda

6、修改disklist文件 编辑disklist文件,增加需要备份的项,如下:

192.168.1.100 /data comp-root-tar

7、创建disklist文件

# > /etc/amanda/DailySet1/tapelist
# chown amanda.disk /etc/amanda/DailySet1/tapelist

8、制作虚拟磁盘卷标 与使用磁带机一样,使用前也需要为虚拟磁盘创建卷标,如下:

# su - amanda
$ /usr/sbin/amlabel DailySet1 DailySet1-01 slot 1
$ /usr/sbin/amlabel DailySet1 DailySet1-02 slot 2

9、检查配置 Amanda自带了一个检测配置文件的工具,用于检测整个Amanda服务端与客户端的配置情况。如下:

$ /usr/sbin/amcheck DailySet1
Amanda Tape Server Host Check
-----------------------------
Holding disk /amanda: 419077 KB disk space available, using 316677 KB
slot 1: read label `DailySet1-01', date `X'

NOTE: skipping tape-writable test
Tape DailySet1-01 label ok
Server check took 0.151 seconds

Amanda Backup Client Hosts Check
--------------------------------
Client check: 1 host checked in 0.100 seconds, 0 problems found

(brought to you by Amanda 2.5.0p2)

10、备份 在前面的Amanda组件中提到过,备份数据使用的程序是amdump,通常情况下放在cron里去自动执行,amdump在备份时不会提示任何的信息,可以通过查看日志文件来检查备份是否成功。

$ /usr/sbin/amdump DailySet1

11、恢复 Amanda提供了交互式的amrecover工具来从Amanda的备份中恢复文件,它需要备份集设置了索引,也就是使用了“index yes”的设置,同时在服务端需要启动amandaidx与amidxtape进程,这两个进程也是由xinetd来管理的。在客户端恢复数据的时候必须使用root用户来运行。恢复前首先要切换到需要恢复的当前目录下,Amrecover工具的使用方法如下: # amrecover DarilySet1 -s serverhost -t serverhost 上面命令中的-s 参数表示指定存放备份集索引的服务器,-t则用于指定磁带机所在的服务器。连接成功后将会停在一个交互式的对话框下,下面是一个详细的恢复过程。

#cd /data
# amrecover  DailySet1 -s holmes86 -t holmes86
AMRECOVER Version 2.5.0p2. Contacting server on holmes86 ...
220 holmes86 AMANDA index server (2.5.0p2) ready.
200 Access OK
Setting restore date to today (2007-08-05)
200 Working date set to 2007-08-05.
Scanning /amanda...
  DailySet1: skipping cruft directory, perhaps you should delete it.
200 Config set to DailySet1.
200 Dump host set to holmes86.
Trying disk /data ...
$CWD '/data' is on disk '/data' mounted at '/data'.
200 Disk set to /data.
/data
amrecover> ls        浏览备份的数据
2007-08-05 sbin/
2007-08-05 lost+found/
2007-08-05 boot/
2007-08-05 bin/
2007-08-05 .
amrecover> add bin    增加一个恢复的列表
Added dir /bin at date 2007-08-05
amrecover> extract    执行恢复

Extracting files using tape drive null: on host holmes86.
The following tapes are needed: DailySet1-02

Restoring files into directory /data
Continue [?/Y/n]? y

Extracting files using tape drive null: on host holmes86.
Load tape DailySet1-02 now
Continue [?/Y/n/s/t]? y
./bin/
./bin/alsacard
............
./bin/zsh
amrecover> quit
200 Good bye.
阅读(327) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~