0737-1.6.1-CDSW分布式计算
- 2020 年 1 月 14 日
- 筆記
作者:冉南阳
简介
Cloudera Data Science Workbench为从单个交互式会话中启动多个称为workers的引擎实例提供了基本支持。任何R或Python会话均可用于生成workers。这些工作程序可以配置为在启动时运行脚本(例如Python文件)或命令中。
可以使用 launch_workers函数。以及另外两个函数是list_workers 和 list_workers。来自所有工作程序的输出将显示在启动它们的会话的控制台中。会话退出时,这些workers将终止。
Python示例
Python分布式运算基本语法
import cdsw workers=cdsw.launch_workers(n=2,cpu=0.2,memory=0.5,code="print('Hello from a CDSW Woker')")
- n(int) -要启动的引擎数。
- cpu(float) -要分配给引擎的CPU内核数。
- 内存(float) -分配给引擎的内存的千兆字节数。
- nvidia_gpu(int,optional) -要分配给引擎的GPU数量。
- kernel(str,optional) -内核。可以是r、 python2、 python3或scala。
- script(str,optional) -工作者启动后应立即执行的Python源文件的名称。
- code(str,optional) -引擎在启动后应立即执行的Python代码。如果指定了脚本,则代码将被忽略。
- env(dict,optional) -在引擎中设置的环境变量。

list_workers
cdsw.list_workers()

stop_worker
cdsw.stop_workers()

编辑Python文件master.py;在Master引擎中,该脚本将启动三个工作程序并接受来自Workers的传入连接。
# master.py import cdsw, socket # Launch two CDSW workers. These are engines that will run in # the same project, execute a given code or script, and exit. workers = cdsw.launch_workers(n=3, cpu=0.2, memory=0.5, script="worker.py") # Listen on TCP port 6000 s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) s.bind(("0.0.0.0", 6000)) s.listen(1) # Accept two connections, one from each worker. Workers will # execute worker.py. conn, addr = s.accept() for i in range(3): # Receive a message from each worker and return a response. data = conn.recv(20) if not data: break print("Master received:", data) conn.send("Hello From Server!".encode()) conn.close()

编辑worker.py文件;Workers将执行脚本中的命令,并返回给Master。
# worker.py import os, socket # Open a TCP connection to the master. s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) s.connect((os.environ["CDSW_MASTER_IP"], 6000)) # Send some data and receive a response. s.send("Hello From Worker!".encode()) data = s.recv(1024) s.close() print("Worker received:", data)

执行master.py,可以看到执行了三次worker.py。


R语言示例
基本语法
library("cdsw") workers <- launch.workers(n=2,cpu=0.2,memory=0.5, env="",code="print('Hello From a CDSW Workers')")
由于解析 launch.workers函数的bug,因此定义env 参数。如果未定义env 参数,env参数在内部序列化为与Cloudera Data Science Workbench不兼容的格式。此bug不会影响Python引擎。

编写master.r文件,在Master引擎中,该脚本将启动两个工作程序并接受来自Workers的传入连接。
# master.r library("cdsw") # Launch two CDSW workers. These are engines that will run in # the same project, execute a given code or script, and exit. workers <- launch.workers(n=2, cpu=0.2, memory=0.5, env="", script="worker.r") # Accept two connections, one from each worker. Workers will # execute worker.r. for(i in c(1,2)) { # Receive a message from each worker and return a response. con <- socketConnection(host="0.0.0.0", port = 6000, blocking=TRUE, server=TRUE, open="r+") data <- readLines(con, 1) print(paste("Server received:", data)) writeLines("Hello from master!", con) close(con) }

编写worker.r文件;Workers将执行以下命令,并返回到Master。
# worker.r print(Sys.getenv("CDSW_MASTER_IP")) con <- socketConnection(host=Sys.getenv("CDSW_MASTER_IP"), port = 6000, blocking=TRUE, server=FALSE, open="r+") write_resp <- writeLines("Hello from Worker", con) server_resp <- readLines(con, 1) print(paste("Worker received: ", server_resp)) close(con)

执行master.r,可以看到执行了两次worker.r



参考文档
https://docs.cloudera.com/documentation/data-science-workbench/1-6-x/topics/cdsw_parallel_computing.html