精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

100萬的并發,如何設計一個商品搜索系統?

開發 架構
假設場景:某電商平臺大促期間,需支撐每秒100萬次的商品搜索請求,要求響應時間≤200ms,同時應對商品數據量超10億條。假設給你來做系統設計,怎么做呢?

前言

今天我們來看一道比較有深度的面試題:百萬并發下,商品搜索系統,你如何設計呢?

假設場景:某電商平臺大促期間,需支撐每秒100萬次的商品搜索請求,要求響應時間≤200ms,同時應對商品數據量超10億條。假設給你來做系統設計,怎么做呢?

如果是我來回答面試官這道題的話,我會按照這些思路來跟面試官闡述:

  • 為什么不能用MySQL的llike?
  • 總體架構設計
  • 核心關鍵設計

1.為什么不能用mysql的like?

我們每次提到關鍵詞搜索,大家很容易就想到數據庫的like,比如:

SELECT * FROM products WHERE title LIKE '%智能手機%' LIMIT 10;

但是,顯然商品數據量超10億條,搜索不能用like。

  • LIKE '%keyword%' 無法利用索引,觸發全表掃描。10億數據時單次查詢可能耗時數秒。
  • 不支持分詞搜索(如"手機殼"無法拆分為"手機"和"殼"單獨匹配)
  • 分庫分表后跨庫LIKE查詢復雜度指數級上升

可以使用Elasticsearch ,但是我們是做系統設計,肯定不能直接回答面試官,說,用Elasticsearch呀,而是按照系統設計的思想(高可用 + 可擴展),說一整個鏈路。

2. 總體架構設計

  • 用戶層(前端 + CDN)
  • 接入層(Nginx )
  • 服務層(Search Gateway )
  • 檢索層(搜索引擎,如 Elasticsearch)
  • 數據層(商品數據服務 / DB / 緩存)

圖片圖片

2.1 用戶層(前端 + CDN)

  • 請求分發:通過CDN加速靜態資源(圖片/JS/CSS)
  • 瀏覽器緩存:利用LocalStorage緩存高頻搜索關鍵詞
  • 請求合并:合并相似搜索請求(如防抖機制)
// 前端防抖示例(減少無效請求)
let searchTimer;
function handleSearch(keyword) {
    clearTimeout(searchTimer);
    searchTimer = setTimeout(() => {
        fetch(`/api/search?q=${encodeURIComponent(keyword)}`);
    }, 300); // 300ms防抖
}

2.2 接入層(Nginx)

  • 流量管控:限流、熔斷、鑒權
  • 負載均衡:輪詢/一致性哈希分發請求
  • 協議轉換:HTTP/2 → HTTP/1.1內部通信

Nginx 關鍵配置

# 限流配置(每秒1000請求/ip)
limit_req_zone $binary_remote_addr znotallow=search_limit:10m rate=1000r/s;

location /api/search {
    limit_req znotallow=search_limit burst=200;
    proxy_pass http://search_cluster;
    
    # 緩存熱門請求結果(5秒)
    proxy_cache search_cache;
    proxy_cache_valid 200 5s;
}

2.3 服務層(Search Gateway)

  • 業務邏輯:請求參數校驗、結果格式化
  • 多級緩存:本地緩存 → Redis → Elasticsearch
  • 降級策略:超時返回兜底數據
// 搜索網關偽代碼
public class SearchGateway {
    @Cacheable(value = "localCache", key = "#keyword")
    public List<Product> search(String keyword) {
        // 1. 檢查Redis緩存
        String redisKey = "search:" + keyword.hashCode();
        List<Product> cached = redis.get(redisKey);
        if (cached != null) return cached;
        
        // 2. 查詢Elasticsearch
        List<Product> result = elasticsearch.search(buildQuery(keyword));
        
        // 3. 異步寫入緩存
        executor.submit(() -> {
            redis.setex(redisKey, 30, result); // 緩存30秒
        });
        
        return result;
    }
}

2.4 檢索層(Elasticsearch)

  • 索引構建:商品標題/類目/屬性倒排索引
  • 分布式查詢:分片并行計算
  • 相關性排序:BM25算法優化

索引設計demo:

PUT /products
{
"settings": {
    "number_of_shards": 40,
    "number_of_replicas": 1,
    "refresh_interval": "30s" // 降低寫入實時性要求
  },
"mappings": {
    "properties": {
      "title": { "type": "text", "analyzer": "ik_max_word" },
      "price": { "type": "double" },
      "sales": { "type": "integer" }
    }
  }
}

2.5 數據層(DB + 緩存)

  • 持久化存儲:MySQL分庫分表
  • 數據同步:Binlog → Canal → Elasticsearch
  • 冷熱分離:Redis緩存熱數據,HBase存歷史數據

分庫分表demo

-- 按商品ID分64個庫,每個庫分256表
CREATE TABLE products_%02d.t_product_%03d (
    id BIGINT PRIMARY KEY,
    title VARCHAR(255),
    price DECIMAL(10,2)
) ENGINE=InnoDB;
-- 分片路由算法:hash(product_id) % 64 → 分庫
-- hash(product_id) / 64 % 256 → 分表

3. 核心關鍵設計

3.1 分片與容量設計(水平擴展)

  • 使用 Elasticsearch,每個索引進行合理分片(Sharding)

每個分片大小控制在 20-50 GB,避免 OOM 和延遲增加

按業務維度(如商品類目、國家)分索引或路由分片

  • 分片副本(Replica)數設置,提升可用性

3.2 深度分頁性能優化

我們在使用mysql做查詢的時候,會遇到深分頁的問題,比如回表十萬次

圖片圖片

我們可以用標簽記錄法,來解決深分頁問題

其實Elasticsearch 也存在深分頁的問題,當用戶翻頁到幾百頁時,ES 會做全量掃描,性能陡降。

  • 避免傳統 from + size 深分頁
  • Search After(推薦):基于上一頁最后一個 sort_value 做游標分頁。(類似標簽記錄法思想)
  • Scroll API:適用于數據導出,不推薦用戶查詢
  • 或業務限制分頁范圍(如最多展示 100 頁)

3.3 避免緩存穿透設計

跟大家一起復習一下,什么是緩存穿透?

指查詢一個一定不存在的數據,由于緩存是不命中時需要從數據庫查詢,查不到數據則不寫入緩存,這將導致這個不存在的數據每次請求都要到數據庫去查詢,進而給數據庫帶來壓力。

在百萬并發商品搜索系統時,我們要避免這個問題,可以用布隆過濾器,簡單流程圖如下:

圖片圖片

核心業務邏輯(代碼簡單demo):

@Service
public class SearchService {
    // 布隆過濾器(存儲所有有效關鍵詞)
    @Autowired
    private BloomFilter<String> searchBloomFilter;

    // Redis緩存操作
    @Autowired
    private RedisTemplate<String, Object> redisTemplate;

    public SearchResult search(String keyword) {
        // Step 1: 布隆過濾器校驗
        if (!searchBloomFilter.mightContain(normalizeKeyword(keyword))) {
            return SearchResult.EMPTY;
        }

        // Step 2: 查詢緩存
        String cacheKey = "search:" + keyword.hashCode();
        SearchResult cached = (SearchResult) redisTemplate.opsForValue().get(cacheKey);
        if (cached != null) return cached;

        // Step 3: 查詢Elasticsearch
        SearchResult result = elasticsearchClient.search(buildQuery(keyword));

        // Step 4: 更新緩存
        if (result.isEmpty()) {
            redisTemplate.opsForValue().set(cacheKey, SearchResult.EMPTY, 30, TimeUnit.SECONDS);
        } else {
            redisTemplate.opsForValue().set(cacheKey, result, 5, TimeUnit.MINUTES);
        }

        return result;
    }

    // 關鍵詞標準化處理(如去空格、轉小寫)
    private String normalizeKeyword(String keyword) {
        return keyword.trim().toLowerCase();
    }
}
這里有個點可能要注意一下哈,布隆過濾器需要初始化一下:
// 初始化所有有效關鍵詞到布隆過濾器
@PostConstruct
public void initBloomFilter() {
    List<String> allKeywords = productDao.getAllSearchKeywords(); // 獲取所有商品標題/標簽
    allKeywords.stream()
               .map(this::normalizeKeyword)
               .forEach(searchBloomFilter::put);
}

// 動態更新(新增商品時)
public void addProduct(Product product) {
    // ... 其他業務邏輯
    searchBloomFilter.put(normalizeKeyword(product.getTitle()));
    product.getTags().forEach(tag -> 
        searchBloomFilter.put(normalizeKeyword(tag))
    );
}

3.4 GC調優

既然是百萬并發的系統設計,少不了GC調優。

盡量降低 Full GC 頻率:

  • 使用 G1 或 ZGC
  • 調大堆內存(視機器資源)
  • 避免頻繁創建臨時對象,使用對象池(如 Query 對象)

在上線前,我們要進行壓力測試,然后調出最優最優JVM參數。JVM 最優參數配置不是一成不變的,根據實際壓測,得到的

壓力測試可以用loadrunner或者jemeter,進行高并發模擬測試。

JVM 參數配置demo

# elasticsearch/jvm.options

# 基礎配置
-Xms31g
-Xmx31g
-XX:+UseG1GC
-XX:MaxGCPauseMillis=200

# G1調優參數
-XX:InitiatingHeapOccupancyPercent=35
-XX:G1ReservePercent=25
-XX:G1HeapReginotallow=4m

# 內存鎖防止Swap
-XX:+AlwaysPreTouch
-XX:+DisableExplicitGC

3.5 災備與高可用設計

高并發系統,少不了容災和高可用的設計要點,可以采取以下幾種方式:
  • 多 AZ 部署(分布在不同機房 / 可用區)
  • Elasticsearch 設置跨機房副本(replica + shard allocation awareness)
  • 服務注冊中心(如 Nacos)與服務熔斷、降級策略配合
  • 主從切換、故障自動轉移(Failover)

圖片圖片


責任編輯:武曉燕 來源: 撿田螺的小男孩
相關推薦

2023-09-08 08:10:48

2023-09-08 08:22:30

2025-09-29 04:55:00

高并發關單系統算法

2019-08-01 08:36:51

緩存系統并發

2025-06-23 08:23:04

2021-04-28 08:52:22

高并發架構設高并發系統

2019-07-31 07:36:12

架構運維技術

2025-06-04 03:15:00

高并發短鏈系統

2018-09-18 09:38:11

RPC遠程調用網絡通信

2024-11-20 13:18:21

2024-04-24 10:38:22

2020-09-02 07:22:17

JavaScript插件框架

2024-08-27 12:49:20

2025-09-28 01:50:00

2013-08-14 10:48:23

實時計算流計算

2019-08-12 10:45:54

Flutter框架Native

2015-11-13 10:25:04

京東商品搜索架構

2015-07-28 14:35:40

2020-07-27 07:53:36

高并發流量系統

2025-04-29 02:00:00

高并發系統場景
點贊
收藏

51CTO技術棧公眾號

欧美成人官网二区| 26uuu久久天堂性欧美| 久久的精品视频| 日韩高清一二三区| 日韩伦理在线| 国产精品不卡在线| 国产精品日韩二区| 中文字幕av片| 亚洲激情综合| 自拍偷拍亚洲在线| 色综合久久五月| 色综合一区二区日本韩国亚洲 | 曰本三级在线| 久久综合中文字幕| 91成人免费视频| 日韩人妻精品中文字幕| 欧美1区2区3区| 精品视频在线导航| 国产麻豆剧传媒精品国产| 天堂久久午夜av| 午夜av电影一区| 法国空姐在线观看免费| 九色视频在线观看免费播放| 国产成人亚洲综合a∨婷婷图片| 日韩av电影在线播放| 久久婷婷综合国产| 天天操夜夜操国产精品| 亚洲欧美在线免费| 日韩免费高清一区二区| 免费一级欧美片在线观看网站| 色偷偷88欧美精品久久久| 日韩精品综合在线| 中中文字幕av在线| 中文字幕在线观看不卡| 欧美重口乱码一区二区| 少妇喷水在线观看| 丰满放荡岳乱妇91ww| 国产一区二中文字幕在线看| 亚洲色成人www永久网站| 欧美freesex交免费视频| 日韩在线视频国产| 国产农村妇女精品一区| 欧美美乳视频| 亚洲欧美日韩在线高清直播| 国产精品入口麻豆| 福利片一区二区| 日韩精品一区在线| 又黄又爽又色的视频| 欧美一区=区三区| 欧美欧美欧美欧美| 亚洲一区二区三区四区五区| 久久久久国产精品www| 欧美黑人一级片| 欧美日本久久| 欧美丰满少妇xxxxx| 欧美精品一区二区蜜桃| 狠狠综合久久| 2019中文字幕在线| 五月天激情四射| 一本久道久久久| 欧美综合在线第二页| 欧美日韩乱国产| 久久免费黄色| 欧美在线视频网| 无码人妻一区二区三区线| 午夜在线一区| 国产精品高清免费在线观看| 中文字幕资源网| 国产一区二区伦理片| 99视频免费观看| 日本加勒比一区| 久久久久久久久99精品| 视频一区二区三| 男女啪啪在线观看| 亚洲欧美电影院| www.xxx麻豆| 亚洲成人看片| 7799精品视频| 奇米777第四色| 国语产色综合| 欧美xxxx14xxxxx性爽| 国产亚洲欧美精品久久久久久| 在线成人欧美| 国产精品99久久久久久久久| 亚洲综合五月天婷婷丁香| 国产精品69毛片高清亚洲| 免费观看成人高| 成人在线观看免费网站| 香蕉成人啪国产精品视频综合网| 岳毛多又紧做起爽| vam成人资源在线观看| 精品国产乱码久久久久久久| 中文字幕成人动漫| 中出一区二区| 欧美中在线观看| 国产精品无码在线播放| 9人人澡人人爽人人精品| 四虎影院一区二区三区 | 国产黄色片在线播放| 国产精品久久久久久亚洲伦 | av色在线观看| 欧美性猛片xxxx免费看久爱| 中文字幕乱妇无码av在线| 中文字幕伦av一区二区邻居| 久热99视频在线观看| 91玉足脚交嫩脚丫在线播放| 精品在线观看免费| 欧洲精品久久| a国产在线视频| 69堂成人精品免费视频| 疯狂揉花蒂控制高潮h| 91超碰国产精品| 国产精品99久久久久久久久久久久| 99在线小视频| 国产精品三级av在线播放| 国产精品12345| 精品视频一区二区三区| 一本色道久久88亚洲综合88| 国产精品自拍视频一区| 激情综合色综合久久| 欧美亚洲另类久久综合| 高清电影在线免费观看| 7777精品伊人久久久大香线蕉的 | 91久久综合| 92看片淫黄大片欧美看国产片| 欧美18xxxxx| 亚洲成a人片综合在线| 在线能看的av网站| 成人看的视频| 日本一区二区三区在线播放| 懂色av一区二区三区四区| 亚洲日本在线天堂| xxxx在线免费观看| 成人亚洲一区| 日韩免费在线视频| 美女做暖暖视频免费在线观看全部网址91 | 久久99精品久久久久久青青日本| 岛国成人毛片| 欧美一级理论片| 亚洲欧美精品aaaaaa片| 秋霞午夜av一区二区三区| 欧美日韩一区二区三区免费| 天堂av在线网| 日韩成人久久久| 中文字幕第15页| 91香蕉视频黄| 欧美国产亚洲一区| 窝窝社区一区二区| 热re99久久精品国产66热| 少妇一级淫片免费看| 午夜精品久久久久影视| 日本少妇xxxx| 夜夜嗨网站十八久久| 久久精品国产综合精品| 亚洲黄色网址| 在线精品91av| 一本大道伊人av久久综合| 国产精品久久久久永久免费观看 | 欧美激情在线一区| 欧美视频xxx| 激情成人中文字幕| 亚洲AV无码片久久精品| 日韩激情一二三区| 一区二区三区国产福利| 国产成年精品| 久久久在线免费观看| 免费国产黄色片| 欧美丝袜一区二区| 色噜噜噜噜噜噜| 国模大尺度一区二区三区| 伊人久久在线观看| 老司机在线精品视频| 茄子视频成人在线| √新版天堂资源在线资源| 欧美日本韩国一区二区三区视频| 日本午夜在线观看| 波多野洁衣一区| 国产无套内射久久久国产| 欧美色图国产精品| 91久久在线观看| gratisvideos另类灌满| 日韩精品在线视频| 97精品人妻一区二区三区| 亚洲精品国产高清久久伦理二区| 国产精品亚洲一区二区无码| 久久黄色网页| 国产日产欧美一区二区| 美女视频免费精品| 国产精品综合网站| 懂色av一区| 中文字幕日韩综合av| 亚洲a视频在线| 在线视频中文字幕一区二区| 午夜精品福利在线视频| 91美女视频网站| 欧美一级小视频| 亚洲欧美不卡| 大地资源网在线观看免费官网| 爽爽窝窝午夜精品一区二区| 成人黄色午夜影院| 亚洲天堂资源| 九九热这里只有精品6| 美女毛片在线看| 精品国产网站在线观看| 日韩欧美一级大片| 黄色成人在线播放| 欧美成人手机视频| 国产精品国产三级国产aⅴ中文 | 亚洲制服在线观看| 男人天堂欧美日韩| 嫩草影院中文字幕| 色一区二区三区四区| 精品国产一区二区三区麻豆免费观看完整版 | 国产极品久久久久久久久波多结野| 色综合导航网站| 日韩子在线观看| 亚洲日本成人网| 亚洲乱码在线观看| 欧美猛男超大videosgay| 男人午夜免费视频| 亚洲午夜国产一区99re久久| 午夜国产福利视频| 国产日韩影视精品| 国产在线观看无码免费视频| 国产精品77777竹菊影视小说| 在线观看av网页| 免费视频一区| 69堂免费视频| 亚洲美女少妇无套啪啪呻吟| 米仓穗香在线观看| 久久久久久久久99精品大| 日韩亚洲视频| 精品国产精品国产偷麻豆| 久久av二区| 奇米影视777在线欧美电影观看 | 日本激情综合网| 日韩成人免费电影| 可以在线看的黄色网址| 黄页网站一区| 欧美日韩福利在线| 亚洲视频免费| 久艹视频在线免费观看| 亚洲天堂黄色| 国产av麻豆mag剧集| 一区免费视频| 黄色一级视频在线播放| 精品二区久久| 5月婷婷6月丁香| 亚洲在线成人| 黑森林福利视频导航| 香蕉久久夜色精品| 亚洲人成色77777| 青青草成人在线观看| 亚洲老女人av| 经典三级在线一区| 一区二区三区人妻| 成人动漫视频在线| 国产白嫩美女无套久久| 91免费视频网址| 99久久久无码国产精品性 | 国产精品三区在线观看| 中文字幕一区二区三区色视频| 精品一区二区在线观看视频| 亚洲欧洲一区二区三区| 成人免费黄色小视频| 亚洲最快最全在线视频| 日韩精品视频免费播放| 天天av天天翘天天综合网| 国产精品va无码一区二区三区| 欧美日韩亚洲一区二区| 人妻中文字幕一区二区三区| 欧美日韩精品电影| 国产高清免费观看| 亚洲第一色在线| 国产中文字幕在线| 久久亚洲春色中文字幕| 免费毛片在线看片免费丝瓜视频 | 91国偷自产中文字幕久久| 91精品国产品国语在线不卡| 亚洲欧美强伦一区二区| 日韩大陆毛片av| 在线免费观看黄色网址| 欧美精品手机在线| 国产污视频在线播放| 欧美综合国产精品久久丁香| 久久久免费人体| 国产精品久久久久免费| 九九综合九九| 亚洲精品天堂成人片av在线播放| 亚洲国产三级| 视频在线观看免费高清| 成人一级片网址| 纪美影视在线观看电视版使用方法| 自拍偷拍亚洲综合| 久久久久久久久久久影院 | 天堂中文在线看| 永久555www成人免费| 日本孕妇大胆孕交无码| 国产精品成人一区二区三区吃奶| 国产不卡精品| 日韩国产欧美一区| 欧美亚韩一区| 亚洲一区二区蜜桃| 成人av在线电影| 伊人久久久久久久久久久久久久| 亚洲高清免费在线| 国产又粗又猛又爽又黄的视频一| 亚洲精品国产福利| 黄色精品免费看| 国产成人在线一区二区| 一区二区三区亚洲变态调教大结局| 日本不卡一区二区三区在线观看| 在线日韩视频| 日本特黄在线观看| 欧美国产97人人爽人人喊| 男女视频免费看| 日韩欧美国产小视频| 亚洲搞黄视频| 国产成人精品视频在线| 国产精品美女在线观看直播| 五月天av影院| 麻豆精品久久精品色综合| 一起草在线视频| 亚洲综合一区二区| 99久久精品日本一区二区免费 | 九九九九久久久久| 好看的日韩av电影| 日本女人黄色片| 亚洲视频1区2区| 在线免费一级片| 国产一区二区三区直播精品电影| 激情国产在线| 精品国产一区二区三区免费| 欧美啪啪一区| 精人妻一区二区三区| 一区二区三区色| 精品国产无码AV| 久99九色视频在线观看| 国产精品视频一区二区三区| 亚洲日本精品| 久久精品999| 蜜桃av.com| 欧美日韩一二三区| av影片在线看| 国产日韩换脸av一区在线观看| 欧美丝袜激情| 色乱码一区二区三区在线| 国产精品午夜在线| 伊人22222| 久久精品国产91精品亚洲| 日本亚洲欧洲无免费码在线| 亚洲一二三区在线| 久久99久久99小草精品免视看| 国产一区二区三区四区在线| 精品视频一区三区九区| 一区二区高清不卡| 成人有码在线视频| 午夜精品网站| av在线播放网址| 欧美午夜性色大片在线观看| 毛片在线免费| 国产乱人伦真实精品视频| 欧美岛国激情| 国产成人av免费观看| 午夜亚洲福利老司机| 伦理片一区二区三区| 国产精品欧美一区二区三区奶水 | 久久亚洲国产成人精品无码区| 福利电影一区二区三区| 一级片中文字幕| 国产香蕉一区二区三区在线视频| 久久伊人国产| 国产成人艳妇aa视频在线 | 大胆人体一区| 午夜视频久久久| 国产乱码精品一区二区三区五月婷| 美女视频黄免费| 亚洲欧美日韩图片| 精品视频一区二区三区在线观看| 欧美精品久久久久久久久久久| 久久嫩草精品久久久精品一| 一级黄色片免费| 国产69精品久久久久9999| 国产99久久| 天堂在线精品视频| 精品毛片三在线观看| 成a人v在线播放| 肥熟一91porny丨九色丨| 老司机一区二区三区| 欧美a级片免费看| 亚洲国产精品久久精品怡红院| 欧美精品高清| 国产精品自拍合集| 国产精品―色哟哟| 无码精品一区二区三区在线| 国产日韩欧美日韩大片| 亚洲国内自拍| 91精品少妇一区二区三区蜜桃臀| 亚洲精品久久久一区二区三区 | 亚洲成年网站在线观看|