• Search Research Projects
  • Search Researchers
  • How to Use
  1. Back to project page

2023 Fiscal Year Research-status Report

クロスレイヤー最適化による新しい高速データ交換モデル

Research Project

Project/Area Number 22K12048
Research InstitutionNagoya Institute of Technology

Principal Investigator

松尾 啓志  名古屋工業大学, 工学(系)研究科(研究院), 教授 (00219396)

Project Period (FY) 2022-04-01 – 2025-03-31
KeywordsDPDK / プロトコルスタック / L2通信 / プロキシ
Outline of Annual Research Achievements

申請者は、Sparkに於ける通信時のキャッシュメカニズムのオーバヘッド低減について複数の検討を行ってきたが、その性能向上は十数パーセントであった。大規模なバッチ処理では、かなりの効果があると考えられるが、例えばDeep Learning処理系の代表例であるTensor Flow(GPU非使用時)に比べると数十分の一の性能しか得られなかった。この原因を解析する上で、2つの問題点に着想した。(1)RDDやその発展系であるDataFrame, Datasetは、耐故障性と相互運用性の実現から、処理オーバヘッドが高く、これ以上の劇的な性能向上は不可能であること。(2)複数サーバー間での高い通信レイテンシが、Sparkの処理単位であるタスクとスケジューラ通信で大きなコストとなっていることである。
例えば、Sparkで分散Deep Learningを実現するためのプロジェクトとして、Project Hydrogenがある。Project Hydrogenの目指すゴールは、本研究が目指すゴールと同様である。しかしアプローチが全く異なる。一つは、本研究がSparkの基本的な特徴である耐故障性と、相互運用性を捨てるところから始まっていることである。つまりDL処理の大部分の実行時間を、数時間から十数時間と想定した場合の故障率と、耐故障性を実現するオーバヘッドを考慮した場合の耐故障性の実装は、性能低下に見合わないと判断したところが、全く異なる。
さらに本研究ではProject Hydrogen が対象としていないクロスレイヤー間での通信スタックも最適化の対象としている。つまりDPDK,SPDKを用いて通信速度・レイテンシを最適化するとともに、Project HydrogenがGPUをスケジューリング対象にしたのと同様に、CPU Coreを動的スケジューリングの対象とするところに新規性を有する。

Current Status of Research Progress
Current Status of Research Progress

2: Research has progressed on the whole more than it was originally planned.

Reason

本年度は主に2つのテーマについて進捗があった。
まずDPDKを用いた透過型L2プロキシでKVSのキャッシュを行う手法を提案した.DPDKによりコンテキスト切り替えのオーバーヘッドを解消し,OSI参照モデルのデータリンク層でキャッシュ制御を行い,キャッシュヒット時にプロキシがレスポンスを送信してスループットを向上させた.インメモリDBであるRedisに適用して提案手法の性能を評価した結果,キャッシュヒット時においてレイテンシを36%削減した.また,READリクエスト割合の増加に伴いスループット性能が向上し,公式のRedisと比較して最大13.6倍向上した.
次に、RDBMSと同様の一貫性を保証しつつ,NoSQLと同様なスケーラビリティを実現するNewSQLが利用されている.NewSQLはタイムスタンプを使用することで分散環境下でもRDBMSと同様のトランザクション処理機能を提供する.NewSQLのトランザクション処理性能は取得するタイムスタンプの精度に依存する.Google Spanner のクローンであるYugabyteDB はタイムスタンプの取得にNTPを用いるが,NTPによって得られるタイムスタンプの精度はSpannerが用いる原子時計・GPSと比較して低いため,トランザクション処理性能は劣る.そこでNewSQLノードに対し,集中型のプロキシを用いてクライアントに対し透過的なトランザクション処理を行うことで,NewSQLにおけるトランザクション処理性能の高速化を実現する手法について提案した.提案手法とYugabyteDBとのsysbenchを用いたトランザクション処理性能の比較において,YuagbyteDBノードを10台用いた場合,読み込み処理のみのワークロードでは1.28 倍,書き込み処理のみのワークロードでは4.46倍,書き込み処理と読み込み処理を含むワークロードでは最大で8.25倍の性能向上を確認した

Strategy for Future Research Activity

今年度は、分散メモリ環境下におけるプロキシを用いたキャッシュシステムについて検討を行う。これは昨年度の研究成果の拡張であり、分散トランザクショナルメモリにおけるキャッシュをプロキシ上に実装することを検討する。そのプロキシとサーバーとの通信はL2/UDPを用いることにより、TCP実装に比べて高速な実装を行う。

Causes of Carryover

今年度は、すでに研究室に設置されたサーバー機を用いたことと、予定していた海外発表を先送りしたため

  • Research Products

    (4 results)

All 2023

All Journal Article (3 results) (of which Peer Reviewed: 3 results) Presentation (1 results)

  • [Journal Article] Accelerating Key-Value Store with Layer-2 Transparent Proxy Cache using DPDK2023

    • Author(s)
      Hayato Aoba, Ryota Kawashima, Hiroshi Matsuo
    • Journal Title

      The Eleventh International Symposium on Computing and Networking Workshops (CANDARW)

      Volume: - Pages: -298-302

    • DOI

      10.1109/CANDARW60564.2023.00056

    • Peer Reviewed
  • [Journal Article] Proxy-based transaction acceleration for NewSQL2023

    • Author(s)
      Yutaka Watanabe, Ryota Kawashima, Hiroshi Matsuo
    • Journal Title

      The Eleventh International Symposium on Computing and Networking Workshops (CANDARW)

      Volume: - Pages: 343-347

    • DOI

      10.1109/CANDARW60564.2023.00065

    • Peer Reviewed
  • [Journal Article] Understanding Roadblocks in Virtual Network I/O: A Comprehensive Analysis of CPU Cache Usage2023

    • Author(s)
      Daichi Takeya, Ryota Kawashima, Hiroki Nakayama, Tsunemasa Hayashi, Hiroshi Matsuo
    • Journal Title

      2023 IEEE 9th International Conference on Network Softwarization (NetSoft)

      Volume: - Pages: -

    • DOI

      10.1109/NetSoft57336.2023.10175477

    • Peer Reviewed
  • [Presentation] DPDKを用いたL2プロキシキャッシュによるKVSの高速化2023

    • Author(s)
      青葉 隼人, 川島 龍太, 松尾 啓志
    • Organizer
      情報処理学会オペレーティングシステム研究会 2023年08月 情報処理学会

URL: 

Published: 2024-12-25  

Information User Guide FAQ News Terms of Use Attribution of KAKENHI

Powered by NII kakenhi