亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL同步Elasticsearch的6種方案小結(jié)

 更新時間:2025年05月06日 09:43:28   作者:蘇三說技術(shù)  
在分布式架構(gòu)中,MySQL與Elasticsearch(ES)的協(xié)同已成為解決高并發(fā)查詢與復雜檢索的標配組合,本文整理了MySQL同步ES的6種主流方案,大家可以根據(jù)自己的需要進行選擇

引言

在分布式架構(gòu)中,MySQL與Elasticsearch(ES)的協(xié)同已成為解決高并發(fā)查詢與復雜檢索的標配組合。

然而,如何實現(xiàn)兩者間的高效數(shù)據(jù)同步,是架構(gòu)設(shè)計中繞不開的難題。

這篇文章跟大家一起聊聊MySQL同步ES的6種主流方案,結(jié)合代碼示例與場景案例,幫助開發(fā)者避開常見陷阱,做出最優(yōu)技術(shù)選型。

方案一:同步雙寫

場景:適用于對數(shù)據(jù)實時性要求極高,且業(yè)務(wù)邏輯簡單的場景,如金融交易記錄同步。

在業(yè)務(wù)代碼中同時寫入MySQL與ES。

代碼如下:

@Transactional  
public void createOrder(Order order) {  
    // 寫入MySQL  
    orderMapper.insert(order);  
    // 同步寫入ES  
    IndexRequest request = new IndexRequest("orders")  
        .id(order.getId())  
        .source(JSON.toJSONString(order), XContentType.JSON);  
    client.index(request, RequestOptions.DEFAULT);  
}

痛點

  • 硬編碼侵入:所有涉及寫操作的地方均需添加ES寫入邏輯。
  • 性能瓶頸:雙寫操作導致事務(wù)時間延長,TPS下降30%以上。
  • 數(shù)據(jù)一致性風險:若ES寫入失敗,需引入補償機制(如本地事務(wù)表+定時重試)。

方案二:異步雙寫

場景:電商訂單狀態(tài)更新后需同步至ES供客服系統(tǒng)檢索。

我們可以使用MQ進行解耦。

架構(gòu)圖如下

代碼示例如下

// 生產(chǎn)者端  
public void updateProduct(Product product) {  
    productMapper.update(product);  
    kafkaTemplate.send("product-update", product.getId());  
}  

// 消費者端  
@KafkaListener(topics = "product-update")  
public void syncToEs(String productId) {  
    Product product = productMapper.selectById(productId);  
    esClient.index(product);  
}

優(yōu)勢

  • 吞吐量提升:通過MQ削峰填谷,可承載萬級QPS。
  • 故障隔離:ES宕機不影響主業(yè)務(wù)鏈路。

缺陷

  • 消息堆積:突發(fā)流量可能導致消費延遲(需監(jiān)控Lag值)。
  • 順序性問題:需通過分區(qū)鍵保證同一數(shù)據(jù)的順序消費。

方案三:Logstash定時拉取

場景:用戶行為日志的T+1分析場景。

該方案低侵入但高延遲。

配置示例如下

input {  
  jdbc {  
    jdbc_driver => "com.mysql.jdbc.Driver"  
    jdbc_url => "jdbc:mysql://localhost:3306/log_db"  
    schedule => "*/5 * * * *"  # 每5分鐘執(zhí)行  
    statement => "SELECT * FROM user_log WHERE update_time > :sql_last_value"  
  }  
}  
output {  
  elasticsearch {  
    hosts => ["es-host:9200"]  
    index => "user_logs"  
  }  
}

適用性分析

  • 優(yōu)點:零代碼改造,適合歷史數(shù)據(jù)遷移。
  • 致命傷
    • 分鐘級延遲(無法滿足實時搜索)
    • 全表掃描壓力大(需優(yōu)化增量字段索引)

方案四:Canal監(jiān)聽Binlog

場景:社交平臺動態(tài)實時搜索(如微博熱搜更新)。

技術(shù)棧:Canal + RocketMQ + ES

該方案高實時,并且低侵入。

架構(gòu)流程如下

關(guān)鍵配置

# canal.properties  
canal.instance.master.address=127.0.0.1:3306  
canal.mq.topic=canal.es.sync

避坑指南

  • 數(shù)據(jù)漂移:需處理DDL變更(通過Schema Registry管理映射)。
  • 冪等消費:通過_id唯一鍵避免重復寫入。

方案五:DataX批量同步

場景:將歷史訂單數(shù)據(jù)從分庫分表MySQL遷移至ES。

該方案是大數(shù)據(jù)遷移的首選。

配置文件如下

{  
  "job": {  
    "content": [{  
      "reader": {  
        "name": "mysqlreader",  
        "parameter": { "splitPk": "id", "querySql": "SELECT * FROM orders" }  
      },  
      "writer": {  
        "name": "elasticsearchwriter",  
        "parameter": { "endpoint": "http://es-host:9200", "index": "orders" }  
      }  
    }]  
  }  
}

性能調(diào)優(yōu)

  • 調(diào)整channel數(shù)提升并發(fā)(建議與分片數(shù)對齊)
  • 啟用limit分批查詢避免OOM

方案六:Flink流處理

場景:商品價格變更時,需關(guān)聯(lián)用戶畫像計算實時推薦評分。

該方案適合于復雜的ETL場景。

代碼片段如下

StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();  
env.addSource(new CanalSource())  
   .map(record -> parseToPriceEvent(record))  
   .keyBy(event -> event.getProductId())  
   .connect(userProfileBroadcastStream)  
   .process(new PriceRecommendationProcess())  
   .addSink(new ElasticsearchSink());

優(yōu)勢

  • 狀態(tài)管理:精準處理亂序事件(Watermark機制)
  • 維表關(guān)聯(lián):通過Broadcast State實現(xiàn)實時畫像關(guān)聯(lián)

總結(jié)

對于文章上面給出的這6種技術(shù)方案,我們在實際工作中,該如何做選型呢?

下面用一張表格做對比:

方案實時性侵入性復雜度適用階段
同步雙寫秒級小型單體項目
MQ異步秒級中型分布式系統(tǒng)
Logstash分鐘級離線分析
Canal毫秒級高并發(fā)生產(chǎn)環(huán)境
DataX小時級歷史數(shù)據(jù)遷移
Flink毫秒級極高實時數(shù)倉

蘇三的建議

  • 若團隊無運維中間件能力 → 選擇Logstash或同步雙寫
  • 需秒級延遲且允許改造 → MQ異步 + 本地事務(wù)表
  • 追求極致實時且資源充足 → Canal + Flink雙保險

到此這篇關(guān)于MySQL同步Elasticsearch的6種方案小結(jié)的文章就介紹到這了,更多相關(guān)MySQL同步Elasticsearch內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL細數(shù)發(fā)生索引失效的情況

    MySQL細數(shù)發(fā)生索引失效的情況

    本文主要介紹了MySQL導致索引失效的幾種情況,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07
  • 數(shù)據(jù)從MySQL遷移到Oracle 需要注意什么

    數(shù)據(jù)從MySQL遷移到Oracle 需要注意什么

    將數(shù)據(jù)從MySQL遷移到Oracle,大家需要注意什么?Oracle移植到mysql,又需要注意什么?如何有效解決移植過程的問題,為了數(shù)據(jù)庫的兼容性我們又該注意些什么?感興趣的小伙伴們可以參考一下
    2016-11-11
  • Mysql服務(wù)器的啟動與停止(一)

    Mysql服務(wù)器的啟動與停止(一)

    Mysql服務(wù)器的啟動與停止(一)...
    2006-11-11
  • 基于Mysql+JavaSwing的超市商品管理系統(tǒng)設(shè)計與實現(xiàn)

    基于Mysql+JavaSwing的超市商品管理系統(tǒng)設(shè)計與實現(xiàn)

    本項目是使用Java swing開發(fā),可實現(xiàn)超市管理系統(tǒng)商品列表信息查詢、添加商品信息和修改商品管理以及刪除商品信息和安裝商品信息查詢等功能。界面設(shè)計和功能比較簡單基礎(chǔ)、適合作為Java課設(shè)設(shè)計以及學習技術(shù)使用,需要的朋友可以參考一下
    2021-09-09
  • 一鍵安裝mysql5.7及密碼策略修改方法

    一鍵安裝mysql5.7及密碼策略修改方法

    這篇文章主要介紹了一鍵安裝mysql5.7及密碼策略修改方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-10-10
  • MySQL常用存儲引擎功能與用法詳解

    MySQL常用存儲引擎功能與用法詳解

    這篇文章主要介紹了MySQL常用存儲引擎功能與用法,較為詳細的分析了mysql存儲引擎的分類、功能、使用方法及相關(guān)操作注意事項,需要的朋友可以參考下
    2018-04-04
  • MySQL常用命令與內(nèi)部組件及SQL優(yōu)化詳情

    MySQL常用命令與內(nèi)部組件及SQL優(yōu)化詳情

    這篇文章主要介紹了MySQL常用命令與內(nèi)部組件及SQL優(yōu)化詳情,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-07-07
  • MySQL去除重疊時間求時間差和的實現(xiàn)

    MySQL去除重疊時間求時間差和的實現(xiàn)

    在生產(chǎn)中常常出現(xiàn)計算兩個時間差的業(yè)務(wù),比如總宕機時間、總開通會員時間等,本文就詳細的來介紹一下如何計算,感興趣的可以了解一下
    2021-08-08
  • mysql獲得60天前unix時間思路及代碼

    mysql獲得60天前unix時間思路及代碼

    首先根據(jù)now()獲得當前時間,使用adddate()方法獲得60天前時間,使用unix_timestamp()方法轉(zhuǎn)換時間類型
    2014-08-08
  • 推薦幾款MySQL相關(guān)工具

    推薦幾款MySQL相關(guān)工具

    這篇文章主要介紹了幾款MySQL相關(guān)工具的相關(guān)資料,幫助大家更好的使用和維護MySQL 數(shù)據(jù)庫,感興趣的朋友可以了解下
    2020-11-11

最新評論