当前位置: 首页 > news >正文

金华网站建设微信开发郑州有没有厉害的seo顾问

金华网站建设微信开发,郑州有没有厉害的seo顾问,织梦 去掉我的网站,教育政务网站建设文章目录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…

文章目录

    • 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故障恢复案例

http://www.fp688.cn/news/164797.html

相关文章:

  • 佛山微信网站建设哪家好东莞网站建设优化技术
  • 设计网站架构百度手机app
  • 丰台青岛网站建设小说百度搜索风云榜
  • 如何自制一个网站关键词优化一年多少钱
  • java网站开发的需求文档百度信息流广告怎么投放
  • 关键字网站采集百度网站官网入口网址
  • java的大型网站建设谷歌优化技巧
  • 鞍山做网站或宁波seo快速排名
  • 家具行业做那个国际网站比较好网络推广和网络营销的区别
  • thinkphp手机网站模板新一轮疫情最新消息
  • 深圳网站建设忧化百色seo外包
  • 手机网站源码 html5广东东莞最新疫情
  • seo搜索培训百度ocpc怎么优化
  • 在哪里找做网站的全网营销
  • 网站开发运营维护方案建议文档谷歌下载安装
  • 什么是网站结构代推广平台
  • 企业备案增加网站品牌传播策划方案
  • 网站首页布局修改关键词seo排名
  • 什么网站做设计可以赚钱吗网络营销软文范例300
  • b2b网站平台免费有哪些微博推广方法有哪些
  • 自己做的网页怎么上传网站seo怎样优化网站
  • 四川星星建设集团有限公司网站如何进行搜索引擎优化?
  • wordpress留言提交慢如何进行seo搜索引擎优化
  • 珠海市做网站网络营销费用预算
  • 上海网站关键词排名优化报价网络营销有哪些形式
  • 那种退不掉的网站怎么做的seo有哪些网站
  • 文化建设网站华为手机网络营销策划方案
  • 建立企业网站的目的网络营销该如何发展
  • 怎样做网站怎要加服务器网络建设推广
  • 电商网站架构互联网公司排名