共计 2008 个字符,预计需要花费 6 分钟才能阅读完成。
我们现在将讨论如何备份数据库和还原 MySQL。数据库的维护非常重要,因为数据库包含我们拥有的重要数据,因此,应备份数据库以避免数据丢失。
备份有两个目的。主要目的是在数据丢失(由于删除或损坏)时恢复数据。第二个目标是将数据还原到过去的某个点。由于其功能,备份过程要求用户复制数据,这最终会消耗存储介质的容量。这鼓励发现简化备份数据存储的技术,例如重复数据删除和压缩。
在本文中,我们将讨论如何轻松地进行备份和恢复数据库,特别是通过 CLI(命令行界面)与 MySQL 系统的数据库。
如果用户名需要密码,则需要在此命令执行后输入一次密码核对;如果数据库用户名不需要密码,则不要加“-p”参数,导入的时候相同。注意输入的用户名需要拥有对应数据库的操作权限,否则无法导出数据。由于是作系统维护和全部数据库的导出,一般我们使用 root 等超级用户权限。
如何备份数据库和还原 MySQL
备份和还原 MySQL 数据库的步骤如下:
如何使用 CLI 备份数据库
使用 MySQL 提供的 mysqldump 工具,备份或导出 MySQL 数据库非常容易。
mysqldump -u[uname] -p[pass] [dbname] > [backupfile].sql
- [uname] – 是有权访问数据库的用户的名称;
- [pass] – 用户密码;
- [dbname] – 是要备份或导出的数据库的名称;
- [backupfile] – 是备份文件的名称。
我们将提供一个示例数据库配置,比如要将 linuxidc 这个数据库导出为一个文件名为 linuxidc-back.sql 的数据库文件到当前目录下,则输入下面的命令:
[linuxidc@localhost ~/www.linuxidc.com]$mysqldump -uroot -pv linuxidc > linuxidc-back.sql
用户名:root 密码:v 数据库名:linuxidc 备份的数据库为:linuxidc-back.sql
需要注意的地方是:- u 和 - p 后面直接跟用户名和密码,不要有空格。
如何使用 CLI 还原数据库
恢复或导入我们先前备份的 MySQL 数据库文件的另一种方法是使用 mysql 就像备份或导出数据库一样简单。
mysql -u[uname] -p[pass] [dbname] < [backupfile].sql
- [uname] – 是有权访问数据库的用户名;
- [pass] – 用户密码;
- [dbname] – 是要还原或导入的数据库的名称;
- [backupfile] – 是还原文件的名称。
我们将给出一个数据库还原示例,如下所示:
[linuxidc@localhost ~/www.linuxidc.com]$mysqldump -uroot -pv linuxidc < linuxidc-back.sql
其他命令参考:
备份远程 MySQL 数据库的命令
mysqldump -hhostname -uusername -ppassword databasename > backupfile.sql
备份 MySQL 数据库为带删除表的格式备份 MySQL 数据库为带删除表的格式,能够让该备份覆盖已有数据库而不需要手动删除原有数据库。
mysqldump —add-drop-table -uusername -ppassword databasename > backupfile.sql
直接将 MySQL 数据库压缩备份
mysqldump -hhostname -uusername -ppassword databasename | gzip > backupfile.sql.gz
备份 MySQL 数据库某个 (些) 表
mysqldump -hhostname -uusername -ppassword databasename specific_table1 specific_table2 > backupfile.sql
同时备份多个 MySQL 数据库
mysqldump -hhostname -uusername -ppassword –databases databasename1 databasename2 databasename3 > multibackupfile.sql
仅仅备份数据库结构
mysqldump –no-data –databases databasename1 databasename2 databasename3 > structurebackupfile.sql
备份服务器上所有数据库
mysqldump –all-databases allbackupfile.sql
还原 MySQL 数据库的命令
mysql -hhostname -uusername -ppassword databasename < backupfile.sql
还原压缩的 MySQL 数据库
gunzip < backupfile.sql.gz | mysql -uusername -ppassword databasename
祝您好运,希望本文对于 Linux 新手有所帮助。
: