Welcome 微信登录

首页 / 数据库 / MySQL / MySQL备份工具之mysqlhotcopy

mysqlhotcopy使用lock tables、flush tables和cp或scp来快速备份数据库.它是备份数据库或单个表最快的途径,完全属于物理备份,但只能用于备份MyISAM存储引擎和运行在数据库目录所在的机器上.与mysqldump备份不同,mysqldump属于逻辑备份,备份时是执行的sql语句.使用mysqlhotcopy命令前需要要安装相应的软件依赖包.1.安装mysqlhotcopy所依赖的软件包(perl-DBD,DBD-mysql)[root@tong2 ~]# yum install perl-DBD* -y[root@tong2 ~]# wget https://cpan.metacpan.org/authors/id/C/CA/CAPTTOFU/DBD-mysql-4.029.tar.gz[root@tong2 ~]# tar xvf DBD-mysql-4.029.tar.gz[root@tong2 ~]# cd DBD-mysql-4.029
[root@tong2 DBD-mysql-4.029]# perl Makefile.PL[root@tong2 DBD-mysql-4.029]# make[root@tong2 DBD-mysql-4.029]# make install[root@tong2 DBD-mysql-4.029]# echo $?
0
[root@tong2 DBD-mysql-4.029]# cd
[root@tong2 ~]# 2.查看mysqlhotcopy的帮助信息[root@tong2 ~]# vim /usr/my.cnf   --在配置文件中添加如下参数[mysqlhotcopy]
interactive-timeout
host=localhost
user=root
password=system
port=3306[root@tong2 ~]# /etc/init.d/mysql restart      --重启服务
Shutting down MySQL.. SUCCESS!
Starting MySQL. SUCCESS![root@tong2 ~]# mysqlhotcopy  --help
Warning: /usr/bin/mysqlhotcopy is deprecated and will be removed in a future version./usr/bin/mysqlhotcopy Ver 1.23Usage: /usr/bin/mysqlhotcopy db_name[./table_regex/] [new_db_name | directory]  -?, --help         display this help-screen and exit
  -u, --user=#       user for database login if not current user
  -p, --password=#   password to use when connecting to server (if not set
                     in my.cnf, which is recommended)
  -h, --host=#       hostname for local server when connecting over TCP/IP
  -P, --port=#       port to use when connecting to local server with TCP/IP
  -S, --socket=#     socket to use when connecting to local server
      --old_server   connect to old MySQL-server (before v5.5) which
                     doesn"t have FLUSH TABLES WITH READ LOCK fully implemented.  --allowold         don"t abort if target dir already exists (rename it _old)   --不覆盖以前备份的文件
  --addtodest          don"t rename target dir if it exists, just add files to it      --属于增量备份
  --keepold            don"t delete previous (now renamed) target when done
  --noindices          don"t include full index files in copy          --不备份索引文件
  --method=#         method for copy (only "cp" currently supported)  -q, --quiet          be silent except for errors
  --debug              enable debug                                          --启用调试输出
  -n, --dryrun       report actions without doing them  --regexp=#         copy all databases with names matching regexp --使用正规表达式
  --suffix=#         suffix for names of copied databases
  --checkpoint=#     insert checkpoint entry into specified db.table    --插入检查点条目
  --flushlog         flush logs once all tables are locked                    --所有表锁定后刷新日志
  --resetmaster        reset the binlog once all tables are locked       --一旦锁表重置binlog文件
  --resetslave       reset the master.info once all tables are locked --一旦锁表重置master.info文件    --tmpdir=#        temporary directory (instead of /tmp)
  --record_log_pos=# record slave and master status in specified db.table
  --chroot=#         base directory of chroot jail in which mysqld operates  Try "perldoc /usr/bin/mysqlhotcopy" for more complete documentation
[root@tong2 ~]# 3.备份一个数据库到一个目录中[root@tong2 ~]# mysqlhotcopy -u root -p system tong /opt/[root@tong2 ~]# ll /opt/tong/
total 112
-rw-rw----. 1 mysql mysql    15 Jan  5 14:35 q.isl
-rw-rw----. 1 mysql mysql  8554 Jan  4 18:03 t.frm
-rw-rw----. 1 mysql mysql 98304 Jan  4 18:03 t.ibd
[root@tong2 ~]# ll /var/lib/mysql/tong
total 112
-rw-rw----. 1 mysql mysql    15 Jan  5 14:35 q.isl
-rw-rw----. 1 mysql mysql  8554 Jan  4 18:03 t.frm
-rw-rw----. 1 mysql mysql 98304 Jan  4 18:03 t.ibd
[root@tong2 ~]# 4.备份多个数据库到一个目录中[root@tong2 ~]# mysqlhotcopy -u root -p system tong mysql /opt/tong[root@tong2 ~]# ll /opt/
total 8
drwxr-x---. 2 mysql mysql 4096 Jan  5 15:29 mysql
drwxr-x---. 2 mysql mysql 4096 Jan  5 15:29 tong[root@tong2 ~]# ll /var/lib/mysql/{mysql,tong} -d
drwxr-xr-x. 2 mysql mysql 4096 Jan  5 15:29 /var/lib/mysql/mysql
drwxr-xr-x. 2 mysql mysql 4096 Jan  5 15:29 /var/lib/mysql/tong
[root@tong2 ~]# 5.备份数据库中某一个表[root@tong2 ~]# mysqlhotcopy -u root -p system mysql./user*/ /opt/[root@tong2 ~]# ll /opt/mysql/
total 20
-rw-r--r--. 1 mysql mysql 10684 Jan  4 16:49 user.frm
-rw-r--r--. 1 mysql mysql 784 Jan  4 16:49 user.MYD
-rw-r--r--. 1 mysql mysql  2048 Jan  4 16:49 user.MYI[root@tong2 ~]# ll /var/lib/mysql/mysql/user.*
-rw-r--r--. 1 mysql mysql 10684 Jan  4 16:49 /var/lib/mysql/mysql/user.frm
-rw-r--r--. 1 mysql mysql 784 Jan  4 16:49 /var/lib/mysql/mysql/user.MYD
-rw-r--r--. 1 mysql mysql  2048 Jan  4 16:49 /var/lib/mysql/mysql/user.MYI
[root@tong2 ~]# 6.恢复数据[root@tong2 ~]# rm -rf /var/lib/mysql/tong
[root@tong2 ~]# mysql -u root -p
Enter password:
Welcome to the MySQL monitor.  Commands end with ; or g.
Your MySQL connection id is 29
Server version: 5.6.21-log MySQL Community Server (GPL)Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved.Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.Type "help;" or "h" for help. Type "c" to clear the current input statement.mysql> show databases;
+--------------------+
| Database         |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| test             |
+--------------------+
4 rows in set (0.00 sec)mysql> exit
Bye[root@tong2 ~]# cp -arp /opt/tong /var/lib/mysql/       --将备份的数据移到mysql数据根目录
[root@tong2 ~]# mysql -u root -p
Enter password:
Welcome to the MySQL monitor.  Commands end with ; or g.
Your MySQL connection id is 30
Server version: 5.6.21-log MySQL Community Server (GPL)Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved.Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.Type "help;" or "h" for help. Type "c" to clear the current input statement.mysql> u tong
Database changed
mysql> show tables;
+----------------+
| Tables_in_tong |
+----------------+
| t              |
+----------------+
2 rows in set (0.00 sec)mysql> exit
Bye[root@tong2 ~]#MySQL备份和恢复具体实施 http://www.linuxidc.com/Linux/2012-12/76257.htmMySQL备份:mylvmbackup介绍与使用 http://www.linuxidc.com/Linux/2013-11/92423.htmLinux下通过mysqldump备份MySQL数据库成sql文件 http://www.linuxidc.com/Linux/2013-02/79793.htmLinux中使用mysqldump对MySQL数据库进行定时备份 http://www.linuxidc.com/Linux/2012-03/56063.htm本文永久更新链接地址