首頁>科技>

阿里妹導讀:隨著大資料的爆發,圖資料的應用規模不斷增長,現有的圖計算系統仍然存在一定的侷限。阿里巴巴擁有全球最大的商品知識圖譜,在豐富的圖場景和真實應用的驅動下,阿里巴巴達摩院智慧計算實驗室研發並開源了全球首個一站式超大規模分散式圖計算平臺GraphScope,併入選中國科學技術協會“科創中國”平臺。本文詳解圖計算的原理和應用及GraphScope的架構設計。

文末福利:GraphScope開源釋出會。

一 什麼是圖計算

圖資料對一組物件(頂點)及其關係(邊)進行建模,可以直觀、自然地表示現實世界中各種實體物件以及它們之間的關係。在大資料場景下,社交網路、交易資料、知識圖譜、交通和通訊網路、供應鏈和物流規劃等都是典型的以圖建模的例子。圖 1 顯示了阿里巴巴在電商場景下的圖資料,其中有各種型別的頂點(消費者、賣家、物品和裝置)和邊(表示了購買、檢視、評論等關係)。此外,每個頂點還有豐富的屬性資訊相關聯。

圖 1:阿里巴巴電商場景圖資料示例

實際場景中的這種圖資料通常包含數十億個頂點和數萬億條邊。除了規模大之外,這個圖的持續更新速度也非常快,每秒可能有近百萬的更新。隨著近年來圖資料應用規模的不斷增長,探索圖資料內部關係以及在圖資料上的計算受到了越來越多的關注。根據圖計算的不同目標,大致可以分為互動查詢、圖分析和基於圖的機器學習三類任務。

1 圖的互動查詢

圖 2:左,金融反欺詐示例;右,圖學習示例。

在圖計算的應用中,業務通常需要以探索的方式來檢視圖資料,以進行一些問題的及時定位和分析某個深入的資訊,如圖 2 (左)中的(簡化)圖模型可被用於金融反欺詐(信用卡非法套現)檢測。透過使用偽造的識別符號,“犯罪分子”可以從銀行獲得短期信用(頂點 4)。他嘗試透過商家(頂點3)的幫助,以虛假購買( 邊 2->3)來兌現貨幣。一旦從銀行(頂點4)收到付款(邊 4->3),商家再透過其名下的多個帳戶將錢(透過邊 3->1 和 1->2)退還給“犯罪分子”。這種模式最終形成一個圖上的閉環(2->3->1...->2)。真實場景中,圖資料在線上的規模可能包含數十億個頂點(例如,使用者)和數千億至萬億條邊(例如,支付交易),並且整個欺詐過程可能涉及到許多實體之間包含各種約束的動態交易鏈,因此需要複雜的實時互動分析才能很好的識別。

2 圖分析

關於圖分析計算的研究已經持續了數十年,產生了很多圖分析的演算法。典型的圖分析演算法包括經典圖演算法(例如,PageRank、最短路徑和最大流),社群檢測演算法(例如,最大團/clique、聯通量計算、Louvain 和標籤傳播),圖挖掘演算法(例如,頻繁集挖掘和圖的模式匹配)。由於圖分析演算法的多樣性和分散式計算的複雜性,分散式圖分析演算法往往需要遵循一定的程式設計模型。當前的程式設計模型有點中心模型“Think-like-vertex”,基於矩陣的模型和基於子圖的模型等。在這些模型下,湧現出各種圖分析系統,如 Apache Giraph、Pregel、PowerGraph、Spark GraphX、GRAPE 等。

3 基於圖的機器學習

經典的 Graph Embedding 技術,例如 Node2Vec 和 LINE,已在各種機器學習場景中廣泛使用。近年來提出的圖神經網路(GNN),更是將圖中的結構和屬性資訊與深度學習中的特徵相結合。GNN 可以為圖中的任何圖結構(例如,頂點,邊或整個圖)學習低維表徵,並且生成的表徵可以被許多下游圖相關的機器學習任務進行分類、鏈路預測、聚類等。圖學習技術已被證明在許多與圖相關的任務上具有令人信服的效能。與傳統的機器學習任務不同,圖學習任務涉及圖和神經網路的相關操作(見圖 2 右),圖中的每個頂點都使用與圖相關的操作來選擇其鄰居,並將其鄰居的特徵與神經網路操作進行聚合。

二 圖計算:下一代人工智慧的基石

不僅僅是阿里巴巴,近年來圖資料和計算技術一直是學術界和工業界的熱點。特別是,在過去的十年中,圖計算系統的效能已提高了 10~100 倍,並且系統仍在變得越來越高效,這使得透過圖計算來加速AI和大資料任務成為了可能。實際上,由於圖能十分自然地表達各種複雜型別的資料,並且可以為常見的機器學習模型提供抽象。與密集張量相比,圖能提供更豐富的語義和更全面的最佳化功能。此外,圖是稀疏高維資料的自然表達,並且圖卷積網路(GCN)和圖神經網路(GNN)中越來越多的研究證明,圖計算是對機器學習的有效補充,在結果的可解釋性、深層次推理因果等方面將扮演越來越重要的作用。

圖 3:圖計算在AI各個領域具有廣闊的應用前景

可以預見,圖計算將在下一代人工智慧的各種應用中發揮重要作用,包括反欺詐,智慧物流,城市大腦,生物資訊學,公共安全,公共衛生,城市規劃,反洗錢,基礎設施,推薦系統,金融技術和供應鏈等領域。

三 圖計算現狀

經過這些年的發展,已有針對各種圖計算需求的多種系統和工具。例如在互動查詢方面,有圖資料庫Neo4j、ArangoDB和OrientDB等、也有分散式系統和服務JanusGraph、Amazon Neptune和Azure Cosmos DB等;在圖分析方面,有 Pregel、Apache Giraph、Spark GraphX、PowerGraph 等系統;在圖學習上有 DGL、pytorch geometric 等。儘管如此,面對豐富的圖資料和多樣化的圖場景,有效利用圖計算增強業務效果依然面臨著巨大的挑戰:

現實生活中的圖計算場景多樣,且通常非常複雜,涉及到多種型別的圖計算。現有的系統主要是為特定型別的圖計算任務設計的。因此,使用者必須將複雜的任務分解為涉及許多系統的多個作業。在系統之間可能會產生大量例如整合、IO、格式轉換、網路和儲存方面的額外開銷。難以開發大型圖計算的應用。為了開發圖計算的應用,使用者通常使用簡單易用的工具(例如 Python 中的 NetworkX 和 TinkerPop)在一臺機器上從小規模圖資料開始。但是,對於普通使用者而言,擴充套件其單機解決方案到並行環境處理大規模圖是極其困難的。現有的用於大規模圖的分散式系統通常遵循不同的程式設計模型,並且缺乏單機庫(例如 NetworkX)中豐富的即用演算法/外掛庫。這使得分散式圖計算的門檻過高。處理大圖的規模和效率仍然有限。例如,由於遊歷模式的高度複雜性,現有的互動式圖查詢系統無法並行執行 Gremlin 查詢。對於圖分析系統,傳統的點中心程式設計模型使圖級別的現有最佳化技術不再可用。此外,許多現有系統也基本未在編譯器級別上做過最佳化。

下面我們透過一個具體的示例看看現有系統的侷限性。

1 示例:論文分類預測

資料集 ogbn-mag 是一個來自於微軟學術的資料集。資料中包含四種類型的點,分別表示論文、作者、機構、研究領域;在這些點之間有表示關係的四種邊:分別是作者“撰寫”了論文,論文“引用”了另一篇論文,作者“隸屬於”某個機構,和論文“屬於”某個研究領域。這個資料很自然的可以用圖來建模。

一個使用者期望在這個圖上對 2014-2020 年間發表的“論文”做一個分類任務,期望能根據論文在資料圖中的結構屬性、自身的主題特徵、以及 kcore、三角計數 triangle-counting 等團聚度的衡量引數,將其歸類並預測文章的主題類別。實際上,這是一個十分常見和有意義的任務,這個預測由於考慮了論文的引用關係和論文的主題,可以幫助研究人員更好的發現領域內的潛在合作和研究熱點。

讓我們分解一下這個計算任務:首先我們需要對論文及其相關的點邊做一個根據年份的篩選,再需要在這個圖上計算 kcore、triangle-counting 等全圖計算,最後將這兩個引數和圖上的原始特徵一起,放入一個機器學習框架進行分類訓練和預測。我們發現當前已有的系統並不能很好的端到端解決這個問題,我們只能透過將多個系統組織成一個 pipeline 的形式執行:

圖 4:論文分類預測多系統組成的工作流

這個任務看起來是解決了,實際上這樣流水線的方案背後隱藏著許多問題。例如多個系統之間互相獨立和割裂,中間資料頻繁落盤進行系統間的資料傳遞;圖分析的程式不是宣告性語言,沒有固定正規化;圖的規模影響機器學習框架的效率等等。這些都是我們在現實圖計算場景中常遇到的問題,總結一下可以概括為以下三點:

圖計算問題十分複雜,計算模式多樣,解決方案碎片化。圖計算學習難度強,成本大,門檻高。圖的規模和資料量大,計算複雜,效率低。

為了解決以上的問題,我們設計並研發了一站式開源圖計算系統:GraphScope。

四 GraphScope 是什麼

GraphScope 是阿里巴巴達摩院智慧計算實驗室研發並開源的一站式圖計算平臺。依託於阿里海量資料和豐富場景,與達摩院的高水平研究,GraphScope 致力於針對實際生產中圖計算的上述挑戰,提供一站式高效的解決方案。

GraphScope 提供 Python 客戶端,能十分方便的對接上下游工作流,具有一站式、開發便捷、效能極致等特點。它具有高效的跨引擎記憶體管理,在業界首次支援 Gremlin 分散式編譯最佳化,同時支援演算法的自動並行化和支援自動增量化處理動態圖更新,提供了企業級場景的極致效能。在阿里巴巴內部和外部的應用中,GraphScope 已經證明在多個關鍵網際網路領域(如風控,電商推薦,廣告,網路安全,知識圖譜等)實現重要的業務新價值。

GraphScope 集合了達摩院的多項學術研究成果,其中的核心技術曾獲得資料庫領域頂級學術會議 SIGMOD2017 最佳論文獎、VLDB2017 最佳演示獎、VLDB2020 最佳論文提名獎、世界人工智慧創新大賽SAIL獎。GraphScope 的互動查詢引擎的論文也已被 NSDI 2021 錄用,即將發表。還有其它圍繞 GraphScope 的十多項研究成果發表在領域頂級的學術會議或期刊上,如 TODS、SIGMOD、VLDB、KDD 等。

1 架構介紹

圖 5:GraphScope 系統架構圖

GraphScope 的底層是一個分散式記憶體資料管理系統 vineyard[1]。vineyard 也是我們開源的一個專案,它提供了高效和豐富的 IO 介面負責與更底層的檔案系統互動,它提供了高效和高層次的資料抽象(包括但不限於圖,tensor,vector 等),支援管理資料的分割槽、元資料等,可以為上層應用提供本機零複製的資料讀取。正是這一點支援了 GraphScope 的一站式能力:在跨引擎之間,圖資料按分割槽的形式存在於 vineyard,由 vineyard 統一管理。

中間是引擎層,分別由互動式查詢引擎 GIE,圖分析引擎 GAE,和圖學習引擎 GLE 組成,我們將在後續的章節中詳細介紹。

最上層是開發工具和演算法庫。GraphScope 提供了各類常用的分析演算法,包括連通性計算類、社群發現類和 PageRank、中心度等數值計算類的演算法,後續會不斷擴充套件演算法包,在超大規模圖上提供與 NetworkX 演算法庫相容的分析能力。此外也提供了豐富的圖學習演算法包,內建支援 GraphSage、DeepWalk、LINE、Node2Vec 等演算法。

2 重點問題:論文分類預測

有了一站式計算平臺 GraphScope,我們可以用一種更簡單的方式解決前面示例中的問題。

GraphScope 提供 Python客戶端, 讓資料科學家可以在自己熟悉的環境中完成所有圖計算相關的工作。開啟 Python 後,我們首先需要建立一個 GraphScope 會話。

import graphscopefrom graphscope.dataset.ogbn_mag import load_ogbn_magsess = graphscope.sesson()g = load_ogbn_mag(sess, "/testingdata/ogbn_mag/")

在上面的程式碼中,我們建立了一個 GraphScope 的 session,並載入了圖資料。

GraphScope 面向雲原生設計,一個 session 的背後對應了一組 k8s 的資源,該session 負責這個會話中所有資源的申請和管理。具體來說,在使用者這行程式碼的背後,session首先會請求一個後端總入口 Coordinator 的 pod。Coordinator 負責跟 Python 客戶端的所有通訊,在完成自身的初始化後,它會拉起一組引擎 pod。這組 pod 中每一個 pod 都有一個 vineyard 例項,共同組成一個分散式記憶體管理層;同時,每一個 pod 中都有 GIE、GAE、GLE 三個引擎,它們的啟停狀態由 Coordinator 在後續按需管理。當這組 pod 拉起並與 Coordinator 建立穩定連線、完成健康檢查後,Coordinator 會返回狀態到客戶端,告訴使用者,session 已拉起成功,資源就緒可以開始截圖或計算了。

interactive = sess.gremlin(g)# count the number of papers two authors (with id 2 and 4307) have co-authoredpapers = interactive.execute("g.V().has('author', 'id', 2).out('writes').where(__.in('writes').has('id', 4307)).count()").one()

首先我們在圖 g 上建立了一個互動式查詢物件 interactive。這個物件在引擎 pod 中拉起了一組互動式查詢引擎 GIE。接著下面是一個標準的 Gremlin 查詢語句,使用者想在這個資料中檢視兩個具體作者的合作論文。這個 Gremlin 語句會發送給 GIE 引擎進行拆解和執行。

GIE 引擎由並行化 Compiler、記憶體和排程管理、Operator 執行時、自適應的遊歷策略和分散式 Dataflow 引擎等核心元件組成。在收到互動式查詢的語句後,該語句首先會被 Compiler 拆分,編譯成多個執行運算元。這些運算元再以分散式資料流的模型被驅動和執行,在這個過程中,每一個持有分割槽資料的計算節點都跑一份該資料流的複製,並行處理本分割槽的資料,並在過程中按需進行資料交換,從而並行化的執行 Gremlin 查詢。

Gremlin 複雜的語法下,遊歷策略至關重要並影響著查詢的並行度,它的選擇直接影響著資源的佔用和查詢的效能。只靠簡單的 BFS 或是 DFS 在現實中並不能滿足需求。最優的遊歷策略往往需要根據具體的資料和查詢動態調整和選擇。GIE 引擎提供了自適應的遊歷策略配置,根據查詢資料、拆解的 Op 和 Cost 模型選擇遊歷策略,以達到運算元執行的高效性。

# extract a subgraph of publication within a time rangesub_graph = interactive.subgraph("g.V().has('year', inside(2014, 2020)).outE('cites')")# project the projected graph to simple graph.simple_g = sub_graph.project_to_simple(v_label="paper", e_label="cites")ret1 = graphscope.k_core(simple_g, k=5)ret2 = graphscope.triangles(simple_g)# add the results as new columns to the citation graphsub_graph = sub_graph.add_column(ret1, {"kcore": "r"})sub_graph = sub_graph.add_column(ret2, {"tc": "r"})

在透過一系列單點檢視的互動式查詢後,使用者透過以上語句開始做圖分析任務。

首先它透過一個 subgraph 的操作子從原圖中根據篩選條件抽取了一個子圖。這個操作子的背後,是互動式引擎 GIE 執行了一個查詢,再將結果圖寫入了 vineyard。

然後使用者在這個新圖上抽取了 label 為論文的點和他們之間關係為引用(cites)的邊,產出了一張同構圖,並在上面呼叫了 GAE 的內建演算法 k-core 和三角計數 triangles 在全圖做了分析型計算。產出結果後,這兩個結果被作為點上的屬性加回了原圖。這裡,藉助於 vineyard 元資料管理和高層資料抽象,新的 sub_graph 是透過原圖上新增一列的變換來生成的,不需要重建整張圖的全部資料。

GAE 引擎核心繼承了曾獲得 SIGMOD2017 最佳論文獎的 GRAPE 系統[2]。它由高效能執行時、自動並行化元件、多語言支援的 SDK 等元件組成。上面的例子用到了 GAE 自帶的演算法,此外,GAE 也支援使用者十分簡單的編寫自己的演算法並在其上即插即用。使用者以基於子圖程式設計的 PIE 模型編寫演算法,或者重用已有圖演算法,而不用考慮分散式細節,由 GAE 來做自動並行化,大幅降低了分散式圖計算對使用者的高門檻。目前,GAE 支援使用者透過C++、Python(後續將支援 Java)等多語言編寫自己的演算法邏輯,即插即用在分散式環境。GAE 的高效能執行時基於 MPI,對通訊、資料排布,硬體特徵做了十分細緻的最佳化,以達到極致效能。

# define the features for learningpaper_features = []for i in range(128):    paper_features.append("feat_" + str(i))paper_features.append("kcore")paper_features.append("tc")# launch a learning engine.lg = sess.learning(sub_graph, nodes=[("paper", paper_features)],                  edges=[("paper", "cites", "paper")],                  gen_labels=[                      ("train", "paper", 100, (1, 75)),                      ("val", "paper", 100, (75, 85)),                      ("test", "paper", 100, (85, 100))                  ])

接下來我們開始用圖學習引擎為論文分類。首先我們配置將資料中論文類節點的 128 維特徵以及我們在上一步中計算出的 kcore 和 triangles 兩個屬性共同作為訓練特徵。然後我們從 session 中拉起圖學習引擎 GIE。在拉起 GIE中 圖 lg 時,我們配置了圖資料,特徵屬性,指定了哪一類的邊,以及將點集劃分為了訓練集、驗證集和測試集。

from graphscope.learning.examples import GCNfrom graphscope.learning.graphlearn.python.model.tf.trainer import LocalTFTrainerfrom graphscope.learning.graphlearn.python.model.tf.optimizer import get_tf_optimizer# supervised GCN.def train_and_test(config, graph):    def model_fn():        return GCN(graph, config["class_num"], ...)    trainer = LocalTFTrainer(model_fn,                             epoch=config["epoch"]...)    trainer.train_and_evaluate()config = {...}train_and_test(config, lg)

然後我們透過上面的程式碼選用模型以及做一些訓練相關的引數配置就可以十分便捷的用 GLE 開始做圖分類任務。

GLE 引擎包含 Graph 與 Tensor 兩部分,分別由各種 Operator 構成。Graph 部分涉及圖資料與深度學習的對接,如按 Batch 迭代、取樣和負取樣等,支援同構圖和異構圖。Tensor 部分則由各類深度學習運算元構成。在計算模組中,圖學習任務被拆解成一個個運算元,運算元再被執行時分散式的執行。為了進一步最佳化取樣效能,GLE 將快取遠端鄰居、經常訪問的點、屬性索引等,以加快每個分割槽中頂點及其屬性的查詢。GLE 採用支援異構硬體的非同步執行引擎,這使 GLE 可以有效地重疊大量併發操作,例如 I/O、取樣和張量計算。GLE 將異構計算硬體抽象為資源池(例如 CPU 執行緒池和 GPU 流池),並協作排程細粒度的併發任務。

五 效能

GraphScope 不僅在易用性上一站式的解決了圖計算問題,在效能上也達到極致,滿足了企業級需求。我們使用 LDBC Benchmark 對 GraphScope 的效能進行了評估和對比測試。

如圖 6 所示,在互動式查詢測試 LDBC SNB Benchmark上,單節點部署的 GraphScope 與開源系統 JanusGraph 相比,多數查詢快一個數量級以上;在分散式部署下,GraphScope 的互動式查詢基本能達到線性加速的擴充套件性。

圖 6:GraphScope 互動式查詢效能

在圖分析測試 LDBC GraphAnalytics Benchmark 上,GraphScope 與 PowerGraph 以及其他最新系統比較,幾乎在所有演算法和資料集的組合中居於領先水平。在某些演算法和資料集上,跟其他平臺比較最低也有五倍的效能優勢。區域性資料見下圖。

圖 7:GraphScope 圖分析效能

關於實驗的設定、重現和完整的效能比較可以參見互動式查詢效能[3]和圖分析效能[4]。

六 擁抱開源

GraphScope 的白皮書、程式碼已經在 github.com/alibaba/graphscope 開源[5],專案遵守 Apache License 2.0。歡迎大家 star、試用,參與到圖計算中來。也歡迎大家貢獻程式碼,一起打造業界最好的圖計算系統。我們的目標是持續更新該專案,不斷提升功能的完整性和系統的穩定性。也歡迎大家關注網站 graphscope.io 來跟進專案的最新狀態。

GraphScope開源釋出會

帶你入門一站式圖計算平臺

基於阿里巴巴的海量資料和豐富場景與智慧引擎的研究,阿里巴巴達摩院智慧計算實驗室研發並開源了包含圖互動查詢、圖分析、圖學習的一站式圖計算引擎GraphScope。在阿里巴巴內部和外部的應用中,GraphScope已經在多個關鍵領域(如風控,電商推薦,廣告,網路安全,知識圖譜等)實現其重要的業務新價值。本次釋出會從GraphScope產生的背景入手,40分鐘帶你入門圖計算,瞭解GraphScope及其試圖解決的問題。

原文連結:https://mp.weixin.qq.com/s/JvLQI0asXhjEfUJ4ls6fMg

11
最新評論
  • 整治雙十一購物亂象,國家再次出手!該跟這些套路說再見了
  • 蘋果眼鏡新專利設計圖曝光,以iPhone手機為屏的頭顯裝置