Linux:从命令行备份 MySQL 数据库
ahcoder 2025-06-18 10:31 2 浏览
为您的数据库创建可靠的备份系统可以让您高枕无忧,而且使用 MySQL 和 Linux 可以轻松实现。
如果您的网站、应用程序或业务依赖于数据库 ,您必须采取的一个非常重要的步骤是备份该数据 。如果没有可靠的备份,您可能会发现自己陷入了数据损坏的困境,并且无法更换它。
幸运的是,备份 MySQL 数据库并不像您想象的那么难,而且所需的工具都是内置的。
想象一下,登录该应用程序或站点并看到与数据库的连接失败或(更糟糕的)数据损坏。或者,也许您需要将数据库迁移到新服务器,而不会丢失一丝信息。
这很重要,这是您需要了解的一项技能。
这就是我在这里的原因:向您展示如何备份该 MySQL 数据库。
您准备好了吗?
让我们来获取 database-y。
您需要什么
在本教程中,您需要备份一个 MySQL 数据库和一个具有管理员权限的用户。我将在 Ubuntu 服务器上演示该过程,因此相关用户需要具有 sudo 权限 。我还将向您展示如何备份 MariaDB 数据库 。
备份 MySQL 数据库
在运行备份之前,您需要知道数据库的确切名称。为此,请首先使用以下命令访问 MySQL 控制台:
进入控制台后,使用以下命令列出您的数据库:
sudo mysql -u root -p
您应该会在列表中看到要备份的数据库。假设数据库名为 newstack。让我们来支持这一点。
SHOW DATABASES;
使用以下命令退出 MySQL 控制台:
EXIT;
您现在可以使用 mysqldump 命令备份数据库,如下所示:
上面的命令会将 newstack 的内容转储到 newstack-backup.sql 中。
恢复该备份
假设您已迁移到新服务器并希望恢复 newstack 数据库。为此,请登录新服务器(正确安装和设置 MySQL)并发出命令:
现在应该可以在 newstack 数据库中找到 newstack-backup.sql 中的数据。
如何自动备份
您不想记住手动备份数据库,因此让我们在 cron 的帮助下自动实现这一点。
我们将备份设置为每天凌晨 1 点运行。为此,请使用以下命令打开 crontab 文件进行编辑:
crontab -e
在该文件的底部,我们将添加以下行:
- PASSWORD 是您的 MySQL root 用户密码。
- USER 是您在本地 Linux 系统上的用户名。
保存并关闭文件。现在,您的 MySQL 数据库将在每天凌晨 1 点备份到 /home/USER 目录中。您可以修改上述命令以将备份转储到您选择的任何目录中。
要记住的一件事是 crontab 条目每晚都会覆盖备份,因此您可以创建另一个 crontab 作业,然后移动和重命名数据库文件。这样的 crontab 条目可能看起来像这样:
这会将文件从 newstack-backup.sql 重命名为
newstack-backup-YYYYMMDD.sql(其中 YYYY 是年份,MM 是月份,DD 是日期)。
如何备份 MariaDB 数据库
作为 MySQL 的衍生产品,MariaDB 有一个名为 mariadb-dump 的内置备份工具,它也非常易于使用。假设我们要备份一个同名的数据库。为此,您需要一个对要备份的数据库具有权限的 MariaDB 用户。
有了这个,你可以像这样备份 newstack 数据库:
- PASSWORD 是 MariaDB 管理员用户密码。
- USER 是您的 Linux 用户名。
然后,您可以像这样恢复备份:
如何自动化 MariaDB 备份
此作的处理方式与 MySQL 备份的处理方式相同。使用以下命令打开 crontab 文件进行编辑:
crontab -e
如果您希望 MariaDB 备份在凌晨 1 点运行,则条目将如下所示:
- PASSWORD 是您的 MariaDB root 用户密码。
- USER 是您在本地 Linux 系统上的用户名。
然后,您可以创建另一个 cron 作业,以与上面对 MySQL 相同的方式移动和重命名备份文件。
为您的数据库创建可靠的备份系统与创建标准数据备份一样重要。尽管您可能认为简单地依赖常规备份过程来包含数据库很容易,但使用上面显示的方法可以确保数据不仅得到备份,而且能够轻松恢复。这种内心的平静无与伦比。
相关推荐
- Java程序员必备的Linux命令速查表
-
Java程序员必备的Linux命令速查表在Java开发的世界里,Linux就像一位默默支持的幕后英雄。作为一名Java开发者,掌握一些基本的Linux命令,不仅能提高工作效率,还能让你在团队中显得格外...
- Linux 命令速查手册:这 30 个高频指令,拯救 90% 的运维小白!
-
在Linux系统的世界里,命令行是强大的武器。对于运维小白而言,掌握一些高频使用的Linux命令,能极大提升工作效率,轻松应对各种系统管理任务。今天,就为大家奉上精心整理的30个Linu...
- linux磁盘管理相关命令(linux磁盘管理常用命令)
-
磁盘的使用情况会直接影响系统的性能,因此我们经常会用到以下命令,主要围绕:fdisk:磁盘分区df:文件系统的磁盘空间占用情况du:文件目录的磁盘空间占用情况查看磁盘关系lsblk查看磁盘分区情况fd...
- 第四章 Linux常用shell命令-4.5.磁盘管理
-
主要介绍一下跟磁盘管理相关命令,有比较多的内容摘抄自网络,如有侵权,请及时联系我删除:显示目前在Linux系统上的文件系统磁盘使用情况统计:df创建和维护分区表的程序:fdisk将磁盘分区或镜像挂...
- Linux新手必备:20个高效命令轻松掌握!
-
Linux基本命令使用指南在现代计算机操作系统中,Linux因其开放性、灵活性和强大的功能,广泛应用于服务器和开发环境中。作为技术人员,掌握Linux的基本命令是非常重要的。在本文中,我们将重点介绍2...
- 每日必学Linux命令:ls命令(linux命令详解之ls命令)
-
ls命令是linux下最常用的命令。ls命令就是list的缩写缺省下ls用来打印出当前目录的清单如果ls指定其他目录那么就会显示指定目录里的文件及文件夹清单。通过ls命令不仅可以查看linux文件...
- Linux系统dev和proc目录详解(linux dev/sr0)
-
简介:Linux系统里的/dev和/proc目录那可是相当重要的系统文件。在Linux系统中,/dev目录专门用来存放设备文件。不光有设备文件,系统里还有好多特殊功能也是通过设备的形式...
- Linux切换目录之cd命令(linux切换指定目录)
-
1.基本概念1.1命令作用当我们在Linux系统上工作时,做得相当多的一项任务就是在不同的目录之间进行切换,这时就需要用到cd命令了。cd是"changedirectory"的首...
- Linux切换目录(cd命令)(linux如何切换到目录)
-
cd命令,是ChangeDirectory的缩写,用来切换工作目录。Linux命令按照来源方式,可分为两种,分别是Shell内置命令和外部命令。所谓Shell内置命令,就是Shel...
- MongoDB数据库的快速部署和启动(mongodb的使用教程)
-
一、Mongodb介绍常见数据库介绍关系数据库RDBMS设计表结构,通过SQL语句进行操作。连表关系常见的关系型数据库:mysqloracle(商业)DB2(IBM)sqlserver(微软...
- 5分钟学会网络服务搭建,飞凌i.MX9352 + Linux 6.1实战示例
-
在“万物互联”的技术浪潮下,网络服务已成为连接物理世界与数字世界的核心纽带,它不仅赋予了终端设备“开口说话”的能力,更构建了智能设备的开发范式。本文就将以飞凌嵌入式OK-MX9352-C开发板(搭载了...
- centos安装geoserver并配置开机启动
-
前提条件:服务器已经安装了java环境一、下载下载地址:http://geoserver.org/release/maintain/下载后文件名为:geoserver-2.19.3-bin.zip二、...
- 开机启动流程(开机流程图)
-
grubandbootCentos5,6的开机启动流程grubCentos7的开机启动流程Centos5,6的开机启动流程initrd/initramfs一般存储在/boot目录下,以.img...
- Linux cron服务概述(crontab服务)
-
cron是Linux/Unix系统中一个非常重要的后台服务(守护进程),用于在预定的时间间隔自动执行命令或脚本。它使得自动化重复性任务成为可能,例如日志清理、数据备份、系统维护等。1.cron...
- CentOS 8利用rc.local进行开机自启动的配置
-
CentOS8利用rc.local进行开机自启动的配置CentOS8linux系统是不建议使用rc.local进行开机自启动的,建议创建systemdservice。我们为了方便以后多一个配置...
- 一周热门
- 最近发表
- 标签列表
-
- linux 远程 (37)
- u盘 linux (32)
- linux 登录 (34)
- linux 路径 (33)
- linux 文件命令 (35)
- linux 是什么 (35)
- linux 界面 (34)
- 查看文件 linux (35)
- linux 语言 (33)
- linux代码 (32)
- linux 查看命令 (33)
- 关闭linux (34)
- root linux (33)
- 删除文件 linux (35)
- linux 主机 (34)
- linux与 (33)
- linux 函数 (35)
- linux .ssh (35)
- cpu linux (35)
- 查看linux 系统 (32)
- linux 防火墙 (33)
- linux 手机 (32)
- linux 镜像 (34)
- linux ip地址 (34)
- linux 用户查看 (33)