dyweb / papers-notebook

:page_facing_up: :cn: :page_with_curl: 论文阅读笔记(分布式系统、虚拟化、机器学习)Papers Notebook (Distributed System, Virtualization, Machine Learning)
https://github.com/dyweb/papers-notebook/issues?utf8=%E2%9C%93&q=is%3Aissue+is%3Aopen+-label%3ATODO-%E6%9C%AA%E8%AF%BB
Apache License 2.0
2.13k stars 244 forks source link

Gandiva: Introspective Cluster Scheduling for Deep Learning #109

Open gaocegege opened 5 years ago

gaocegege commented 5 years ago

OSDI'18

https://www.usenix.org/system/files/osdi18-xiao.pdf

https://www.usenix.org/sites/default/files/conference/protected-files/osdi18_slides_sivathanu.pdf

也是基于 k8s 实现了原型

MS 的

Jack47 commented 5 years ago

I'm reading this paper too, maybe we can share and discuss together.

gaocegege commented 5 years ago

@Jack47

Sure, 希望我能在最近写一些阅读的笔记

gaocegege commented 5 years ago

另外推荐 #86 ,也是类似的工作

gaocegege commented 5 years ago

这篇论文是北邮的博士学长的一作,据说有开源的计划,可以期待一下。

论文是基于这样几个 key insight:

screenshot from 2018-11-08 17-06-44

论文在不同方面利用了第三个 key insight,针对场景做了一些优化,主要是为机器学习工作负载的调度增加了几个新的原语,包括对 GPU 资源的时间共享,任务的迁移,对 GPU 资源的动态 alloc 一类的,但是很多原语没有说具体是如何做的,比如 Grow-Shrink, 和 time-sharing,以及怎么保证资源的隔离性的同时提供高的性能。

gaocegege commented 5 years ago

并没有看懂 Grow-Shrink 是通过什么方式实现的

gaocegege commented 5 years ago

对自动机器学习场景的介绍略显不足,不太够。

huyutuo commented 5 years ago

不太清楚在suspend-resume过程中,如何实现的,在论文中提到需要将GPU内的一些信息转移至CPU,然后再进行挂起,我有个问题,如何将GPU内的信息转移至CPU啊 谢谢

huyutuo commented 5 years ago

这篇论文是北邮的博士学长的一作,据说有开源的计划,可以期待一下。

论文是基于这样几个 key insight:

  • 深度学习是反馈驱动的探索,用户经常运行一批训练,取其中结果最好的。这个可以理解为是类似参数搜索,模型结构搜索这样的场景。
  • 在资源使用的异构性,导致很难得到最优解
  • intra-job predictability,这是全文比较关键的一个概念,如下图所示,GPU 的内存使用存在一定的周期性

screenshot from 2018-11-08 17-06-44

论文在不同方面利用了第三个 key insight,针对场景做了一些优化,主要是为机器学习工作负载的调度增加了几个新的原语,包括对 GPU 资源的时间共享,任务的迁移,对 GPU 资源的动态 alloc 一类的,但是很多原语没有说具体是如何做的,比如 Grow-Shrink, 和 time-sharing,以及怎么保证资源的隔离性的同时提供高的性能。

不太清楚在suspend-resume过程中,如何实现的,在论文中提到需要将GPU内的一些信息转移至CPU,然后再进行挂起,这个里面GPU与CPU的通信是如何完成的,希望能得到您的帮助!谢谢!

gaocegege commented 4 years ago

@huyutuo 不好意思现在才看到

因为文章写的不是很细节,我也不太清楚。按照我自己的猜测,应该是实现了把 GPU 显存的对象完全 dump 到内存,但是具体怎么实现不清楚。可能 CUDA 有一些 API 可以用吧

JiangShanCode commented 2 years ago

请问现在有开源了吗?找了一遍没发现

gaocegege commented 2 years ago

好像没有,如果没记错的话

Jack47 commented 2 years ago

这篇论文是北邮的博士学长的一作,据说有开源的计划,可以期待一下。 论文是基于这样几个 key insight:

  • 深度学习是反馈驱动的探索,用户经常运行一批训练,取其中结果最好的。这个可以理解为是类似参数搜索,模型结构搜索这样的场景。
  • 在资源使用的异构性,导致很难得到最优解
  • intra-job predictability,这是全文比较关键的一个概念,如下图所示,GPU 的内存使用存在一定的周期性

screenshot from 2018-11-08 17-06-44 论文在不同方面利用了第三个 key insight,针对场景做了一些优化,主要是为机器学习工作负载的调度增加了几个新的原语,包括对 GPU 资源的时间共享,任务的迁移,对 GPU 资源的动态 alloc 一类的,但是很多原语没有说具体是如何做的,比如 Grow-Shrink, 和 time-sharing,以及怎么保证资源的隔离性的同时提供高的性能。

不太清楚在suspend-resume过程中,如何实现的,在论文中提到需要将GPU内的一些信息转移至CPU,然后再进行挂起,这个里面GPU与CPU的通信是如何完成的,希望能得到您的帮助!谢谢!

这个就是平常用的 checkpoint 机制,类似游戏存档。Google 搜 "pytorch checkpoint" 就出来了。https://pytorch.org/docs/stable/checkpoint.html

gaocegege commented 2 years ago

应该不是这么简单吧,checkpoint 是完全 dump 到内存或者硬盘了

lambda7xx commented 2 years ago

这不是北航和MSRA的合作吗?发了好几年了,我感觉应该不会开源发自我的iPhone------------------ Original ------------------From: Jack Chen @.>Date: Fri,Mar 18,2022 10:11 AMTo: dyweb/papers-notebook @.>Cc: Subscribed @.***>Subject: Re: [dyweb/papers-notebook] Gandiva: Introspective Cluster Schedulingfor Deep Learning (#109)

这篇论文是北邮的博士学长的一作,据说有开源的计划,可以期待一下。 论文是基于这样几个 key insight:

深度学习是反馈驱动的探索,用户经常运行一批训练,取其中结果最好的。这个可以理解为是类似参数搜索,模型结构搜索这样的场景。 在资源使用的异构性,导致很难得到最优解 intra-job predictability,这是全文比较关键的一个概念,如下图所示,GPU 的内存使用存在一定的周期性

论文在不同方面利用了第三个 key insight,针对场景做了一些优化,主要是为机器学习工作负载的调度增加了几个新的原语,包括对 GPU 资源的时间共享,任务的迁移,对 GPU 资源的动态 alloc 一类的,但是很多原语没有说具体是如何做的,比如 Grow-Shrink, 和 time-sharing,以及怎么保证资源的隔离性的同时提供高的性能。

不太清楚在suspend-resume过程中,如何实现的,在论文中提到需要将GPU内的一些信息转移至CPU,然后再进行挂起,这个里面GPU与CPU的通信是如何完成的,希望能得到您的帮助!谢谢!

这个就是平常用的 checkpoint 机制,类似游戏存档。Google 搜 "pytorch checkpoint" 就出来了。https://pytorch.org/docs/stable/checkpoint.html

—Reply to this email directly, view it on GitHub, or unsubscribe.Triage notifications on the go with GitHub Mobile for iOS or Android. You are receiving this because you are subscribed to this thread.Message ID: @.> [ { @.": "http://schema.org", @.": "EmailMessage", "potentialAction": { @.": "ViewAction", "target": "https://github.com/dyweb/papers-notebook/issues/109#issuecomment-1071951375", "url": "https://github.com/dyweb/papers-notebook/issues/109#issuecomment-1071951375", "name": "View Issue" }, "description": "View this Issue on GitHub", "publisher": { @.***": "Organization", "name": "GitHub", "url": "https://github.com" } } ]