电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

MySQL 日志相關知識總結

瀏覽:3日期:2023-10-06 10:43:57

數據庫中用于存儲數據的文件稱為data file,日志文件稱為log file。此外,如果每次讀寫都是直接訪問磁盤,性能很差,所以數據庫是有緩存的,數據緩存是data buffer,日志緩存log buffer。

sql執行順序

當我們執行一條更新語句時,比如 update table set c=c+1 where id = 2,執行順序如下:

執行器通過存儲引擎獲取id=2的行記錄。如果id=2的行記錄所在的數據頁已經在內存中,則直接返回;否則,需要從磁盤讀取數據 執行器拿到返回的行數據,把字段c的值+1,得到新的行數據,然后調用存儲引擎接口寫入行數據 引擎把這行數據更新到內存,同時將這個更新操作記錄到redo log里面,此時redo log處于prepare狀態。然后告訴執行器執行完成,隨時可以提交事務 執行器生成這個操作的bin log,并把bin log寫入磁盤 執行器調用引擎的提交事務接口,引擎把剛剛寫入的redo log改成commit狀態,更新完成

補充:MySQL的基本存儲結構是頁(記錄都存在頁里邊),所以MySQL是先把這條記錄所在的頁找到,然后把該頁加載到內存中,再修改對應的記錄。

bin log是什么

bin log稱為歸檔日志、二進制日志,屬于MySQL Server層面的,用于記錄數據庫表結構和表數據的變更,可以簡單理解為存儲每條變更的sql語句,比如insert、delete、update(當然,不僅是sql,還有事務id,執行時間等等)。

MySQL 日志相關知識總結

什么時候產生

事務提交的時候,一次性將事務中的sql語句按照一定格式記錄到bin log

有什么用

主要有兩個作用:主從復制和恢復數據

目前大部分數據庫架構都是一主多從,從服務器通過訪問主服務器的bin log,保證數據一致性 bin log記錄數據庫的變更,可以通過它恢復數據 什么時候落盤

區分innodb_flush_log_at_trx_commit和sync_binlog

​ 二進制日志取決于sync_binlog參數

0:事務提交后,由操作系統決定什么時候把緩存刷新到磁盤(性能最好,安全性最差) 1:每提交一次事務,調用一次fsync將緩存寫入到磁盤(安全性最好,性能最差) n:當提交n次事務后,調用一次fsync將緩存寫入到磁盤 文件記錄模式

bin log有三種文件記錄模式,分別是row、statement、mixed

row(row-based replication,PBR):記錄每一行數據的修改情況

優點:能夠清楚記錄每行數據修改細節,能夠完全保證主從數據一致性缺點:批量操作時會產生大量的日志,比如alter table

statement:記錄每條修改數據的sql,可認為sql語句復制

優點:日志數據量小,減少磁盤IO,提高存儲和恢復速度缺點:在某些情況下會出現主從不一致,比如sql語句中包含**now()**等函數

mixed:上面兩種模式的混合,MySQL會根據sql語句選擇寫入模式,一般使用statement模式保存bin log,對于statement模式無法復制的操作,使用row模式保存bin log。 redo log是什么

redo log稱為重做日志,屬于InnoDB存儲引擎層的日志,記錄物理頁的修改信息,而不是某一行或幾行修改成什么樣

什么時候產生

事務開始,就會寫入redo log。redo log寫入到磁盤并不是隨著事務提交才寫入,而是在事務執行過程中,就已經寫入到磁盤

有什么用

可用于恢復數據。redo log是在事務開始后就寫入到磁盤,且是順序IO,寫入速度較快。如果服務器突然掉電,InnoDB引擎會使用redo log把數據庫恢復到掉電前的時刻,保證數據的完整性

什么時候落盤

InnoDB先把日志寫到緩沖區(log buffer),然后再把日志從log buffer刷到os buffer,最后調用文件系統的fsync函數將日志刷新到磁盤。重做日志寫入時機由參數innodb_flush_log_at_trx_commit決定

0:每秒一次,把log buffer寫入os buffer,并調用fsync刷到磁盤 1:每次提交事務時,把log buffer寫入os buffer,并調用fsync刷到磁盤 2:每次提交事務時,只是寫入到os buffer,然后每秒一次調用fsync將日志刷新到磁盤

一般取值為2,因為即使MySQL宕機,數據也沒有丟失。只有整個服務器掛了,才損失1秒的數據

MySQL 日志相關知識總結

bin log VS redo log

看了以上的介紹,感覺bin log和redo log很像,都是記錄數據變更,可用于恢復。其實,它們還是有明顯區別的。

bin log屬于MySQL Server層面的,redo log屬于InnoDB存儲引擎層面 bin log是邏輯日志,記錄的是sql語句的原始邏輯;redo log是物理日志,記錄的是物理頁面更新的內容 bin log是追加寫,文件達到限制后會更換下個文件,不會覆蓋;redo log是循環寫,文件大小固定,寫滿就重頭開始寫,覆蓋原來的內容 bin log作用是主從復制和恢復數據,當數據庫被刪除、或者從庫同步主庫數據時,由于bin log記錄變更數據的sql,所以可通過bin log恢復。而redo log作用是持久化,當發生服務器宕機或者掉電等情況,數據丟失,可以通過redo log恢復。 bin log是提交事務時才寫入磁盤,而redo log在開啟事務時,就開始寫入到磁盤

如果整個數據庫被刪除,可以通過redo log恢復嗎?

不行!因為redo log側重點是保存某次事務的數據變更,當內存中的數據刷到磁盤后,redo log的數據其實已經沒有參考價值。此外,redo log會覆蓋歷史數據,也不可能通過它來恢復所有數據。

undo log

詳細分析MySQL事務日志

是什么

undo log稱為回滾日志,屬于InnoDB存儲引擎層,是邏輯日志,記錄每行數據。當我們變更數據時,就會產生undo log,可以認為insert一條數據,undo log會記錄一條對應的delete日志,反之亦然。

什么時候產生

在事務開始前,將當前版本生成undo log

有什么用

主要作用:提供回滾和多版本并發控制(MVCC)

回滾:當需要rollback時,從undo log的邏輯記錄讀取相應的內容進行回滾 MVCC:undo log記錄中存儲的是舊版本數據,當一個事務需要讀取數據時,會順著undo鏈找到滿足其可見性的記錄

以上就是MySQL 日志相關知識總結的詳細內容,更多關于MySQL 日志的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 艾默生变频器,艾默生ct,变频器,ct驱动器,广州艾默生变频器,供水专用变频器,风机变频器,电梯变频器,艾默生变频器代理-广州市盟雄贸易有限公司官方网站-艾默生变频器应用解决方案服务商 | 瓶盖扭矩仪(扭力值检测)-百科| 恒温恒湿箱(药品/保健品/食品/半导体/细菌)-兰贝石(北京)科技有限公司 | 免联考国际MBA_在职MBA报考条件/科目/排名-MBA信息网 | 深圳APP开发公司_软件APP定制开发/外包制作-红匣子科技 | 苏州防水公司_厂房屋面外墙防水_地下室卫生间防水堵漏-苏州伊诺尔防水工程有限公司 | 欧美日韩国产一区二区三区不_久久久久国产精品无码不卡_亚洲欧洲美洲无码精品AV_精品一区美女视频_日韩黄色性爱一级视频_日本五十路人妻斩_国产99视频免费精品是看4_亚洲中文字幕无码一二三四区_国产小萍萍挤奶喷奶水_亚洲另类精品无码在线一区 | b2b网站大全,b2b网站排名,找b2b网站就上地球网 | YAGEO国巨电容|贴片电阻|电容价格|三星代理商-深圳市巨优电子有限公司 | 仿真茅草_人造茅草瓦价格_仿真茅草厂家_仿真茅草供应-深圳市科佰工贸有限公司 | 铝合金电阻-无源谐波滤波器-上海稳达电讯设备厂 | 天然鹅卵石滤料厂家-锰砂滤料-石英砂滤料-巩义东枫净水 | 智能化的检漏仪_气密性测试仪_流量测试仪_流阻阻力测试仪_呼吸管快速检漏仪_连接器防水测试仪_车载镜头测试仪_奥图自动化科技 | 密集柜_档案密集柜_智能密集架_密集柜厂家_密集架价格-智英伟业 密集架-密集柜厂家-智能档案密集架-自动选层柜订做-河北风顺金属制品有限公司 | 不干胶标签-不干胶贴纸-不干胶标签定制-不干胶标签印刷厂-弗雷曼纸业(苏州)有限公司 | 工业铝型材-铝合金电机壳-铝排-气动执行器-山东永恒能源集团有限公司 | 新疆散热器,新疆暖气片,新疆电锅炉,光耀暖通公司 | 华禹护栏|锌钢护栏_阳台护栏_护栏厂家-华禹专注阳台护栏、楼梯栏杆、百叶窗、空调架、基坑护栏、道路护栏等锌钢护栏产品的生产销售。 | 上海质量认证办理中心| 胜为光纤光缆_光纤跳线_单模尾纤_光纤收发器_ODF光纤配线架厂家直销_北京睿创胜为科技有限公司 - 北京睿创胜为科技有限公司 | 尊享蟹太太美味,大闸蟹礼卡|礼券|礼盒在线预订-蟹太太官网 | 千淘酒店差旅平台-中国第一家针对TMC行业的酒店资源供应平台 | 纯化水设备-EDI-制药-实验室-二级反渗透-高纯水|超纯水设备 | R507制冷剂,R22/R152a制冷剂厂家-浙江瀚凯制冷科技有限公司 | 电动葫芦-河北悍象起重机械有限公司 | 整合营销推广|营销网络推广公司|石家庄网站优化推广公司|智营销 好物生环保网、环保论坛 - 环保人的学习交流平台 | 安徽净化板_合肥岩棉板厂家_玻镁板厂家_安徽科艺美洁净科技有限公司 | 变压器配件,变压器吸湿器,武强县吉口变压器配件有限公司 | 哈尔滨京科脑康神经内科医院-哈尔滨治疗头痛医院-哈尔滨治疗癫痫康复医院 | 阻垢剂,反渗透阻垢剂,缓蚀阻垢剂-山东普尼奥水处理科技有限公司 真空粉体取样阀,电动楔式闸阀,电动针型阀-耐苛尔(上海)自动化仪表有限公司 | 减速机电机一体机_带电机减速器一套_德国BOSERL电动机与减速箱生产厂家 | 西安文都考研官网_西安考研辅导班_考研培训机构_西安在职考研培训 | 转子泵_凸轮泵_凸轮转子泵厂家-青岛罗德通用机械设备有限公司 | 影视模板素材_原创专业影视实拍视频素材-8k像素素材网 | 芜湖厨房设备_芜湖商用厨具_芜湖厨具设备-芜湖鑫环厨具有限公司 控显科技 - 工控一体机、工业显示器、工业平板电脑源头厂家 | 北京印刷厂_北京印刷_北京印刷公司_北京印刷厂家_北京东爵盛世印刷有限公司 | 视频直播 -摄影摄像-视频拍摄-直播分发 | 网站seo优化_seo云优化_搜索引擎seo_启新网络服务中心 | 高精度-恒温冷水机-螺杆式冰水机-蒸发冷冷水机-北京蓝海神骏科技有限公司 | 带锯机|木工带锯机圆木推台锯|跑车带锯机|河北茂业机械制造有限公司| | 加中寰球移民官网-美国移民公司,移民机构,移民中介,移民咨询,投资移民 |