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

在MySQL中使用Sphinx實現(xiàn)多線程搜索的方法

 更新時間:2015年06月26日 09:32:22   投稿:goldensun  
這篇文章主要介紹了在MySQL中使用Sphinx實現(xiàn)多線程搜索的方法,修改Sphinx的搜索引擎配置即可,需要的朋友可以參考下

 MySQL、Sphinx及許多數(shù)據(jù)庫和搜索引擎中的查詢是單線程的。比如說,在一臺32個CPU核心、16個磁盤的R910服務(wù)器上執(zhí)行一個查詢,它最多只會用到一個核心和一個磁盤。沒錯,只會使用一個。

如果查詢是CPU密集型作業(yè),那么會使用大約3%的整機CPU能力(以上述32核機器為例)。如果是磁盤密集型,則大約會使用6%的整機IO能力(也是與上例同樣的配置,16個磁盤組成RAID10或RAID0)。

我再換個說法吧。如果你在一臺單核單磁盤的機器上執(zhí)行了某個查詢,花了10秒,那么把同樣的查詢放到一臺32核16磁盤的機器上去跑,同樣需要10秒,不會有絲毫改善。

你早就知道這一點了,對吧?那么,我的問題是——有沒有辦法可以改善呢?

如果是Sphinx,太棒了,答案是有!而且不需要花上太多的工夫。你甚至不需要修改應(yīng)用和數(shù)據(jù)庫,只需要稍微改下Sphinx的配置。

計劃

首先,我來說明一下我們的目標。

Sphinx本身就支持分布式搜索,在很久以前就已經(jīng)朝著水平擴展的目標來設(shè)計。如果索引在一臺機器上放不下,可以讓多臺機器分別對不同的部分進行索引,設(shè)置一個聚合節(jié)點,負責從應(yīng)用接收請求,然后把請求再同時發(fā)給所有的數(shù)據(jù)節(jié)點,最后將它們返回的結(jié)果合并起來,返回給應(yīng)用。在應(yīng)用看起來,就好像只有一臺服務(wù)器在為它服務(wù)。


好,下面你猜怎么著?哈,我們可以把這個功能應(yīng)用到單臺機器上,讓我們的查詢快上n多倍。而且,現(xiàn)在Sphinx已經(jīng)支持這種做法了,所以我們根本不用再假裝查詢哪些遠程節(jié)點。

還有另外一個好處,配置分布式搜索以后,索引是可以并行建的!

還是有一點需要注意,雖然這種做法可以加速絕大多數(shù)的查詢,但還是有一些例外的情況。因為,并行的查詢結(jié)果仍然需要合并起來,而這個合并過程是單線程的。而且,合并包括一些CPU密集的操作,如分級、排序,甚至用GROUP BY進行COUNT,如果數(shù)據(jù)量很大,合并過程就會變成瓶頸。

要確認這一點也很簡單,只要查看Sphinx的查詢?nèi)罩?,看看每個查詢匹配的記錄數(shù)有多少,我們就心里有數(shù)了。

執(zhí)行

假設(shè)在服務(wù)器上一個索引配置如下 (很多細節(jié)都省略了):
 

復制代碼 代碼如下:

source src1
{
    type = mysql
    sql_query = SELECT id, text FROM table
}
 
index idx1
{
    type = plain
    source = src1
}
 
searchd
{
    dist_threads = 0 # default
}

現(xiàn)在我們使用有3個CPU核心和磁盤的機器來做這個索引--就是這個idx1.下面是我們更改的配置文件 :

 

復制代碼 代碼如下:

source src1
{
    type = mysql
    sql_query = SELECT id, text FROM table
}
 
source src1p0 : src1
{
    sql_query = SELECT id, text FROM table WHERE id % 3 = 0;
}
 
source src1p1 : src1
{
    sql_query = SELECT id, text FROM table WHERE id % 3 = 1;
}
 
source src1p2 : src1
{
    sql_query = SELECT id, text FROM table WHERE id % 3 = 2;
}
 
index idx1_template
{
    type = plain
    source = src1
}
 
index idx1p0 : idx1_template
{
    source = src0
}
 
index idx1p1 : idx1_template
{
    source = src1
}
 
index idx1p2 : idx1_template
{
    source = src2
}
 
index idx1
{
    type = distributed
    local = idx1p0
    local = idx1p1
    local = idx1p2
}
 
searchd
{
    dist_threads = 3
}

做完這些后,你需要重建索引. 但是現(xiàn)在idx1p0到idx1p2的索引indexer命令可以同步進行.

另外,用不同的操作來分離數(shù)據(jù)不是最好的辦法, 你可以在MYSQL中用一個輔助表來區(qū)分它們的范圍, 配合 sql_query_range使用或是別的什么, 具體根據(jù)你的數(shù)據(jù)來決定.

寫在最后

我一直都很喜歡 Sphinx,Sphinx可以如此容易的擴展到你所需要的足夠多的機器上,并且這種方式在很多年前就已經(jīng)在被使用了。然后,我想,我并沒有和我往常一樣,利用這個特性來使得在一臺機器上的查詢變得更快。嗯,這并不是在說它很慢或者其實什么,只是,查詢永遠不會太快,不是嗎?

相關(guān)文章

  • MYSQL查詢時間范圍內(nèi)的數(shù)據(jù)示例代碼

    MYSQL查詢時間范圍內(nèi)的數(shù)據(jù)示例代碼

    這篇文章主要介紹了MYSQL查詢時間范圍內(nèi)的數(shù)據(jù),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • MySQL多表連接的入門實例教程

    MySQL多表連接的入門實例教程

    這篇文章主要給大家介紹了關(guān)于MySQL多表連接的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用MySQL具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-12-12
  • Mysql中使用時間查詢的詳細圖文教程

    Mysql中使用時間查詢的詳細圖文教程

    在項目開發(fā)中,一些業(yè)務(wù)表字段經(jīng)常使用日期和時間類型,下面這篇文章主要給大家介紹了關(guān)于Mysql中使用時間查詢的相關(guān)資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-03-03
  • 解析mysql中如何獲得數(shù)據(jù)庫的大小

    解析mysql中如何獲得數(shù)據(jù)庫的大小

    本篇文章是對mysql中如何獲得數(shù)據(jù)庫的大小的解決方法進行了詳細的分析介紹,需要的朋友參考下
    2013-06-06
  • Win10安裝MySQL8壓縮包版的教程

    Win10安裝MySQL8壓縮包版的教程

    這篇文章主要介紹了Win10安裝MySQL8壓縮包版的教程,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • 談?wù)凪ySQL中的隱式轉(zhuǎn)換

    談?wù)凪ySQL中的隱式轉(zhuǎn)換

    這篇文章主要介紹了MySQL中的隱式轉(zhuǎn)換的相關(guān)資料,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下
    2020-10-10
  • mysql中字段類型轉(zhuǎn)義方式

    mysql中字段類型轉(zhuǎn)義方式

    這篇文章主要介紹了mysql中字段類型轉(zhuǎn)義方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • MySQL索引詳解及演進過程及面試題延伸

    MySQL索引詳解及演進過程及面試題延伸

    這篇文章主要介紹了MySQL索引詳解及演進過程以及延申出面試題,索引在關(guān)系型數(shù)據(jù)庫中,是一種單獨的、物理的對數(shù)據(jù)庫表中的一列或者多列值進行排序的一種存儲結(jié)構(gòu)
    2022-07-07
  • MySQL數(shù)據(jù)類型優(yōu)化原則

    MySQL數(shù)據(jù)類型優(yōu)化原則

    這篇文章主要介紹了MySQL數(shù)據(jù)類型優(yōu)化原則的相關(guān)資料,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下
    2020-11-11
  • mysql之validate_password_policy的使用

    mysql之validate_password_policy的使用

    這篇文章主要介紹了mysql之validate_password_policy的使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05

最新評論