网站设计论文结论/网站内部链接优化方法
文章目录
- 1. MySQL数据损坏类型
- 1.1 物理损坏
- 1.2 逻辑损坏
- 2. DBA运维人员备份/恢复职责
- 2.1 设计备份/容灾策略
- 2.1.1 备份策略
- 2.1.2 容灾策略
- 2.2 定期的备份/容灾检查
- 2.3 定期的故障恢复演练
- 2.4 数据损坏时的快速准确恢复
- 2.5 数据迁移工作
- 3. MySQL常用备份工具
- 3.1 逻辑备份方式
- 3.2 物理备份方式
- 3.3 架构备份方式
- 4. mysqldump应用
- 4.1 mysqldump介绍
- 4.2 mysqldump备份方式
- 4.2.1 InnoDB表
- 4.2.2 非InnoDB表
- 4.3 mysqldump核心参数
- 4.3.1 mysqldump连接参数
- 4.3.2 mysqldump备份参数
- 4.3.3 mysqldump备份高级参数
- 4.3.3.1 --master-data参数
- 4.3.3.2 --single-transaction参数
- 4.3.3.2 -R/-E/--triggers参数
- 4.3.3.2 --max_allowed_packet参数
- 5. 基于mysqldump+binlog故障恢复案例
1. MySQL数据损坏类型
1.1 物理损坏
磁盘损坏:硬件,磁道坏,dd,格式化
文件损坏:数据文件损坏,redo损坏
1.2 逻辑损坏
drop、delete、truncate、update
2. DBA运维人员备份/恢复职责
2.1 设计备份/容灾策略
2.1.1 备份策略
备份工具原则
备份周期设计
备份监控方法
2.1.2 容灾策略
备份:用什么备份
架构: 高可用,延时从库,灾备库
容灾的好处: 在发生灾难的时候,怎么能快速的恢复业务。可以用备份或高可用的架构
2.2 定期的备份/容灾检查
备份软件 ------> 带库(磁带)
每周 北京 --> 天津 货运
一定要定时的检查数据库的备份情况,以防止自己写的脚本有bug,保证正常备份。
2.3 定期的故障恢复演练
至少每年两次的恢复演练。在测试环境进行恢复演练。
2.4 数据损坏时的快速准确恢复
每个产品数据库出现故障,要快速的恢复数据,把相关命令写清楚,每一种损坏的应对策略。
2.5 数据迁移工作
一般用备份的手段或者主从的手段来进行迁移
3. MySQL常用备份工具
逻辑备份:备份的是sql语句
物理备份:备份的是表空间文件(数据文件)
3.1 逻辑备份方式
mysqldump(MDP) *****
replication(主从方式)
mydumper(自行扩展)
load data in file(自行扩展)
3.2 物理备份方式
MySQL Enterprise Backup(企业版)
Percona Xtrabackup(PBK,XBK)*****
小提示:社区版没有自带的物理备份方式
3.3 架构备份方式
架构备份方式,属于逻辑的一种,比如MySQL主从。
4. mysqldump应用
查看mysqldump的参数帮助:mysqldump --help
4.1 mysqldump介绍
逻辑备份工具。备份的是SQL语句。
4.2 mysqldump备份方式
innodb表,备份的时候不需要锁原来的表的,原来的表该干什么干什么,不受影响。
因为这只是一个优先读的快照,不会影响其他人操作
非innodb表在mysql中基本上都是系统相关的表,系统表要备份,元数据要备份的话,要进行
全局锁表
做全备份的时候,有innodb和非innodb,备份时会有短暂的锁表的情况,尽量避免非innodb锁表的情况
mysql8.0以后,大部分的系统表都被存储到innnodb表中,备份起来性能会更好一些
4.2.1 InnoDB表
可以采用快照备份的方式
开启一个独立的事务,获取当前最新的一致性快照。
将快照数据,放在临时表中,转换成SQL(Create database,Create table,insert),保存到sql文件中
4.2.2 非InnoDB表
需要锁表备份,触发FTWRL,全局锁表。转化成SQL(Create database,Create table,insert),保存到sql文件中
4.3 mysqldump核心参数
4.3.1 mysqldump连接参数
-u 用户名 -p密码 -h IP地址 -P 端口号 -S 套接字文件
mysql也好,mysqldump也好,在你没有指定-S或者配置文件里面也没有-S的时候,也会自动去/tmp里面去找,-S 不指定也行,默认会去找/tmp/mysql.sock,如果mysql.sock在其他地方,那就必须要加-S或者在配置文件加上参数指定mysql.sock的具体位置
避免mysql密码暴露问题:(一般不采用,没有必要)
# 在配置文件中添加这些参数,登录mysql时不需要密码(一般不采用,没有必要)。
vim ~/.my.cnf
[mysql]
user=root
password=123456
[mysqldump]# 读取mysql配置文件顺序: 后面的参数覆前面的参数
[root@db01 ~]# mysql --help --verbose | grep my.cnf
/etc/my.cnf /etc/mysql/my.cnf /usr/local/mysql/etc/my.cnf ~/.my.cnf
4.3.2 mysqldump备份参数
-A 全备
[root@db01 ~]# mkdir -p /data/backup
[root@db01 ~]# chown -R mysql.mysql /data/*
[root@db01 ~]# mysqldump -uroot -p123456 -S /tmp/mysql.sock -A > /data/backup/full.sql
[root@db01 ~]# vim /data/backup/full.sql
-B 备份单库或多个库(-B后面跟的都是库名)
# 备份world库和test库
[root@db01 ~]# mysqldump -uroot -p123456 -B world test > /data/backup/db.sql
备份单表或多表(固定语法: 数据库 表 表 表,不能写多个库名)
# 备份world库中的city表和coutry表
[root@db01 ~]# mysqldump -uroot -p123456 -S /tmp/mysql.sock world city country > /data/backup/tab.sql
验证一下:以下两个命令的备份结果区别?
mysqldump -uroot -p123456 -B world > /data/backup/db1.sql
# 上面的比下面多出两条sql
create database world;
use world;# 这条sql备份world库下面的所有表。应用时,world库不存在,需要手工创建,并且use到world库下再恢复。
mysqldump -uroot -p123456 world > /data/backup/db2.sql
对比两个sql文件:vimdiff db1.sql db2.sql
4.3.3 mysqldump备份高级参数
4.3.3.1 --master-data参数
场景:每周日23:00全备,周1-6进行binlog备份。所有备份时完整的。
周三时,有一个核心运维人员济宁了删库操作。
恢复思路:恢复全备 + 所有需要binlog恢复
痛点:binlog的截取。起点查找比较困难,有两种方法
起点: 一定要找到备份开启时刻准确的position号以及binlog文件名,因为对innodb来说时快照备份,对于myisam是锁表备份,所以全备的那一刻起就必须找到准确起点position号。有两种方法找起点。
方法一:备份开始时,自动记录日志文件信息(有position号) --master-data=2(–master-data=2在备份开始的那个时刻,记录一下当前日志文件的一个状态)常用方法
方法二:备份开始时,切割日志。-F(备份一开始binlog日志就是flush一下,生成一个新的文件,切割一个新的日志出来,-F 备份起始的时候,直接刷新一个新的日志,是有多少个库,刷新多少个。这个参数使用起来不太方便)
终点: drop之前的位置点
–master-data=2 参数详解:
[root@db01 binlog]# mysqldump --help--master-data[=#] This causes the binary log position and filename to beappended to the output. If equal to 1, will print it as aCHANGE MASTER command; if equal to 2, that command willbe prefixed with a comment symbol. This option will turn--lock-all-tables on, unless --single-transaction isspecified too (in which case a global read lock is onlytaken a short time at the beginning of the dump; don'tforget to read about --single-transaction below). In allcases, any action on logs will happen at the exact momentof the dump. Option automatically turns --lock-tablesoff.
功能:
(1)备份时自动记录binlog信息
(2)自动锁表和解锁
(3)配合single transaction 可以减少锁表时间
开始实验
确认起点方法一:(生产中使用–master-data=2参数)
[root@db01 backup]# mysqldump -uroot -p123456 -A --master-data=2 > /data/backup/full1.sql;
[root@db01 backup]# mysqldump -uroot -p123456 -A --master-data=1 > /data/backup/full2.sql;
对比 --master-data=2和 --master-data=1备份出来的区别:
vim full1.sql full2.sql
区别:–master-data=2多了主从的命令,但是前面有注释。 --master-data=1没有注释,我们不需要主从的命令,真要使用主从,手动去指定恢复的起点。
确认起点方法二:(一般不用这种方法,了解即可)
[root@db01 binlog]# ls
mysql-bin.000001 mysql-bin.000003 mysql-bin.000005 mysql-bin.000007
mysql-bin.000002 mysql-bin.000004 mysql-bin.000006 mysql-bin.index
# 这种方法切出来的日志文件比较多而且混乱,不好确定位置点
[root@db01 binlog]# mysqldump -uroot -p123456 -A -F > /data/backup/full3.sql
[root@db01 binlog]# ls
mysql-bin.000001 mysql-bin.000008 mysql-bin.000015 mysql-bin.000022 mysql-bin.000029
mysql-bin.000002 mysql-bin.000009 mysql-bin.000016 mysql-bin.000023 mysql-bin.000030
mysql-bin.000003 mysql-bin.000010 mysql-bin.000017 mysql-bin.000024 mysql-bin.000031
mysql-bin.000004 mysql-bin.000011 mysql-bin.000018 mysql-bin.000025 mysql-bin.index
mysql-bin.000005 mysql-bin.000012 mysql-bin.000019 mysql-bin.000026
mysql-bin.000006 mysql-bin.000013 mysql-bin.000020 mysql-bin.000027
mysql-bin.000007 mysql-bin.000014 mysql-bin.000021 mysql-bin.000028
4.3.3.2 --single-transaction参数
对于InnoDB引擎表备份时,开启一个独立事务,获取一致性快照,进行备份。
# --master-data=2 --single-transaction生产必加参数
[root@db01 backup]# mysqldump -uroot -p123456 -A --master-data=2 --single-transaction > /data/backup/full1.sql
[root@db01 binlog]# mysqldump --help--single-transaction Creates a consistent snapshot by dumping all tables in asingle transaction. Works ONLY for tables stored instorage engines which support multiversioning (currentlyonly InnoDB does); the dump is NOT guaranteed to beconsistent for other storage engines. While a--single-transaction dump is in process, to ensure avalid dump file (correct table contents and binary logposition), no other connection should use the followingstatements: ALTER TABLE, DROP TABLE, RENAME TABLE,TRUNCATE TABLE, as consistent snapshot is not isolatedfrom them. Option automatically turns off --lock-tables.
4.3.3.2 -R/-E/–triggers参数
这一组参数涉及mysql高级变成部分,涉及到的一些对象,可以理解为和表有一定的关系,所以备份时也要加上。
拿Linux系统来通俗的理解这些参数:
-R 类似于自己写的程序脚本,如果之备份linux系统,不备份自己写的脚本程序,那就缺少了功能【备份存储过程和函数,相当于再数据库里开发的一些程序】
-E 类似于计划任务,【备份事件】
–triggers类似于特殊类的脚本,【备份触发器】
# -R -E --triggers生产环境必备的参数
[root@db01 backup]# mysqldump -uroot -p123456 -A --master-data=2 --single-transaction -R -E --triggers > /data/backup/full1.sql
4.3.3.2 --max_allowed_packet参数
传输包的最大传输大小:--max_allowed_packet=64M
# 调整客户端--max_allowed_packet大小,如果64M还是不够,那就调整128M
[root@db01 backup]# mysqldump -uroot -p123456 -A --master-data=2 --single-transaction -R -E --triggers --max_allowed_packet=64M > /data/backup/full1.sql
深度解析:
两种情况:(mysqldump是修改客户端–max_allowed_packet的大小)
(1) mysql发送insert指令是客户端向服务端发送数据,如果报错Got a packet bigger than ‘max_allowed_packet’ bytes
,那么就修改服务端–max_allowed_packet的大小。
(2)mysqldump命令指令是服务端向客户端发送数据,如果报错Got a packet bigger than ‘max_allowed_packet’ bytes
,那么就修改客户端–max_allowed_packet的大小。
5. 基于mysqldump+binlog故障恢复案例
相关文章:

MySQL备份恢复(十二)
文章目录1. MySQL数据损坏类型1.1 物理损坏1.2 逻辑损坏2. DBA运维人员备份/恢复职责2.1 设计备份/容灾策略2.1.1 备份策略2.1.2 容灾策略2.2 定期的备份/容灾检查2.3 定期的故障恢复演练2.4 数据损坏时的快速准确恢复2.5 数据迁移工作3. MySQL常用备份工具3.1 逻辑备份方式3.2…...

【Java|golang】1792. 最大平均通过率---封装最小堆
一所学校里有一些班级,每个班级里有一些学生,现在每个班都会进行一场期末考试。给你一个二维数组 classes ,其中 classes[i] [passi, totali] ,表示你提前知道了第 i 个班级总共有 totali 个学生,其中只有 passi 个学…...

PHP 页面静态化
前言随着网站的内容的增多和用户访问量的增多,网站加载会越来越慢,受限于带宽和服务器同一时间的请求次数的限制,,我们往往需要在此时对我们的网站进行代码优化和服务器配置的优化。一、页面静态化概念静态化定义静态化就是指把原…...

【Python】进制、计算机中的单位、编码、数据类型、索引、字符串切片、字符串的功能方法
一、进制计算机中底层所有的数据都是以 010101 的形式存在(图片、文本、视频等)。二进制八进制十进制(也就是我们熟知的阿拉伯数字)十六进制进制转换v1 bin(25) # 十进制转换为二进制 print(v1) # "0b11001"v2 oct(23…...

基于android的无人健身房
需求信息: 1:客户登录:首次登陆必须注册,用户注册完成后可以进入软件查看自己的金额、会员等级、消费和健身时长。 2:计费功能:用户通过软件扫描二维码后即可进入健身房,软件显示欢迎进入健身房…...

带你Java基础入门
首先我们都知道的,Java是一种高级计算机语言,是可以编写跨平台应用软件、完全面向对象的程序设计语言。相对于零基础小白如何更加快速的入门java?小编给大家整理了java300集自学教程视频,非常适合零基础的小伙伴,一周时间实现快速…...

VNCTF 2023 - Web 象棋王子|电子木鱼|BabyGo Writeups
象棋王子 签到题,jsfuck解密 丢到console得到flag 电子木鱼 后面两道都是代码审计,这题是rust,题目给出了源码,下载下来看 关键代码: 由于限制,quantity只能为正数 功德也只能是正数(负数的…...

「JVM 编译优化」插入式注解处理器(自定义代码编译检查)
JDK 的编译子系统暴露给用户直接控制的功能相对很少,除了虚拟机即时编译的若干参数,便只有 JSR-296 中定义的插入式注解处理器 API; 文章目录1. 目标2. 实现3. 运行与测试4. 其他应用案例1. 目标 前端编译器在讲 Java 源码编译成字节码时对源…...

一文彻底理解大小端和位域 BIGENDIAN LITTLEENDIAN
一文彻底理解大小端和位域 为什么有大小端 人们一直认为大道至简,就好像物理学上的世界追求使用一个理论来统一所有的现象。为什么cpu存在大小端之分,一言以蔽之,这两种模式各有各的优点,其各自的优点就是对方的缺点,…...

面试准备知识点与总结——(虚拟机篇)
目录JVM的内存结构JVM哪些部分会发生内存溢出方法区、永久代、元空间三者之间的关系JVM内存参数JVM垃圾回收算法1.标记清除法2.标记整理3.标记复制说说GC和分代回收算法三色标记与并发漏标的问题垃圾回收器项目中什么时候会内存溢出,怎么解决类加载过程三个阶段何为…...

spring cloud 集成 seata 分布式事务
spring cloud 集成 seata 分布式事务 基于 seata-server 1.6.x 序言 下载 seata-server 准备一个数据库 seata 专门为 seata-server 做存储,如, 可以指定 branch_tabledistributed_lockglobal_tablelock_table 准备一个业务库,比如存放定单ÿ…...

k8s篇之概念介绍
文章目录时光回溯什么是K8SK8S不是什么一、K8S构成组件控制平面组件(Control Plane Components)kube-apiserveretcdkube-schedulerkube-controller-managercloud-controller-managerNode 组件kubeletkube-proxy容器运行时(Container Runtime&…...

JavaScript学习第1天:浏览器组成、JS的组成、变量、数据类型转化、运算符、while和do...while循环
目录一、浏览器的组成二、JS的组成三、变量1、同时声明多个变量2、声明变量特殊情况四、数据类型1、数据类型2、 isNaN()方法3、字符串转义符4、字符串拼接5、特殊拼接五、数据类型转换1、转化为字符串2、转化为数字型3、转化为布尔值六、运算符1、递增和递减运算符2、逻辑运算…...

【Flutter入门到进阶】Dart进阶篇---Dart多线程异步原理
1 Isolate 1.1 什么是Isolate 1.1.1 概念 线程?异步?隔离?到底什么意思? Isolate中文意思是隔离,从使用角度来说是Dart的线程,但是从本质虚拟机的实现角度来讲Isolate是一组封装。 isolate可以理解为dar…...

WEB系列(二)-----------XSS
XSS原理及基础 定义 恶意攻击者会往Web页面里插入JS代码,当用户点击网页时.镶嵌的JS代码就会执行,从而达到恶意的特殊目的. 原因 程序对输入和输出的控制不够严格,导致payload输出到前段时被浏览器当做有效代码执行从而产生危害。 分类 存储型反射型DOM型 测…...

[python入门㊾] - python异常中的断言
目录 ❤ 断言的功能与语法 ❤ 常用断言 ❤ 常用的断言表达方式 ❤ 异常断言 ❤ 正则断言 ❤ 检查断言装饰器 ❤ 断言的功能与语法 Python assert(断言)用于判断一个表达式,在表达式条件为 False 的时候触发异常 断言可以在条件…...

一文告诉你什么是财务数据治理?
大家好,我是梦想家Alex,今天是周末,就不给大家分享技术文了~应出版社老师推荐,文末给大家送几本DAMA中国主席力荐,20位行业专家历时2年共同打造的《财务数据治理实战》,将数据治理理论应用于财务…...

MySQL数据库调优————ORDER BY语句
ORDER BY调优的核心原理,原则是利用索引的有序性跳过排序环节 关于ORDER BY语句的一些尝试 我们使用employees表进行尝试,索引情况如下 在执行计划的结果中,Extra里如果存在,Using filesort则表示,排序没有使用到索…...

Linux命令之grep
Linux grep是一个非常强大的文本搜索工具。按照给定的正则表达式对目标文本进行匹配检查,打印匹配到的行。grep命令可以跟其他命令一起使用,对其他命令的输出进行匹配。 grep语法如下: grep [options] [pattern] content 文本检索 grep可以对…...

一起学 pixijs(4):如何绘制文字md
大家好,我是前端西瓜哥,今天我们来学 pixijs 如何绘制文字。pixijs 版本为 7.1.2。 使用原生的 WebGL 来绘制文字是非常繁琐的,pixijs 对此进行了高层级的封装,提供了 Text 类和 BitMapText 类来绘制文字。 Text 最基本的写法&…...

mac m1设备上安装Qt并使用qt编程遇到的问题以及解决方式
# 简介: 首先在M1平台上的程序可以看到有两种架构,分别是intel的(x86-64)和苹果的m1(arm64架构),根据苹果的介绍,当在m1上面运行intel程序的时候使用的是转译的方式运行的ÿ…...

tensorflow 学习笔记(二):神经网络的优化过程
前言: 学习跟随 如何原谅奋力过但无声的 tensorflow 笔记笔记。 本章主要讲解神经网络的优化过程:神经网络的优化方法,掌握学习率、激活函数、损失函数和正则化的使用,用 Python 语言写出 SGD、Momentum、Adagrad、RMSProp、Ada…...

【Java】《Java8 实战》 CompletableFuture 学习
文章目录前言1. 并发(Concurrent) 和 并行(Parallel)1.1 并发的来源1.2 并发技术解决了什么问题2. 并行的来源2.1 并行解决了什么问题3. CompletableFuture 简介4. CompletableFuture 简单应用5. CompletableFuture 工厂方法的应用6. CompletableFuture join() 方法7. 使用 Par…...

Vue3之条件渲染
1.何为条件渲染 条件渲染就是在指定的条件下,渲染出指定的UI。比如当我们显示主页的时候,应该隐藏掉登录等一系列不相干的UI元素。即UI元素只在特定条件下进行显示。而在VUE3中,这种UI元素的显示和隐藏可以通过两个关键字,v-if 和…...

将Nginx 核心知识点扒了个底朝天(四)
为什么 Nginx 不使用多线程? Apache: 创建多个进程或线程,而每个进程或线程都会为其分配 cpu 和内存(线程要比进程小的多,所以 worker 支持比 perfork 高的并发),并发过大会榨干服务器资源。 Nginx: 采用…...

设计模式之工厂模式
文章の目录一、什么是工厂模式二、工厂模式有什么用?三、应用场景四、示例1、用字面量的方式创建对象2、使用工厂模式创建对象参考写在最后一、什么是工厂模式 工厂模式是一种众所周知的设计模式,广泛应用于软件工程领域,用于抽象创建特定对…...

80.链表-由来
链表是怎么发展来的 线性表:是n个具有相同特性的数据元素的有限序列。 链表:具有线性存储结构的线性表。 为什么需要使用链表?(链表是如何被设计出来的) 程序开发最重要的部分是如何在项目程序中找到一种合适的、好…...

元胞自动机
文章目录前言文献阅读摘要主要贡献方法框架实验结论元胞自动机元胞自动机是什么?构成及规则案例及代码实现总结前言 This week,the paper proposes a Multi-directional Temporal Convolutional Artificial Neural Network (MTCAN) model to impute and forecast P…...

设计模式之各种设计模式总结与对比
目录1 目标2 定位3 一句话归纳设计原则4 G0F 23种设计模式简介5 设计模式使用频次总结6 —句话归纳设计模式7 设计模式之间的关联关系和对比1 目标 1、 简要分析GoF 23种设计模式和设计原则,做整体认知。 2、 剖析Spirng的编程思想,启发思维,为之后深入学习Spring…...

JAVA练习55- Fizz Buzz
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 目录 前言 一、题目-Fizz Buzz 1.题目描述 2.思路与代码 2.1 思路 2.2 代码 总结 前言 提示:这里可以添加本文要记录的大概内容: 2月19日练习…...