您好,欢迎访问一九零五行业门户网

在Linux异构网络中备份MYSQL数据库(图)_MySQL

笔者是一个中小linux网站的管理员,系统构架是:rhel 4.0 + php 4.3 + mysql 4.03 +apache 1.23。日均ip访问量在200次,一个典型的linux小型网站。由于是小型网站,所以没有经费使用磁带机进行系统备份,使用的dvd光盘刻录机+网络硬盘。随着linux的应用日益广泛,特别是在网络应用方面,有大量的网络服务器使用linux操作系统。由于linux的桌面应用和windows相比还有一定的差距,所以在企业应用中往往是linux和windows操作系统共存形成异构网络。在服务器端大多使用linux和unix的,pc端使用windows 9x/2000/xp。下面我们就讲讲在linux异构网络备份mysql。
一、 本地备份
mysql数据库的常用备份方法是使用使用实用程序mysqldump, 其命令格式如下:
# mysqldump [options] database [tables]
其参数的含义为:
options:代表mysqldump的选项,通过mysqldump –help可以查到。
database: 代表将要备份的数据库
tables:  代表将要备份的表,如果不指定任何表,则备份整个数据库。
使用 mysqldump进行备份非常简单,如果要备份数据库” phpbb_db_backup ”,使用命令:
#mysqldump –u -p phpbb_db_backup > /usr/backups/mysql/ phpbb_db_backup.2005.5.6
还可以使用gzip命令对备份文件进行压缩:
#mysqldump phpbb_db_backup | gzip > /usr/backups/mysql/ phpbb_db_backup.2005.5.6。gz
恢复数据使用命令:
#mysql –u -p phpbb_db_backup
二、 备份数据到dvd盘片
随着mysql数据量的增大,使用传统cd—r来备份硬盘并不现实,采用cd—rw分卷制作实在太麻烦、磁带机对于中小企业又过于昂贵。另外各个应用程序的复杂度日与剧增, 处理的数据量也都相当庞大,linux用户常常遇到的问题就是 : 有什么办法可以经济快捷的对数据做备份与保存。随着dvd刻录机和盘片的价格迅速降低,使用dvd刻录机用来备份linux操作系统非常明智的。
1、安装
下面以ide接口的内置刻录设备为例,介绍在linux环境中使用dvd刻录机。linux 需要将ide接口的刻录设备虚拟为scsi设备才能进行dvd刻录。2.4以上内核linux发行版本包含了已编译进内核的 scsi 仿真,所以只要对启动文件作一些小改动;usb或1394(firewire)接口的外置刻录机就简单多了。
把dvd刻录机设备接入计算机第二个ide接口(dev/hdc),开启电源。假设系统用grub启动,用文本编辑器打开/boot/grub/grub.conf,找到以“kernel”开头的一行,在这行内容的未尾加入“hdc=ide-scsi”,例如:“kernel /vmlinuz-2.4.20-8 ro root=label=/ hdc=ide-scsi”。
2、安装刻录软件
dvd+rw-tools :一个包含有用于刻录dvd和映像的软件工具包,包括:growisofs和dvd+rw-format。官方站点:http://fy.chalmers.se/~appro/linux/dvd+rw/,
cdrdao :dao即是disk-at-once(实时刻录),是一种在烧录过程中没有音轨间的两秒缓冲的刻录方法。它可以对磁盘的布局和磁道进行完全的控制,这一功能在刻录多来源的盘片相当有帮助。
cdrtools:包含了一套用于cd、dvd刻录的工具。growisofs在创建映像时会使用这个软件包中的mkisofs工具,并且用户可以使用readcd来从一个现有的dvd上创建iso映像。此外,cdrecord应用程序可被用于扫描连接系统上的cd/dvd刻录机,并且可以使用它来将iso映像刻录到cd—r(w)光盘上。通常大多数linux版本包括这个软件,也可以下载使用:http://freshmeat.net/redir/cdrecord/35795/url_homepage/cdrecord.html
dvdrecord:命令行下的dvd刻录软件。命令行下的dvd刻录可用于很多种情形,比如当我们通过远程访问主机时,机器上的图形界面无法启动时,或者机器由于某些原因无法启动gui时。此外,在完成一些备份等自动重复的功能时,也需要使用命令行工具。
以上介绍了一下必须的软件和相关下载网址,安装过程比较简单,这里就不赘述了。
3、命令行下刻录
使用dvd+rw-tools 进行刻录工作
growisofs是dvd+rw-tools一个工具,growlsofs访问其刻录设备使用的是一种不同的方式。它使用/dev下面的unix路径来连接刻录机。不同的系统和发行版中用于刻录机的路径不尽相同,所以最好的方法是查看发行版中的帮助。在一些系统中,一个名为/dev/dvd的软链接会被设置成指向可用的dvd刻录机,在本文中,使用/dev/dvd来指定刻录机,如果系统中路径设置不同,那么请使用合适的路径将其取代。
(1)格式化可读写dvd光盘
可以使用dvd+rw-tools工具包中提供的dvd十rw—format命令。它有两种格式化dvd光盘的方式:快速模式、完全模式。快速模式:
#dvd+rw-format -blank /dev/dvd
完全模式:
#dvd+rw-format -blank=full /dev/dvd
(2)将文件存储至dvd刻录盘:
dvd和普通的光盘一样,使用的也是iso9660文件系统,以及同样的通用扩展(joliet和rockridge)。growlsofs提供了一种简单的将文件或目录存储至dvd刻录盘的方法。先用调用mkisofs工具来创建一个映像,并且无需在将该映像存储至硬盘之前就刻录下来。其基本的命令格式如下:
#growisofs -dvd-compat -z /dev/dvd -j -r /path/to/home/cao
此命令将/path/to/home/cao目录下的文件制作一个映像并且刻录到的dvd光盘。
二、网络备份
将mysql数据放在一台计算机上是不安全的,所以应当把数据备份到局域网中其他计算机中。假设mysql服务器ip地址是:192.168.1.3。局域网使用linux的远程计算机ip地址是192.168.1.17;局域网使用windows的远程计算机ip地址是192.168.1.18。网络拓扑见图1.
1. 通过nfs网络备份
类似于windows的网络共享,unix(linux)系统也有自己的网络共享,那就是nfs(网络文件系统),在linux客户端挂接(mount)nfs磁盘共享之前,必须先配置好nfs服务端。linux系统nfs服务端配置方法如下:
(1)修改 /etc/exports,增加共享目录
/export/home/sunky 192.168.1.17(rw)
/export/home/sunky1 *(rw)
/export/home/sunky2 linux-client(rw)
注:/export/home/目录下的sunky、sunky1、sunky2是准备共享的目录,10.140.133.23、*、linux-client是被允许挂接此共享linux客户机的ip地址或主机名。如果要使用主机名linux-client必须在服务端主机/etc/hosts文件里增加linux-client主机ip定义。格式如下:
192.168.1.17 linux-client
若修改/etc/export文件增加新的共享,应先停止nfs服务,再启动nfs服务方能使新增加的共享起作用。使用命令exportfs -rv也可以达到同样的效果。linux客户端挂接(mount)其他linux系统或unix系统的nfs共享。这里我们假设192.168.1.17是nfs服务端的主机ip地址,当然这里也可以使用主机名,但必须在本机/etc/hosts文件里增加服务端ip定义。/export/home/sunky为服务端共享的目录。如此就可以在linux客户端通过/mnt/nfs来访问其它linux系统或unix系统以nfs方式共享出来的文件了。
把mysql数据备份到使用linux的远程计算机需要在两端都安装nfs协议(networkfile system),远程nfs计算机安装nfs协议后还要修改配置文件:/etc/exports,加入一行:
/usr/backups/mysql/ 192.168.1.17 (rw, no_root_squash)
表示将/usr/backups/mysql/目录共享。这个目录具有远程root用户读写权限。保存nfs配置文件,然后使用命令:
#exportfs -a –r
然后重新启动nfs服务:
#service nfsd start
远程计算机设定后,在mysql服务器/mnt 目录下建立一个backup_share目录:
#mkdir /mnt/backup_share
将远程的linux计算机的/usr/backups/mysql/目录挂载到mysql服务器的/mnt/backup_share目录下:
# mount -t nfs 192.168.1.17:/usr/backups/mysql /mnt/backup_share
将目录挂载进来后,只要进入/mnt/backup_share 目录,就等于到了ip地址:192.168.1.7那部nfs计算机的/usr/backups/mysql目录中。下面使用mysqldump把“phpbb_db_backup”备份到远程计算机:
# mysqldump phpbb_db_backup > /mnt/backup_share/ phpbb_db_backup.2005-5-6
2. 通过samba网络备份
windows网络共享的核心是smb/cifs,在linux下要挂接(mount)windows的磁盘共享,就必须安装和使用samba软件包。现在流行的linux发行版绝大多数已经包含了samba软件包,如果安装linux系统时未安装samba请首先安装samba。当然也可以到www.samba.org网站下载samba软件包,现在最新的版本是3.0.10版。然后windows计算机上建立一个目录(/arc)并且共享,赋予其读写权限。同样在mysql服务器/mnt 目录下建立一个backup_share1目录,然后进行挂载:
# mount -t smbfs -o username=cjh, password=xxxx //192.168.1.18/arc /mnt/backup_share
最后使用命令进行备份:
# mysqldump phpbb_db_backup > /mnt/backup_share/ phpbb_db_backup.2005-5-6
mysql是一个功能强大的数据库,需要在实践中多练习才能熟练掌握,本文介绍mysql的网络备份方法。希望对大家有所帮助。
其它类似信息

推荐信息