RM新时代网站-首页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

谷歌用ML模型替代數(shù)據(jù)庫組件,或徹底改變數(shù)據(jù)系統(tǒng)開發(fā),機器學習將取代數(shù)據(jù)庫搜索

DPVg_AI_era ? 2017-12-14 16:50 ? 次閱讀

本周,谷歌團隊在arXiv上傳了一篇論文,探討用機器學習取代數(shù)據(jù)庫索引,引發(fā)了大量的關(guān)注和討論。作者還概述了如何使用這一思想來替換數(shù)據(jù)庫系統(tǒng)的其他組件和操作,包括排序和連接。如果成功,數(shù)據(jù)系統(tǒng)的開發(fā)方式將會徹底改變。

“如果這項研究取得更多的成果,將來有一天我們很可能回過頭看然后說,索引是最先倒下的,接著是其他的數(shù)據(jù)庫組件(排序算法、查詢優(yōu)化、連接),它們都逐漸被神經(jīng)網(wǎng)絡取代。”紐約州立大學布法羅分校的計算機科學和工程教授Murat Demirbas這樣說。

文章描述了一個非常有前景且十分有趣的方向,題目讀來也頗有小說的感覺——“The Case for Learned Index Structures”。

這篇論文旨在證明“機器學習模型有潛力大幅超越當前最先進的數(shù)據(jù)庫索引,提供好很多的性能”。

斯坦福大學Chirs Manning教授發(fā)表Twitter,評論稱谷歌團隊這篇論文用機器學習替代傳統(tǒng)算法,而且“一口吃掉一大塊”

用神經(jīng)網(wǎng)絡學習數(shù)據(jù)分布,讓索引“data-aware”

索引(Index),就是一種對數(shù)據(jù)庫表中一列或多列的值進行排序的結(jié)構(gòu),使用索引可以快速訪問數(shù)據(jù)庫表中的特定信息。數(shù)據(jù)庫的索引好比圖書的目錄,目錄能讓你在看書時不把整本書看完就快速找到需要的信息,索引也能讓數(shù)據(jù)庫程序迅速地找到表中的數(shù)據(jù),而不必將整個數(shù)據(jù)庫掃描完。

但是,數(shù)據(jù)庫在應用索引時,對數(shù)據(jù)本身并不了解,數(shù)據(jù)相當于一個黑盒,而不了解數(shù)據(jù)的分布,造成了很大的浪費。

舉例來說,如果鍵的范圍在0到500m之間,比起用哈希,直接把鍵當索引速度可能更快。如果知道了數(shù)據(jù)的累積分布函數(shù)(CDF),“CDF*鍵*記錄大小”可能約等于要查找的記錄的位置,這一點也適用于其他數(shù)據(jù)分布的情況。

數(shù)據(jù)的累積分布函數(shù)(CDF)可以作為索引

作者在論文中表示,精確了解數(shù)據(jù)分布,可以大幅優(yōu)化當前數(shù)據(jù)庫系統(tǒng)使用的幾乎所有索引結(jié)構(gòu)。

但是,精確了解數(shù)據(jù)分布,數(shù)據(jù)庫就成了“白盒”,失去了可重用性。這樣一來就需要檢查數(shù)據(jù),每次都從頭開始設計索引。

于是,谷歌研究人員想到了機器學習方法,并使用其中最強的一種——神經(jīng)網(wǎng)絡,去學習數(shù)據(jù)分布,并用學到的知識預測數(shù)據(jù)的分布。

這樣一種折中的方法,讓數(shù)據(jù)索引變得“data-aware”,由此獲得性能的提升。

如果成功,數(shù)據(jù)庫開發(fā)方式可能徹底改變

他們將神經(jīng)網(wǎng)絡應用于三種索引類型:B樹,用于處理范圍查詢;哈希映射(Hash-map),用于點查找查詢;以及Bloom-filter,用于設置包含檢查。下面著重介紹一下作者如何用神經(jīng)網(wǎng)絡替代B樹。

B樹提供了一種有效的分層索引。從概念上講,B-tree將一個鍵映射到一個頁面。因此,我們可以用一個模型,也進行鍵的位置映射,而對于錯誤范圍,我們可以做一個二進制搜索(或擴展環(huán)搜索)的變體來定位頁面。

要知道m(xù)in_error和max-error,就用擁有的數(shù)據(jù)來訓練模型。數(shù)據(jù)是靜態(tài)的,神經(jīng)網(wǎng)絡進行預測,然后從這些錯誤中學習。即使簡單的邏輯回歸也可以用于簡單的分布。

在測試時,作者將機器學習索引與B樹進行比較,他們使用了3個真實世界數(shù)據(jù)集,其中網(wǎng)絡日志數(shù)據(jù)集(Weblogs)對索引而言極具挑戰(zhàn)性,包含了200多萬個日志條目,是很多年的大學網(wǎng)站的請求,而且每個請求都有單一的時間戳,數(shù)據(jù)中含有非常復雜的時間模式,包括課程安排、周末、假期、午餐休息、部門活動、學期休息,這些都是非常難以學習的。

從上圖可見,對于網(wǎng)絡日志數(shù)據(jù),機器學習索引帶來的速度提升最高達到了53%,對應的體積也有76%的縮小,相比之下誤差范圍稍有加大。

用機器學習模型替換B樹的好處是:

  • 索引結(jié)構(gòu)更小:更少的主內(nèi)存或L1緩存

  • 查找速度更快:因為索引變小了

  • 更強的并行性(TPU),而不是B-樹中的分層if語句

這里有一個關(guān)鍵點,那就是用計算換內(nèi)存,計算越來越便宜,CPU-SIMD/GPU/TPU的功能越來越強大,作者甚至指出,“運行神經(jīng)網(wǎng)絡的高昂成本在未來可以忽略不計——谷歌TPU能夠在一個周期內(nèi)最高完成上萬次神經(jīng)網(wǎng)絡運算。有人聲稱,到2025年CPU的性能將提高1000倍,基于摩爾定律的CPU在本質(zhì)上將不復存在。利用神經(jīng)網(wǎng)絡取代分支重索引結(jié)構(gòu),數(shù)據(jù)庫可以從這些硬件的發(fā)展趨勢中受益。

論文還介紹了幾個策略來提高機器學習索引的性能,包括使用遞歸模型索引、分層模型和混合模型。機器學習方法都帶來了能效提升,具體的評估結(jié)果請參考論文。

需要指出,作者并不認為機器學習索引結(jié)構(gòu)可以完全替代傳統(tǒng)索引?!拔覀冋撌隽艘环N建立索引的新方法,它完善了現(xiàn)有的研究,并且為該領域數(shù)十年的研究開辟了一個新方向?!?/span>

作者還概述了如何使用這一思想來替換數(shù)據(jù)庫系統(tǒng)的其他組件和操作,包括排序和連接。如果成功,數(shù)據(jù)系統(tǒng)的開發(fā)方式將會徹底改變。

論文:The Case for Learned Index Structures

摘要

索引就是模型:B-Tree-Index可以被看作一個將鍵(key)映射到排序數(shù)組中記錄位置的模型,哈希索引可以被看作將鍵映射到未分類數(shù)組中記錄位置的模型,而BitMap-Index可以被看作查看數(shù)據(jù)記錄是否存在的模型。

在這篇探索性研究論文中,我們從這個前提出發(fā),假設所有現(xiàn)有的索引結(jié)構(gòu)都可以用其他類型的模型來代替,包括深度學習模型,也即文中所謂的“機器學習索引”(learned indexes)。

本文關(guān)鍵思想是,一個模型可以學習排序順序或查找鍵的結(jié)構(gòu),并使用這個信號來有效預測記錄的位置或記錄是否存在。我們從理論上分析了在哪些條件下機器學習索引的性能優(yōu)于傳統(tǒng)索引結(jié)構(gòu),描述了設計機器學習索引的主要挑戰(zhàn)。

我們在幾個真實世界的數(shù)據(jù)集上做了測試,初步結(jié)果表明,通過使用神經(jīng)網(wǎng)絡,我們在速度上能比緩存優(yōu)化的B樹快70%,同時內(nèi)存節(jié)省了一個數(shù)量級。更重要的是,我們相信用機器學習模型取代數(shù)據(jù)管理系統(tǒng)核心組件的想法,對未來的系統(tǒng)設計有著深遠的影響,這項工作僅僅展現(xiàn)了未來無限可能的一瞥。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 谷歌
    +關(guān)注

    關(guān)注

    27

    文章

    6161

    瀏覽量

    105300
  • 數(shù)據(jù)庫
    +關(guān)注

    關(guān)注

    7

    文章

    3794

    瀏覽量

    64360
  • 機器學習
    +關(guān)注

    關(guān)注

    66

    文章

    8406

    瀏覽量

    132561

原文標題:【機器學習吃掉算法】谷歌用ML模型替代數(shù)據(jù)庫組件,或徹底改變數(shù)據(jù)系統(tǒng)開發(fā)

文章出處:【微信號:AI_era,微信公眾號:新智元】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    數(shù)據(jù)庫數(shù)據(jù)恢復—Mysql數(shù)據(jù)庫表記錄丟失的數(shù)據(jù)恢復流程

    Mysql數(shù)據(jù)庫故障: Mysql數(shù)據(jù)庫表記錄丟失。 Mysql數(shù)據(jù)庫故障表現(xiàn): 1、Mysql數(shù)據(jù)庫表中無任何數(shù)據(jù)
    的頭像 發(fā)表于 12-16 11:05 ?106次閱讀
    <b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復—Mysql<b class='flag-5'>數(shù)據(jù)庫</b>表記錄丟失的<b class='flag-5'>數(shù)據(jù)</b>恢復流程

    數(shù)據(jù)庫數(shù)據(jù)恢復—MYSQL數(shù)據(jù)庫ibdata1文件損壞的數(shù)據(jù)恢復案例

    mysql數(shù)據(jù)庫故障: mysql數(shù)據(jù)庫文件ibdata1、MYI、MYD損壞。 故障表現(xiàn):1、數(shù)據(jù)庫無法進行查詢等操作;2、使用mysqlcheck和myisamchk無法修復數(shù)據(jù)庫
    的頭像 發(fā)表于 12-09 11:05 ?127次閱讀

    數(shù)據(jù)庫數(shù)據(jù)恢復—通過拼接數(shù)據(jù)庫碎片恢復SQLserver數(shù)據(jù)庫

    一個運行在存儲上的SQLServer數(shù)據(jù)庫,有1000多個文件,大小幾十TB。數(shù)據(jù)庫每10天生成一個NDF文件,每個NDF幾百GB大小。數(shù)據(jù)庫包含兩個LDF文件。 存儲損壞,數(shù)據(jù)庫
    的頭像 發(fā)表于 10-31 13:21 ?198次閱讀
    <b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復—通過拼接<b class='flag-5'>數(shù)據(jù)庫</b>碎片恢復SQLserver<b class='flag-5'>數(shù)據(jù)庫</b>

    科技云報到:大模型時代下,向量數(shù)據(jù)庫的野望

    科技云報到:大模型時代下,向量數(shù)據(jù)庫的野望
    的頭像 發(fā)表于 10-14 17:18 ?246次閱讀

    Oracle數(shù)據(jù)恢復—異常斷電后Oracle數(shù)據(jù)庫報錯的數(shù)據(jù)恢復案例

    Oracle數(shù)據(jù)庫故障: 機房異常斷電后,Oracle數(shù)據(jù)庫報錯:“system01.dbf需要更多的恢復來保持一致性,數(shù)據(jù)庫無法打開”。數(shù)據(jù)
    的頭像 發(fā)表于 09-30 13:31 ?298次閱讀
    Oracle<b class='flag-5'>數(shù)據(jù)</b>恢復—異常斷電后Oracle<b class='flag-5'>數(shù)據(jù)庫</b>啟<b class='flag-5'>庫</b>報錯的<b class='flag-5'>數(shù)據(jù)</b>恢復案例

    數(shù)據(jù)庫數(shù)據(jù)恢復—SQL Server數(shù)據(jù)庫出現(xiàn)823錯誤的數(shù)據(jù)恢復案例

    SQL Server數(shù)據(jù)庫故障: SQL Server附加數(shù)據(jù)庫出現(xiàn)錯誤823,附加數(shù)據(jù)庫失敗。數(shù)據(jù)庫沒有備份,無法通過備份恢復數(shù)據(jù)庫。
    的頭像 發(fā)表于 09-20 11:46 ?338次閱讀
    <b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復—SQL Server<b class='flag-5'>數(shù)據(jù)庫</b>出現(xiàn)823錯誤的<b class='flag-5'>數(shù)據(jù)</b>恢復案例

    恒訊科技分析:sql數(shù)據(jù)庫怎么?

    SQL數(shù)據(jù)庫的使用通常包括以下幾個基本步驟: 1、選擇數(shù)據(jù)庫系統(tǒng): 選擇適合您需求的SQL數(shù)據(jù)庫系統(tǒng),如MySQL、PostgreSQL、Microsoft SQL Server、SQLite等
    的頭像 發(fā)表于 07-15 14:40 ?346次閱讀

    數(shù)據(jù)庫數(shù)據(jù)恢復—SQL Server數(shù)據(jù)庫所在分區(qū)空間不足報錯的數(shù)據(jù)恢復案例

    SQL Server數(shù)據(jù)庫數(shù)據(jù)恢復環(huán)境: 某品牌服務器存儲中有兩組raid5磁盤陣列。操作系統(tǒng)層面跑著SQL Server數(shù)據(jù)庫,SQL Server
    的頭像 發(fā)表于 07-10 13:54 ?479次閱讀

    鴻蒙開發(fā)接口數(shù)據(jù)管理:【@ohos.data.rdb (關(guān)系型數(shù)據(jù)庫)】

    關(guān)系型數(shù)據(jù)庫(Relational Database,RDB)是一種基于關(guān)系模型來管理數(shù)據(jù)數(shù)據(jù)庫。關(guān)系型數(shù)據(jù)庫基于SQLite
    的頭像 發(fā)表于 06-10 18:35 ?1300次閱讀

    模型卷價格,向量數(shù)據(jù)庫“卷”什么?

    被大模型“帶飛”這一年,向量數(shù)據(jù)庫才剛剛寫下序言
    的頭像 發(fā)表于 05-23 09:24 ?1768次閱讀
    大<b class='flag-5'>模型</b>卷價格,向量<b class='flag-5'>數(shù)據(jù)庫</b>“卷”什么?

    HarmonyOS開發(fā)案例:【搭建關(guān)系型數(shù)據(jù)庫】(4)

    本節(jié)介紹如何調(diào)用關(guān)系型數(shù)據(jù)庫接口在本地搭建數(shù)據(jù)庫,并讀寫相應的用戶數(shù)據(jù)。
    的頭像 發(fā)表于 05-11 10:27 ?869次閱讀
    HarmonyOS<b class='flag-5'>開發(fā)</b>案例:【搭建關(guān)系型<b class='flag-5'>數(shù)據(jù)庫</b>】(4)

    數(shù)據(jù)庫數(shù)據(jù)恢復—raid5陣列上層Sql Server數(shù)據(jù)庫數(shù)據(jù)恢復案例

    數(shù)據(jù)庫數(shù)據(jù)恢復環(huán)境: 5塊硬盤組建一組RAID5陣列,劃分LUN供windows系統(tǒng)服務器使用。windows系統(tǒng)服務器內(nèi)運行了Sql Server
    的頭像 發(fā)表于 05-08 11:43 ?503次閱讀
    <b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復—raid5陣列上層Sql Server<b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復案例

    ?通過Modbus讀寫數(shù)據(jù)庫中的數(shù)據(jù)

    本文是數(shù)據(jù)庫數(shù)據(jù)轉(zhuǎn)為Modbus服務端/從站,實現(xiàn)數(shù)據(jù)庫內(nèi)的數(shù)據(jù)也可以走Modbus協(xié)議通過網(wǎng)口
    發(fā)表于 03-14 13:44

    數(shù)據(jù)庫數(shù)據(jù)恢復】Oracle數(shù)據(jù)庫ASM實例無法掛載的數(shù)據(jù)恢復案例

    oracle數(shù)據(jù)庫ASM磁盤組掉線,ASM實例不能掛載。數(shù)據(jù)庫管理員嘗試修復數(shù)據(jù)庫,但是沒有成功。
    的頭像 發(fā)表于 02-01 17:39 ?518次閱讀
    【<b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復】Oracle<b class='flag-5'>數(shù)據(jù)庫</b>ASM實例無法掛載的<b class='flag-5'>數(shù)據(jù)</b>恢復案例

    2024年,國產(chǎn)數(shù)據(jù)庫正醞釀新變局!

    隨著互聯(lián)網(wǎng)、5G、AI技術(shù)的飛速發(fā)展,海量數(shù)據(jù)的持續(xù)激增,數(shù)據(jù)資產(chǎn)的核心價值正在凸顯,大數(shù)據(jù)代數(shù)據(jù)庫行業(yè)也迎來了快速增長。 作為數(shù)據(jù)存儲、
    的頭像 發(fā)表于 01-05 13:18 ?449次閱讀
    2024年,國產(chǎn)<b class='flag-5'>數(shù)據(jù)庫</b>正醞釀新變局!
    RM新时代网站-首页