码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Mysql知识点


    文章目录

    • 日志(log)
      • bin log
      • undo log
      • redo log
      • Realy log
    • Mysql数据如何恢复?
    • Mysql删库后如何恢复?
    • Mysql崩溃后如何恢复?
    • Mysql如何做主从复制?
    • MySQL [DML与DDL](https://blog.csdn.net/yuell102/article/details/125899572?csdn_share_tail=%7B%22type%22:%22blog%22,%22rType%22:%22article%22,%22rId%22:%22125899572%22,%22source%22:%22yuell102%22%7D&ctrtid=b83hH)
      • 全称
      • 详细描述
      • DML与DDL的区别:

    日志(log)

    bin log

    主要应用于:数据恢复、主从复制
    bin log 以事件的形式记录了所有的 DDL 和 DML 语句(因为它记录的是操作而不是数据值,属于逻辑日志):

    • b i n l o g 是 M y S Q L 数据库级别的文件,主要用于恢复数据库和同步数据库 \color{#FF0000}{bin log是MySQL数据库级别的文件,主要用于恢复数据库和同步数据库} binlog是MySQL数据库级别的文件,主要用于恢复数据库和同步数据库
    • 对 M y S Q L 数据库各种引擎下执行修改的所有操作进行记录,不会记录 s e l e c t 和 s h o w 语句 \color{#FF0000}{对MySQL数据库各种引擎下执行修改的所有操作进行记录,不会记录select和show语句} 对MySQL数据库各种引擎下执行修改的所有操作进行记录,不会记录select和show语句
    • 存储大小不受限制 \color{#FF0000}{存储大小不受限制} 存储大小不受限制

    数据恢复:区别于Redo Log的崩溃恢复,数据恢复是基于业务数据的,比如删库跑路,而崩溃恢复是断电重启的

    undo log

    redo log

    Realy log

    从节点数据库,读到主节点数据后的一个缓冲日志,避免数据量过大压垮从节点

    Mysql数据如何恢复?

    - 恶意删库数据库恢复
    - 数据库崩溃数据恢复
    
    • 1
    • 2

    Mysql删库后如何恢复?

    • 基本上bin log每天会做全量备份,拿到历史的全量备份bin log进行恢复
    • 比如当前9点钟删的库,现在是10点钟,当前的可以截取到8:50(删库前几分钟,不包含删库语句)bin log进行恢复
    • 8:50-10:00点的数据需要人工分析去恢复

    Mysql崩溃后如何恢复?

    Mysql如何做主从复制?

    1. 主节点修改会通过自己的 I/O tread(I/O 线程)保存在二进制日志 Binary log(bin log)里面
    2. 从节点也启动一个 I/O thread,通过配置好的用户名和密码, 连接到主节点请求读取二进制日志,然后把读取到的二进制日志写到从节点本地的一个Realy log(日志起到缓存作用,不至于一下把从节点压垮)里面
    3. 从节点同时开启一个 SQL thread 定时检查 Realy log(这个文件也是二进制的),匀速的更新到从节点库中。
    4. 每个从节点都会记录二进制日志坐标:
    文件名
    文件中它已经从主站读取和处理的位置
    
    • 1
    • 2
    1. 由于每个从节点都记录了自己当前处理二进制日志中的位置,假如从节点意外断开连接,重新连接然后依然可以恢复处理。
      请添加图片描述请添加图片描述

    MySQL DML与DDL

    全称

    DML( data maintain Language)
    DDL(Data Definition Language)
    
    • 1
    • 2

    详细描述

    DML( Data Manipulation Language),数据操作语言-数据库基本操作,SQL中处理数据等操作统称为DML,即实现了基本的“增删改查”操作, 包括的关键字有: select、update、delete、insert、merge, 事务提交后生效,可回滚。
    DDL( Data Definition Language),数据定义语言-用于定义和管理SQL数据库中所有对象的语言,对数据库中的某些对象(database、table)进行管理,包括的关键字: create、alter、drop、truncate、comment、grant、revoke, 隐性提交,不能回滚。
    
    • 1
    • 2

    DML与DDL的区别:

    DML操作是可以手动控制事务的开启、提交和回滚的。
    DDL操作是隐性提交的,不能rollback!
    
    • 1
    • 2
  • 相关阅读:
    mongodb 基本概念
    【路径规划-PRM路径规划】基于RRT算法避障路径规划附完整matlab代码
    【PCIE709-F】基于复旦微JFM7VX690T80 FPGA的全国产化8通道光纤双FMC接口数据处理平台
    Nature:“我还有用!“凋亡细胞释放的代谢物充当组织信使
    【JAVA程序设计】(C00083)基于SSM+uniapp好物分享小程序及管理系统-有文档
    使用VisualStudio生成类图结构图for高效阅读代码
    Java之IO简述 第一篇——File类
    JavaScript の querySelector 使用说明
    《区块链公链数据分析简易速速上手小册》第1章:区块链基础(2024 最新版)
    二进制搭建以太坊节点
  • 原文地址:https://blog.csdn.net/yuell102/article/details/125898205
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号