日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
機(jī)器學(xué)習(xí)分布式框架Ray

機(jī)器學(xué)習(xí)分布式框架Ray

作者:wedo實(shí)驗(yàn)君 2021-09-09 15:45:17

人工智能

機(jī)器學(xué)習(xí)

分布式 Ray是UC Berkeley RISELab新推出的高性能分布式執(zhí)行框架,具有比Spark更優(yōu)異的計(jì)算性能,而且部署和改造更簡(jiǎn)單,同時(shí)支持機(jī)器學(xué)習(xí)和深度學(xué)習(xí)的分布式訓(xùn)練,支持主流的深度學(xué)習(xí)框架。

創(chuàng)新互聯(lián)建站專注于企業(yè)成都營(yíng)銷網(wǎng)站建設(shè)、網(wǎng)站重做改版、鹿城網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5高端網(wǎng)站建設(shè)、商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)營(yíng)銷網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為鹿城等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。

 [[422916]]

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

1.什么是Ray

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

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

  •  https://github.com/ray-project/ray

2. Ray架構(gòu)

Ray的架構(gòu)參見最早發(fā)布的論文Ray: A Distributed Framework for Emerging AI Applications

由上圖可知Ray主要包括:

  •  Node: 節(jié)點(diǎn),主要是head和worker, head可以認(rèn)為是Master,worker是執(zhí)行任務(wù)的單元
    •   每個(gè)節(jié)點(diǎn)都有自己的本地調(diào)度器local scheduler
    •   object store:一個(gè)內(nèi)存對(duì)象存儲(chǔ),允許Node之間進(jìn)行通信
  •  scheduler:有兩個(gè)調(diào)度器,每個(gè)節(jié)點(diǎn)都有本地的調(diào)度器, 在提交任務(wù)時(shí),Local Scheduler會(huì)判斷是否需要提交給Global Scheduler分發(fā)給其他worker來(lái)執(zhí)行。
  •  GCS:全局狀態(tài)控制記錄了Ray中各種對(duì)象的狀態(tài)信息,可以認(rèn)為是meta數(shù)據(jù),是Ray容錯(cuò)的保證

Ray適用于任何分布式計(jì)算的任務(wù),包括分布式訓(xùn)練。筆者最近是用在大量的時(shí)間序列預(yù)測(cè)模型訓(xùn)練和在線預(yù)測(cè)上。

Ray目前庫(kù)支持超參數(shù)調(diào)優(yōu)Ray tune, 梯度下降Ray SGD,推理服務(wù)RaySERVE, 分布式數(shù)據(jù)Dataset以及分布式增強(qiáng)學(xué)習(xí)RLlib。還有其他第三方庫(kù),如下所示:

3. 簡(jiǎn)單使用

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 單機(jī)使用

  •  簡(jiǎn)單例子 Ray 通過(guò)@ray.remote裝飾器使得函數(shù)變成可分布式調(diào)用的任務(wù)。通過(guò)函數(shù)名.remote方式進(jìn)行提交任務(wù),通過(guò)ray.get方式來(lái)獲取任務(wù)返回值。單擊情況下和多線程異步執(zhí)行的方式類似。 
  
 
 
 
  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返回的對(duì)象的id 如ObjectRef(7f10737098927148ffffffff0100000001000000)。需要通過(guò)ray.get來(lái)獲取實(shí)際的值, 需要注意的是ray.get是阻塞式的調(diào)用,不能[ray.get(do_some_work.remote(x)) for x in range(4)]

  •  注意小任務(wù)使用情況 需要注意的是ray分布式計(jì)算在調(diào)度的時(shí)候需要發(fā)費(fèi)額外的時(shí)間,如調(diào)度,進(jìn)程間通信以及任務(wù)狀態(tài)的更新等等,所以避免過(guò)小的任務(wù)??梢园研∪蝿?wù)進(jìn)行合并   
  
 
 
 
  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() 把一個(gè)對(duì)象放到對(duì)象存儲(chǔ)上,返回一個(gè)object id, 這個(gè)id可以在分布式機(jī)器上都可以調(diào)用,該操作為異步的。通過(guò)ray.get()可以是獲取。 
  
 
 
 
  1. num = ray.put(10)  
  2. ray.get(num) 
  •  ray.wait 如果任務(wù)返回多個(gè)結(jié)果,ray.get()會(huì)等所有結(jié)果都完成之后才會(huì)執(zhí)行后續(xù)的操作。如果多個(gè)結(jié)果執(zhí)行的耗時(shí)不同,此時(shí)短板在于最長(zhǎng)的那個(gè)任務(wù)。

          這個(gè)時(shí)候可以采用ray.wait()方法,ray.wait()返回執(zhí)行完畢的和未執(zhí)行完畢的任務(wù)結(jié)果,執(zhí)行完成的結(jié)果可以繼續(xù)后續(xù)的操作   

  
 
 
 
  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的架構(gòu)遵循master-slave的模式。Head Node 可以認(rèn)為是Master,其他的Node為worker。在集群部署時(shí),Head Node需要首先啟動(dòng)ray start --head, 其他機(jī)器依次啟動(dòng)worker,注意需要指定head Node的地址確定關(guān)系,ray start --address 10.8.xx.3:6379。

關(guān)閉服務(wù),需要每一臺(tái)機(jī)器執(zhí)行 ray.stop

 

  
 
 
 
  1. # To start a head node.  
  2. #ray start --head --num-cpus= --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=
     --num-cpus= --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} 

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

3. 不同任務(wù)的例子

  •  任務(wù)依賴 任務(wù)之間存在依賴關(guān)系,Ray和Spark一樣也是通過(guò)生成DAG圖的方式來(lái)確定依賴關(guān)系,確定可以并行跑的任務(wù)。如下圖所示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)     

  •  有狀態(tài)任務(wù) 上面提到的任務(wù)都是無(wú)狀態(tài)的(除依賴外),即任務(wù)之間都是無(wú)關(guān)系的。Ray也是支持有狀態(tài)的任務(wù)成為Actor。常是在python class上加@ray.remote,ray會(huì)跟蹤每個(gè)class內(nèi)部狀態(tài)的不同狀態(tài)。 
  
 
 
 
  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.  # 不斷的執(zhí)行可以每個(gè)counter計(jì)數(shù)不斷增加  
  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 任務(wù) map-reduce任務(wù)其實(shí)可以其他分布式任務(wù)是一樣的。主要是各種聚合操作。Map-Reduce常規(guī)操作如下  

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

         這里舉一個(gè)簡(jiǎn)單的例子:   

  
 
 
 
  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)     

  •  訓(xùn)練模型如pytorch 官網(wǎng)提供了Best Practices: Ray with PyTorch, 主要是下載訓(xùn)練/測(cè)試數(shù)據(jù)和訓(xùn)練多個(gè)模型(感覺不是很實(shí)用)。訓(xùn)練多個(gè)模型,可以進(jìn)行參數(shù)融合。

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

4. 總結(jié)

本文分享了高效的Python分布式計(jì)算框架Ray,希望對(duì)你有幫助??偨Y(jié)如下:

  •  Ray是UC Berkeley RISELab新推出的高性能分布式執(zhí)行框架, Spark也是伯克利出品的
  •  Ray架構(gòu)關(guān)鍵:兩個(gè)調(diào)度器, Head和worker節(jié)點(diǎn),GCS全局狀態(tài)控制保證計(jì)算容錯(cuò)
  •  Ray應(yīng)用簡(jiǎn)單:@ray.remote把任務(wù)變成分布式任務(wù), x.remote提交任務(wù), get/wait獲取結(jié)果
  •  集群不是:ray start
  •  Ray支持多種任務(wù):有依賴DAG,有狀態(tài)Actor以及深度學(xué)習(xí)支持
  •  不斷豐富的庫(kù):RaySERVE, RaySGD, RayTune, Ray data,rllib 


標(biāo)題名稱:機(jī)器學(xué)習(xí)分布式框架Ray
網(wǎng)頁(yè)網(wǎng)址:http://www.dlmjj.cn/article/djghocp.html