## 引言
> 不敢說全部,大多數系統原子級的操作,在微觀層面都是分布式的。
比如:
1. Mysql中的事務原子性的實現原理;
2. Java內存數據一致性原理。
其實現,從微觀層面來講都需要有更細粒度的組件來保證。
## Mysql
redo log和binlog區別
| | redo log | binlog|
| --- | --- | --|
| 引擎 | Innodb引擎特有的,用于保證crash-safe能力 |是Mysql的server層實現的,所有引擎都可以使用|
| 功能| redo log是物理日志,記錄的是在某個數據頁上做了什么修改|binlog是邏輯日志,記錄的是這個語句的原始邏輯,比如值+1|
|特性| redo log是循環寫的,空間固定會用完 | binlog是可以追加寫入的|
Mysql中保證數據的一致性,有兩個重要的日志:物理日志redo log和邏輯日志binlog。
redo log用于保證crash-safe能力。
`Innodb_flush_log_at_trx_commit`這個參數設置成1,表示每次失誤的redo log都直接持久化到磁盤,可以保證Mysql異常重啟后數據不丟失。
sync_binlog這個參數設置成1的時候,表示每次失誤的binlog都持久化到磁盤,這樣可以保證Mysql異常重啟后binlog不丟失。

## 兩階段提交
兩階段提交是跨系統維持數據邏輯一致性時常用的一個方案。
比如:
- Mysql通過redo log、binlog實現數據一致性。
- 分布式事務2PC,兩階段提交,將事務的提交過程分為資源準備和資源提交兩個階段,并且由事務協調者來協調所有事務參與者,如果準備階段所有事務參與者都預留資源成功,則進行第二階段的資源提交,否則事務協調者回滾資源。
- 簡介
- 更新說明
- 其他作品
- 第一部分 Java框架基礎
- 第一章 Java基礎
- 多線程實戰
- 嘗試一下Guava帶返回值的多線程處理類ListenableFuture
- LocalDate和Date有什么區別
- JAVA8接口增強實踐
- 第二章 Spring框架基礎
- MVC究竟是個啥?
- @ApiImplicitParam
- 七種方式,教你在SpringBoot初始化時搞點事情!
- Spring事務狀態
- maven
- Mybatis小總結
- mybatis-plus的使用
- 第三章 SpringSecurity實戰
- 基于SpringSecurity+jwt的用戶認證
- spring-security-oauth2
- 第四章 數據庫
- mysql
- mysql授權
- mysql數據庫三個關鍵性能指標--TPS\QPS\IOPS
- 梳理一下那些年Mysql的弱語法可能會踩的坑
- 關于Mysql的“字符串”數值的轉換和使用
- 憑這一文咱把事務講透
- Mysql性能優化
- 查詢性能優化
- 不常用的一些語法
- elasticsearch
- elasticsearch文檔操作
- 索引的基本操作
- java操作ElaticSearch
- elasticsearch中的各種查詢
- DB與ES混合應用可能存在的問題及解決方案探索
- 使用es必須要知道的一些知識點:索引篇
- Es中的日期操作
- MongoDB
- 入門篇(了解非關系型數據庫 NoSQL - MongoDB)
- 集群分片 (高級篇)
- 互聯網大廠的建表規范
- 第五章 中間件
- nginx
- nginx動靜分離配置,這個雷你踩過嗎?
- Canal
- Sharding-jdbc
- 水平分庫實踐
- kafka
- 第六章 版本管理
- git
- Not currently on any branch 情況提交版本
- 第七章 IO編程
- 第八章 JVM實戰調優
- jvisualvm
- jstat
- 第二部分 高級項目實戰篇
- 第一章 微信開發實戰
- 第二章 文件處理
- 使用EasyExcel處理導入導出
- 第三章 踩坑指南
- 郵件發送功能
- 第三部分 架構實戰篇
- 第一章 架構實戰原則
- 接口防止重復調用的一種方案
- 第二章 高并發緩存一致性管理辦法
- 第三章 異地多活場景下的數據同步之道
- 第四章 用戶體系
- 集成登錄
- auth-sso的管理
- 第五章 分庫分表場景
- 第六章 秒殺與高并發
- 秒殺場景
- 第七章 業務中臺
- 中臺的使用效果是怎樣的?
- 通用黑白名單方案
- 第八章 領域驅動設計
- 第十一章 微服務實戰
- Nacos多環境管理之道
- logback日志雙寫問題及Springboot項目正確的啟動方式
- 第四部分 優雅的代碼
- java中的鏈式編程
- 面向對象
- 開發原則
- Stream操作案例分享
- 注重性能的代碼
- 第五部分 談談成長
- 新手入門指北
- 不可不知的調試技巧
- 構建自己的知識體系
- 我是如何做筆記的
- 有效的提問
- 謹防思維定勢
- 學會與上級溝通
- 想清楚再去做
- 碎片化學習
- 第六部分 思維導圖(付費)
- 技術基礎篇
- 技術框架篇
- 數據存儲篇
- 項目實戰篇
- 第七部分 吾愛開源
- 7-1 麻雀聊天
- 項目啟動
- 前端登錄無請求問題解決
- websocket測試
- 7-2 ocp微服務框架
- evm框架集成
- 項目構建與集成
- zentao-center
- 二次開發:初始框架的搭建
- 二次開發:增加細分菜單、權限到應用
- 7-3 書棧網
- 項目啟動
- 源碼分析
- 我的書架
- 文章發布機制
- IM
- 第八章 團隊管理篇
- 大廠是怎么運作的
- 第九章 碼山有道
- 簡歷內推
- 聯系我內推
- 第十章 學點前端
- Vue