全量备份

Linux环境

数据备份

数据库的备份与恢复有多中方法,通过mysql自带的mysqldump工具可对数据库进行备份。语法:

mysqldump -u username -p password --databases db_name > file_name .sql

说明:

-u参数指定用户名,username 填入用户名;

-p参数指定用户密码,password 填入用户密码;

–databases参数指定要导出的数据库,可以是一个或者多个,多个数据库用空格分开,db_name填入要备份的数据库;

file_name填入导出的文件名称,可以是文件的绝对路径,文件的格式可以.db文件或者.sql文件。

mysqldump 并不是在mysql命令行中运行,是一个可执行文件,安装mysql后在安装目录下会有该工具。以linux为例,比如mysqldump 工具在/usr/bin路径下。导出某个数据库:

[root@201 mysqlback]# /usr/bin/mysqldump -u root -p123456 --databases mysql_test > /share/mysql_test.db

导出所有数据库使用–all-databases参数

[root@201 mysqlback]# /usr/bin/mysqldump -u root -p 123456 --all-databases > /share/all.db

数据恢复

数据库的恢复可以使用source命令执行,进入mysql的命令行,执行以下命名。

mysql> source /share/mysql_test.sql;
query ok, 0 rows affected (0.06 sec)

windows环境

cmd命令行备份

语法同上,比如把temp数据库备份到 d:\temp.bak

mysqldump –u root –p123456 temp > d:\temp.bak

如果你希望备份是数据库的某几张表,可以在数据库后面加要备份的表名称,比如:

mysqldump –u root –p123456 temp dept > d:\temp.dept.bak

数据恢复

进入mysql控制台,使用source命令备份文件恢复我们的数据,比如:

mysql>source d:\temp.dept.bak

定时备份

把备份数据库的指令,写入到 bat文件, 然后通过任务管理器去定时调用 bat文件执行备份,比如新建一个bakTask.bat,里面写入mysql的备份命令:

F:\MySQL\bin\mysqldump -u root -p123456 temp dept > d:\temp.dept.bak

如果你的mysqldump.exe文件路径有空格,则一定要使用双引号 “ ” 包裹。把bakTask.bat做成一个任务,并设置每天定时调用。具体步骤如下:

(1) windows搜索“任务计划程序”,打开windows的任务计划程序。
在这里插入图片描述

(2)选中任务计划程序库,右键创建基本任务,输入任务名称,选择触发时间,最后选中bakTask.bat文件,下一步完成任务计划程序的创建。
在这里插入图片描述

增量备份

一个完整的备份方案应当包含全量备份与增量备份,下面以windows环境为例,讲解mysql的增量备份。当启用增量备份之后,mysql会以二进制的形式把用户对数据库的操作记录到文件中。需要注意的是,增量备份并不会记录所有的数据库操作。通常对ddl语句 (create alter drop),dml语句 (insert update delete),dcl语句(grant revoke set commit rollback)进行记录,而不会记录dql语句(select),因为数据查询语句并不会影响数据的完整性。增量备份通常会记录数据库操作语句、操作时间、操作位置等内容。

启用增量备份

在进行增量备份之前需要查看一下mysql 是否开启log_bin

mysql> show variables like '%log_bin%';+---------------------------------+-------+| Variable_name          | Value |+---------------------------------+-------+| log_bin             | OFF  || log_bin_basename         |    || log_bin_index          |    || log_bin_trust_function_creators | OFF  || log_bin_use_v1_row_events    | OFF  || sql_log_bin           | ON   |+---------------------------------+-------+

log_bin为off说明还没有开启log_bin。找到mysql安装目录下的my.ini或者my.conf文件,启用log_bin二进制备份,在[mysqld]下新增以下配置

[mysqld]#启用增量备份,双引号及双反斜杠log-bin=log-bin=F:\\MySQLbinlog\\log-binserver-id=1

重启mysql服务后生效,对数据库进行操作时将会生成log-bin.000001、log-bin.index文件。log-bin.000001文件写满后继续生成log-bin.000002文件,以此类推,是数据库操作日志文件。log-bin.index记录着操作日志文件的路径。

log-bin操作日志文件用文本编辑器是无法查看的,需要用mysql自带的工具进行查看。

F:\MySQL\bin>mysqlbinlog.exe F:\MySQLbinlog\log-bin.000001
mysqlbinlog: [ERROR] unknown variable 'default-character-set=utf8'

在使用mysqlbinlog工具查看时可能会报unknown variable 'default-character-set=utf8’的错误,可以使用以下命令查看

>mysqlbinlog.exe --no-defaults --base64-output=decode F:\MySQLbinlog\log-bin.000001
>mysqlbinlog.exe F:\MySQLbinlog\log-bin.000002 > tmp.sql

在这里插入图片描述

关于增量备份的恢复我们放到下一篇讲。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/92759.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/92759.shtml
英文地址,请注明出处:http://en.pswp.cn/web/92759.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用Windbg分析多线程死锁项目实战问题分享

目录 1、问题描述 2、使用.effmach x86命令切换到32位上下文 3、切换到UI线程,发现UI线程死锁了 4、使用!locks命令查看临界区锁的详细信息,遇到了问题 5、使用dt命令查看临界区对象信息,找到发生死锁的多个线程 6、用户态锁与内核态锁…

防火墙组网方式总结

一、部署模式:灵活适配多样网络环境下一代防火墙(NGAF)具备极强的网络适应能力,支持五种核心部署模式,可根据不同网络需求灵活选择。路由模式:防火墙相当于路由器,位于内外网之间负责路由寻址&a…

AI大模型:(二)5.1 文生视频(Text-to-Video)模型发展史

目录 1.介绍 2.发展历史 2.1.早期探索阶段(2015-2019) 2.1.1.技术萌芽期 2.1.2.RNN/LSTM时代 2.2.技术突破期(2020-2021) 2.2.1 Transformer引入视频生成 2.2.2 扩散模型的兴起 2.3.商业化突破期(2022-2023) 2.3.1 产品化里程碑 2.3.2 竞争格局形成 2.4.革命…

14mm寻北仪能否塞进液压支架生死缝隙?

在煤矿井下世界的方寸之间,液压支架的每个关键节点都承载着千钧重压。顶梁铰接点、立柱顶端、掩护梁角落,恰恰是空间最为局促的“禁区”。ER-MNS-10A MEMS寻北仪应运而生!它采用了先进的MEMS陀螺技术,以14mm至薄高度、40g极致轻盈…

python之浅拷贝深拷贝

文章目录潜拷贝(shallow copy)深拷贝(deep copy)总结一下python的浅拷贝和深拷贝.潜拷贝(shallow copy) python中潜拷贝指的是:构造一个新的复合对象,然后将原对象中的对象引用插入其中 平常开发过程中潜拷贝是比深拷贝更常见的场景. 比如编程中使用到的一些基本的…

普通大学本科生如何入门强化学习?

问题:你平时是如何紧跟大型语言模型和智能体技术前沿的?有哪些具体的学习和跟踪方式?回答:我会通过“输入-内化-实践”结合的方式跟踪前沿。首先,学术动态方面,每天花10分钟浏览arXiv的http://cs.CL和http://cs.AI板块&#xff0c…

新手向:Python实现数据可视化图表生成

Python数据可视化入门:从零开始生成图表数据可视化是数据分析过程中不可或缺的关键环节,它通过将抽象的数字信息转化为直观的图形展示,帮助分析师和决策者更快速、更准确地发现数据中隐藏的模式、规律和发展趋势。在当今大数据时代&#xff0…

VBA即用型代码手册:计算选择的单词数Count Words in Selection

我给VBA下的定义:VBA是个人小型自动化处理的有效工具。可以大大提高自己的劳动效率,而且可以提高数据的准确性。我这里专注VBA,将我多年的经验汇集在VBA系列九套教程中。作为我的学员要利用我的积木编程思想,积木编程最重要的是积木如何搭建及…

DNS(域名系统)

分层结构根域名(ipv4,13台),二级域名,三级域名……相关记录A将域名解析为ipv4地址AAAA将域名解析为ipv6地址MX指名该区域为邮件服务区PTR反向查询将主机名解析为域名NS记录服务器的名字CNAME别名查询方式递归查询迭代查…

【大模型】强化学习算法总结

角色和术语定义 State:状态Action:动作Policy/actor model:策略模型,用于决策行动的主要模型Critic/value model:价值模型,用于评判某个行动的价值大小Reward model:奖励模型,用于给…

基于梅特卡夫定律的开源链动2+1模式AI智能名片S2B2C商城小程序价值重构研究

摘要:梅特卡夫定律揭示了网络价值与用户数量的平方关系,在互联网经济中,连接的深度与形式正因人的参与发生质变。本文以开源链动21模式、AI智能名片与S2B2C商城小程序的协同应用为研究对象,通过实证分析其在社群团购、下沉市场等场…

Ubuntu22.04安装CH340驱动及串口

一、CH340驱动安装 1.1 查看USB设备能否被识别 CtrlAltT打开终端: lsusb 插入设备前: 插入设备后: 输出中包含ID 1a86:7523 QinHeng Electronics CH340 serial converter的信息,这表明CH340设备已经被系统识别。 1.2 查看USB转串…

CPU缓存(CPU Cache)和TLB(Translation Lookaside Buffer)缓存现代计算机体系结构中用于提高性能的关键技术

CPU缓存(CPU Cache)和TLB(Translation Lookaside Buffer)缓存是现代计算机体系结构中用于提高性能的关键技术。它们通过减少CPU访问数据和指令的延迟来提高系统的整体效率。以下是对这两者的详细解释: 1. CPU 缓存 CPU…

唐扬·高并发系统设计40问

课程下载:https://download.csdn.net/download/m0_66047725/91644703 00开篇词 _ 为什么你要学习高并发系统设计?.pdf 00开篇词丨为什么你要学习高并发系统设计?.mp3 01 _ 高并发系统:它的通用设计方法是什么?.pdf …

基于Spring Data Elasticsearch的分布式全文检索与集群性能优化实践指南

基于Spring Data Elasticsearch的分布式全文检索与集群性能优化实践指南 技术背景与应用场景 随着大数据时代的到来,海量信息的存储与检索成为各类应用的核心需求。Elasticsearch 作为一款分布式搜索引擎,凭借其高可扩展、高可用和实时检索的优势&#x…

Linux系统编程——基础IO

一些前置知识:文件 属性 内容文件 分为 打开的文件、未打开的文件打开的文件:由进程打开,本质是 进程与文件 的关系;维护的文件对象先加载文件属性,文件内容一般按需加载未打开的文件:在永久性存储介质 —…

力扣164:最大间距

力扣164:最大间距题目思路代码题目 给定一个无序的数组 nums,返回 数组在排序之后,相邻元素之间最大的差值 。如果数组元素个数小于 2,则返回 0 。 您必须编写一个在「线性时间」内运行并使用「线性额外空间」的算法。 思路 这道题的思路…

Redis类型之Hash

1.hash常用操作 这里还是要强调,redis的类型指的是value的类型。故而这里的hash是把key这一层组织完成以后,到了value这一层,value的其中一种类型还可以是hash。1.1 HSET 和 HGETHSET:设置hash类型的keyHSET key field value [fie…

Apache Pulsar性能与可用性优化实践指南

Apache Pulsar性能与可用性优化实践指南 一、技术背景与应用场景 随着微服务、实时计算和大数据平台的普及,消息系统承担了海量数据的传输与解耦任务。Apache Pulsar作为新一代分布式消息与流处理系统,拥有多租户、持久化存储和灵活一致性的特点&#xf…

工单分类微调训练运维管理工具原型

简述需求进展之前,我尝试用Longformer模型来训练工单分类系统,但问题很快就暴露出来:Longformer训练时间长得让人抓狂,每次训练只能针对一个租户的数据,无法快速适配多个租户的需求。切换一个使用相同标签的租户还能够…