精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

機器學習分布式框架Ray

人工智能 機器學習 分布式
Ray是UC Berkeley RISELab新推出的高性能分布式執行框架,具有比Spark更優異的計算性能,而且部署和改造更簡單,同時支持機器學習和深度學習的分布式訓練,支持主流的深度學習框架。

 [[422916]]

Python中文社區 (ID:python-china)

1.什么是Ray

分布式計算框架大家一定都耳熟能詳,諸如離線計算的Hadoop(map-reduce),spark, 流式計算的strom,Flink等。相對而言,這些計算框架都依賴于其他大數據組件,安裝部署也相對復雜。

在python中,之前有分享過的Celery可以提供分布式的計算。今天和大家分享另外一個開源的分布式計算框架Ray。Ray是UC Berkeley RISELab新推出的高性能分布式執行框架,具有比Spark更優異的計算性能,而且部署和改造更簡單,同時支持機器學習和深度學習的分布式訓練,支持主流的深度學習框架(pytorch,tensorflow,keras等)。

2. Ray架構

Ray的架構參見最早發布的論文Ray: A Distributed Framework for Emerging AI Applications

由上圖可知Ray主要包括:

  •  Node: 節點,主要是head和worker, head可以認為是Master,worker是執行任務的單元
    •   每個節點都有自己的本地調度器local scheduler
    •   object store:一個內存對象存儲,允許Node之間進行通信
  •  scheduler:有兩個調度器,每個節點都有本地的調度器, 在提交任務時,Local Scheduler會判斷是否需要提交給Global Scheduler分發給其他worker來執行。
  •  GCS:全局狀態控制記錄了Ray中各種對象的狀態信息,可以認為是meta數據,是Ray容錯的保證

Ray適用于任何分布式計算的任務,包括分布式訓練。筆者最近是用在大量的時間序列預測模型訓練和在線預測上。

Ray目前庫支持超參數調優Ray tune, 梯度下降Ray SGD,推理服務RaySERVE, 分布式數據Dataset以及分布式增強學習RLlib。還有其他第三方庫,如下所示:

3. 簡單使用

3.1 安裝部署 

  1. pip install --upgrade pip  
  2. # pip install ray  
  3. pip install ray == 1.6.0  
  4. # ImportError: cannot import name 'deep_mapping' from 'attr.validators'  
  5. # pip install attr == 19.1.0 

3.2 單機使用

  •  簡單例子 Ray 通過@ray.remote裝飾器使得函數變成可分布式調用的任務。通過函數名.remote方式進行提交任務,通過ray.get方式來獲取任務返回值。單擊情況下和多線程異步執行的方式類似。 
  1. import time  
  2.   import ray  
  3.   ray.init(num_cpus = 4) # Specify this system has 4 CPUs.  
  4.   @ray.remote  
  5.   def do_some_work(x):  
  6.       time.sleep(1) # Replace this is with work you need to do.  
  7.       return x  
  8.   start = time.time()  
  9.   results = ray.get([do_some_work.remote(x) for x in range(4)])  
  10.   print("duration =", time.time() - start)  
  11.   print("results = ", results)   
  12.   # duration = 1.0107324123382568  
  13.   # results =  [0, 1, 2, 3] 

remote返回的對象的id 如ObjectRef(7f10737098927148ffffffff0100000001000000)。需要通過ray.get來獲取實際的值, 需要注意的是ray.get是阻塞式的調用,不能[ray.get(do_some_work.remote(x)) for x in range(4)]

  •  注意小任務使用情況 需要注意的是ray分布式計算在調度的時候需要發費額外的時間,如調度,進程間通信以及任務狀態的更新等等,所以避免過小的任務。可以把小任務進行合并   
  1. @ray.remote  
  2.    def tiny_work(x):  
  3.        time.sleep(0.0001) # Replace this is with work you need to do.  
  4.        return x  
  5.    start = time.time()  
  6.    result_ids = [tiny_work.remote(x) for x in range(100000)]  
  7.    results = ray.get(result_ids)  
  8.    print("duration =", time.time() - start) 
  •  ray.put ray.put() 把一個對象放到對象存儲上,返回一個object id, 這個id可以在分布式機器上都可以調用,該操作為異步的。通過ray.get()可以是獲取。 
  1. num = ray.put(10)  
  2. ray.get(num) 
  •  ray.wait 如果任務返回多個結果,ray.get()會等所有結果都完成之后才會執行后續的操作。如果多個結果執行的耗時不同,此時短板在于最長的那個任務。

          這個時候可以采用ray.wait()方法,ray.wait()返回執行完畢的和未執行完畢的任務結果,執行完成的結果可以繼續后續的操作   

  1. import random  
  2.    @ray.remote  
  3.    def do_some_work(x):  
  4.        time.sleep(random.uniform(0, 4)) # Replace this is with work you need to do.  
  5.        return   
  6.    def process_incremental(sum, result):  
  7.        time.sleep(1) # Replace this with some processing code.  
  8.        return sum + result  
  9.    start = time.time()  
  10.    result_ids = [do_some_work.remote(x) for x in range(4)]  
  11.    sum = 0  
  12.    while len(result_ids):  
  13.        done_id, result_ids = ray.wait(result_ids)  
  14.        sum = process_incremental(sum, ray.get(done_id[0])) 
  15.     print("duration =", time.time() - start, "\nresult = ", sum)  
  16.    # duration = 5.270821809768677   
  17.    # result =  6    

2.3 集群部署

Ray的架構遵循master-slave的模式。Head Node 可以認為是Master,其他的Node為worker。在集群部署時,Head Node需要首先啟動ray start --head, 其他機器依次啟動worker,注意需要指定head Node的地址確定關系,ray start --address 10.8.xx.3:6379。

關閉服務,需要每一臺機器執行 ray.stop

 

  1. # To start a head node.  
  2. #ray start --head --num-cpus=<NUM_CPUS> --num-gpus=<NUM_GPUS>  
  3. ray start --head --node-ip-address 10.8.xx.3 --port=6379  
  4. # To start a non-head node.  
  5. # ray start --address=<address> --num-cpus=<NUM_CPUS> --num-gpus=<NUM_GPUS>  
  6. ray start --address 10.8.xx.3:6379 --node-ip-address 10.8.xx.3 --num-cpus 10 --temp-dir={your temp path} 

  •  提交任務 任何一臺worker機器都可以提交任務, 先通過init連接Head Node就可以remote起來了。 
  1. import ray  
  2. ray.init(10.8.xx.3:6379) 

3. 不同任務的例子

  •  任務依賴 任務之間存在依賴關系,Ray和Spark一樣也是通過生成DAG圖的方式來確定依賴關系,確定可以并行跑的任務。如下圖所示zeros是可以并行跑的。 
  1. import numpy as np  
  2. # Define two remote functions. Invocations of these functions create tasks  
  3. # that are executed remotely.  
  4. @ray.remote  
  5. def multiply(x, y):  
  6.     return np.dot(x, y)  
  7. @ray.remote  
  8. def zeros(size):  
  9.     return np.zeros(size)  
  10. # Start two tasks in parallel. These immediately return futures and the  
  11. # tasks are executed in the background.  
  12. x_id = zeros.remote((100, 100))  
  13. y_id = zeros.remote((100, 100))  
  14. # Start a third task. This will not be scheduled until the first two  
  15. # tasks have completed.  
  16. z_id = multiply.remote(x_id, y_id)  
  17. # Get the result. This will block until the third task completes.  
  18. z = ray.get(z_id)  
  19. print(z)     

  •  有狀態任務 上面提到的任務都是無狀態的(除依賴外),即任務之間都是無關系的。Ray也是支持有狀態的任務成為Actor。常是在python class上加@ray.remote,ray會跟蹤每個class內部狀態的不同狀態。 
  1. @ray.remote  
  2.  class Counter(object):  
  3.      def __init__(self):  
  4.          self.n = 0  
  5.      def increment(self):  
  6.          self.n += 1  
  7.      def read(self):  
  8.          return self.n  
  9.  counters = [Counter.remote() for i in range(4)]  
  10.  # 不斷的執行可以每個counter計數不斷增加  
  11.  [c.increment.remote() for c in counters]  
  12.  futures = [c.read.remote() for c in counters]  
  13.  print(ray.get(futures))  
  14.  # [1, 1, 1, 1]  
  15.  # [11, 11, 11, 11] 
  • map-reduce 任務 map-reduce任務其實可以其他分布式任務是一樣的。主要是各種聚合操作。Map-Reduce常規操作如下  

  •  - word count例子見:https://github.com/ray-project/ray/blob/master/doc/examples/streaming/streaming.py

         這里舉一個簡單的例子:   

  1. @ray.remote  
  2.    def map(obj, f):  
  3.        return f(obj)  
  4.    @ray.remote  
  5.    def sum_results(*elements):  
  6.        return np.sum(elements)  
  7.    items = list(range(100))  
  8.    map_func = lambda i : i*2  
  9.    remote_elements = [map.remote(i, map_func) for i in items]  
  10.    # simple reduce  
  11.    remote_final_sum = sum_results.remote(*remote_elements)  
  12.    result = ray.get(remote_final_sum) 
  13.    # tree reduce  
  14.    intermediate_results = [sum_results.remote(  
  15.        *remote_elements[i * 20: (i + 1) * 20]) for i in range(5)]  
  16.    remote_final_sum = sum_results.remote(*intermediate_results)  
  17.    result = ray.get(remote_final_sum)     

  •  訓練模型如pytorch 官網提供了Best Practices: Ray with PyTorch, 主要是下載訓練/測試數據和訓練多個模型(感覺不是很實用)。訓練多個模型,可以進行參數融合。

           參見 https://docs.ray.io/en/latest/using-ray-with-pytorch.html

4. 總結

本文分享了高效的Python分布式計算框架Ray,希望對你有幫助。總結如下:

  •  Ray是UC Berkeley RISELab新推出的高性能分布式執行框架, Spark也是伯克利出品的
  •  Ray架構關鍵:兩個調度器, Head和worker節點,GCS全局狀態控制保證計算容錯
  •  Ray應用簡單:@ray.remote把任務變成分布式任務, x.remote提交任務, get/wait獲取結果
  •  集群不是:ray start
  •  Ray支持多種任務:有依賴DAG,有狀態Actor以及深度學習支持
  •  不斷豐富的庫:RaySERVE, RaySGD, RayTune, Ray data,rllib 
責任編輯:龐桂玉 來源: Python中文社區
相關推薦

2025-01-13 08:05:04

2023-11-01 18:02:33

RayPython分布式

2025-06-30 08:21:58

2017-09-11 15:19:05

CoCoA機器學習分布式

2015-06-10 09:47:18

微軟分布式云平臺

2016-08-31 07:02:51

2018-11-07 09:23:21

服務器分布式機器學習

2017-04-08 17:32:39

人工智能喬丹Ray

2017-12-05 14:55:56

2022-08-03 20:18:58

機器學習算法分析數據

2017-06-29 13:29:34

大數據PAI機器學習

2023-06-26 00:14:28

Openjob分布式任務

2023-08-24 08:49:27

2021-06-02 22:16:56

框架CAPBASE

2021-12-13 11:07:10

鴻蒙HarmonyOS應用

2019-07-04 15:13:16

分布式緩存Redis

2024-01-05 07:28:50

分布式事務框架

2010-06-03 19:46:44

Hadoop

2021-08-30 18:36:33

鴻蒙HarmonyOS應用

2021-08-30 20:19:55

應用程序
點贊
收藏

51CTO技術棧公眾號

亚洲毛片网站| 琪琪久久久久日韩精品| 一区二区高清免费观看影视大全| 96成人在线视频| 天堂网av手机版| 日韩国产专区| 亚洲国产成人在线播放| 精品久久久久久久无码| av网站大全在线| 337p粉嫩大胆噜噜噜噜噜91av| 国产日本欧美在线观看| 久久视频免费在线观看| 成人精品久久| 亚洲福利视频免费观看| 一区二区免费av| 日韩伦理精品| 一区二区在线看| 日韩视频专区| 无码国产精品96久久久久| 蜜桃视频一区二区三区在线观看| 97碰碰碰免费色视频| 人成免费在线视频| 亚洲春色h网| 日韩免费性生活视频播放| 青青青在线视频免费观看| 蜜臀av在线| 自拍偷自拍亚洲精品播放| 女同一区二区| 黑人精品一区二区三区| 激情综合网天天干| 国产精品久久久久免费a∨| 亚洲一区 视频| 91精品一区国产高清在线gif| 亚洲欧洲高清在线| 久久国产精品免费观看| 亚洲精品自在久久| 国产在线精品一区二区| 超碰aⅴ人人做人人爽欧美| xxxxx99| 1区2区在线观看| 久久久不卡网国产精品一区| 91视频免费在线观看| 中文字幕人妻一区二区三区视频| 国产香蕉视频在线看| 青青草国产精品97视觉盛宴| 欧美一级成年大片在线观看| 国产精品1000| 欧美日韩 国产精品| 久久这里只有精品视频首页| 国产在线免费av| 精品国产一区二区三区四区| 亚洲欧洲一区二区三区久久| 日本少妇色视频| 麻豆一区二区| 亚洲精品午夜精品| 黄瓜视频污在线观看| 色橹橹欧美在线观看视频高清| 亚洲第一偷拍网| 亚洲精品在线视频观看| 911精品产国品一二三产区| 亚洲成av人片乱码色午夜| 成年网站在线| 超碰人人人人人人人| 欧美精品二区三区四区免费看视频 | 精品国产一区二区三区av片| 99久久香蕉| 亚洲国产精品天堂| 欧美日韩中文字幕在线播放| 中文字幕在线播放网址| 亚洲激情校园春色| 久久亚洲国产成人精品无码区| 国产精品扒开做爽爽爽的视频| 亚洲欧洲日产国产综合网| 久久99九九99精品| jizz欧美| 国产精品色在线| 亚洲精品欧美精品| 黄色网页在线观看| 亚洲午夜在线观看视频在线| 色欲色香天天天综合网www| 擼擼色在线看观看免费| 色婷婷综合视频在线观看| 国产一区视频免费观看| 午夜不卡一区| 精品国产免费一区二区三区四区 | 国产经典欧美精品| 国产视频一区二区三区四区| 你懂的视频在线观看| 国产精品久久久久三级| 一二三在线视频| 国产精品xx| 欧美撒尿777hd撒尿| 超碰在线资源站| 久久香蕉网站| 中文字幕日韩电影| 九九免费精品视频| 久久午夜电影| http;//www.99re视频| 欧洲视频在线免费观看| 中文字幕一区在线| 免费一级特黄特色毛片久久看| 欧美www.| 精品久久久久99| 免费看日本黄色片| 9色国产精品| 96精品久久久久中文字幕| 深夜福利视频一区| 亚洲欧美激情在线| 蜜臀视频一区二区三区| 综合伊人久久| 北条麻妃久久精品| 亚洲影院在线播放| 成人在线视频一区二区| 一区二区视频在线播放| 天堂电影一区| 精品国内二区三区| 久艹在线观看视频| 国产欧美短视频| 成人在线资源网址| 黄色一级片在线观看| 91黄色免费网站| 国产精品久久久久久亚洲色 | 最新在线中文字幕| 91美女视频网站| av无码久久久久久不卡网站| 青青在线精品| 一区二区三区视频观看| 久久一区二区三区视频| 国产精品一二三四| 一区在线电影| 日韩精品一区二区三区av| 国产丝袜一区二区| 欧美激情亚洲综合| 成人综合在线视频| 成年在线观看视频| 国产免费av国片精品草莓男男| 亚洲天堂开心观看| 一级黄色免费网站| 99久久精品免费看| 性高湖久久久久久久久aaaaa| 91精品一久久香蕉国产线看观看| 这里只有精品视频| 婷婷激情五月综合| 国产日韩欧美麻豆| 男人插女人下面免费视频| 最新亚洲精品| 国产成人精品综合| 欧美成人片在线| 91久久精品一区二区三| japanese中文字幕| 日韩国产在线一| 性欧美videosex高清少妇| 日韩精品三区| 日韩一二三在线视频播| 国产精品嫩草影院精东| 亚洲精品日日夜夜| 成人一区二区三区仙踪林| 国产尤物精品| 91九色在线观看| sm捆绑调教国产免费网站在线观看 | 中文字幕亚洲一区二区av在线| 三级a在线观看| 国产精品久久久久9999赢消| 亚洲aa中文字幕| 欧美精品videosex| 亚洲国产美女久久久久| 国产精品一区二区三区四| 91丨porny丨中文| 日韩无套无码精品| 久久激情电影| 成人三级在线| 午夜伦理福利在线| 最近更新的2019中文字幕| 国产女无套免费视频| 亚洲影视资源网| 久久久久久亚洲中文字幕无码| 日韩综合在线视频| 欧美日韩亚洲国产成人| 国产精品白丝一区二区三区| 日韩**中文字幕毛片| 免费黄色在线看| 精品国产乱码久久久久久免费| 日韩久久精品视频| 亚洲国产经典视频| 最新中文字幕日本| 久久久久久久高潮| 久久久99精品视频| 国产精品免费99久久久| 91夜夜未满十八勿入爽爽影院| 成人在线免费观看黄色| 国产亚洲综合久久| 亚洲男人第一天堂| 欧美在线色视频| 黄网站免费在线| 欧美激情一区二区三区不卡| 中国特级黄色片| 日本欧美久久久久免费播放网| 国产手机视频在线观看| 精品在线播放| 99精品国产高清一区二区| 日本在线精品| 久久人91精品久久久久久不卡| 国产福利电影在线| 亚洲成人免费网站| aaaa一级片| 91福利在线观看| 日本三级欧美三级| 亚洲青青青在线视频| 日韩精品无码一区二区三区久久久| 国内成人精品2018免费看| 国产午夜福利视频在线观看| 亚洲免费二区| 色视频一区二区三区| 欧美日韩一区二区三区不卡视频| 91精品在线看| 国产精品久久久久77777丨| 98精品国产自产在线观看| av在线下载| 日韩视频在线免费观看| 国产在线一二三区| 日韩精品一二三四区| 亚洲精品久久久蜜桃动漫| 欧美高清你懂得| 中文字幕视频一区二区| 一本色道久久加勒比精品| 亚洲国产综合久久| 亚洲一区在线视频| 黄色一级免费视频| 亚洲精品欧美二区三区中文字幕| 国产偷人妻精品一区| 成人91在线观看| 精品伦一区二区三区| 国产91丝袜在线18| 欧美成人手机在线视频| 精品在线播放午夜| 日韩一级免费片| 麻豆精品新av中文字幕| 国产精品人人爽人人爽| 久久精品人人| 成人亚洲视频在线观看| 久久婷婷麻豆| 久久久国产欧美| 麻豆精品精品国产自在97香蕉| 久久99999| 欧美aaa在线| 久久久久久蜜桃一区二区| 蜜臀精品一区二区三区在线观看| 91香蕉视频污版| 免费成人在线影院| 男生操女生视频在线观看| 麻豆精品国产91久久久久久| 一区二区三区四区毛片| 国产一区91精品张津瑜| 污免费在线观看| 成人国产视频在线观看| 免费a v网站| 91美女片黄在线| 91成年人网站| 国产精品毛片大码女人| 欧美日韩黄色网| 一区二区三区鲁丝不卡| 亚洲一区欧美在线| 色综合天天做天天爱| 最近中文字幕免费观看| 6080日韩午夜伦伦午夜伦| 亚洲欧美强伦一区二区| 亚洲精品av在线| 成人在线观看免费| 久久精品国产欧美亚洲人人爽| 91精品久久| 韩国国内大量揄拍精品视频| 欧美日韩美女| 国产日韩在线视频| eeuss鲁片一区二区三区| 精品视频一区在线| 日韩国产综合| 国产男女免费视频| 日韩影院精彩在线| 日韩不卡的av| 91在线免费视频观看| 婷婷综合在线视频| 亚洲伊人色欲综合网| 中文字幕在线欧美| 91精品国产色综合久久ai换脸 | 久久一二三国产| 国产在线观看免费视频软件| 亚洲午夜在线观看视频在线| 日韩黄色片网站| 精品国产乱码久久久久久牛牛| 九色在线播放| 免费av一区二区| 韩漫成人漫画| 不卡一卡2卡3卡4卡精品在| 日韩成人午夜| 四虎免费在线观看视频| 性8sex亚洲区入口| 免费不卡av网站| 久久精品亚洲麻豆av一区二区| 亚洲色图综合区| 91福利精品视频| 三级网站在线看| 日韩在线观看免费| 第84页国产精品| 波多野结衣一区二区三区在线观看| 国产欧美一区二区精品久久久| 久久视频免费在线| 蜜桃av噜噜一区二区三区小说| 国产sm在线观看| 中文字幕日韩av资源站| 国产美女激情视频| 精品国产一区二区三区不卡| av亚洲在线| 国产91免费观看| 精品国产一区二区三区成人影院| 97超碰免费观看| 免费成人你懂的| 精品国产成人亚洲午夜福利| 亚洲国产精品嫩草影院| 国产精品日韩无码| 一区二区亚洲精品国产| 亚洲最新无码中文字幕久久| 91视频在线免费观看| 91视频综合| 在线免费视频a| 国产日韩av一区| 五月天婷婷导航| 精品视频中文字幕| yellow在线观看网址| www.久久久| 中文字幕乱码亚洲无线精品一区 | 日韩精品成人免费观看视频| 精品动漫一区二区三区在线观看| 国产激情视频在线| 91久久精品国产91久久| 91久久电影| 手机版av在线| 中文字幕在线不卡一区| 91成品人影院| 久久亚洲精品一区二区| 亚洲国产一区二区久久| 中文字幕乱码一区二区三区| 日本中文一区二区三区| 色屁屁草草影院ccyy.com| 在线亚洲免费视频| 大胆av不用播放器在线播放| 国产成人一区二区三区小说| 欧洲专线二区三区| 免费观看成人网| 日本一区二区三区久久久久久久久不| 日韩熟女一区二区| 国产一区二区三区网站| 久久国产三级| 欧美日韩一级在线| 国产一区二区日韩精品| 妺妺窝人体色www在线下载| 欧美r级电影在线观看| 成人福利影视| 欧美成ee人免费视频| 日韩成人精品在线观看| 欧美a级片免费看| 精品日韩欧美一区二区| а√天堂中文在线资源8| 久热国产精品视频一区二区三区| 免费在线亚洲欧美| 国产午夜精品久久久久久久久| 欧美日韩亚洲高清一区二区| av免费在线免费| 国产一区二区三区四区五区加勒比| 亚洲视频播放| 网爆门在线观看| 日韩美女主播在线视频一区二区三区 | 欧美黑人xxxⅹ高潮交| 极品国产人妖chinesets亚洲人妖 激情亚洲另类图片区小说区 | 国产精品三区www17con| 中文亚洲免费| 日本猛少妇色xxxxx免费网站| 7777精品伊人久久久大香线蕉的 | 久久精品一区二区国产| 性少妇xx生活| 欧美videossexotv100| 正在播放日韩精品| 一区二区三区不卡在线| 成人午夜伦理影院| 亚洲综合成人av| 久久国产精彩视频| 天天躁日日躁成人字幕aⅴ| 日韩欧美国产片| 精品久久久久久久久国产字幕| av在线免费一区| 国产精品一区二区免费| 免费在线成人网| 日本三级黄色大片| 色综久久综合桃花网| 日韩精品免费一区二区夜夜嗨| 亚洲久久中文字幕| 污片在线观看一区二区| 免费a在线看| 欧美一区亚洲二区| 国产麻豆9l精品三级站| 久久久国产免费|