我有几个占用大量内存的大对象(sklearn模型),我想在几个进程之间共享它们。 有没有办法做到这一点?
答案 0 :(得分:2)
在从相同的python脚本启动进程的前提下,以下示例创建了第二个进程并在两个进程之间共享变量。对此进行详细说明以创建一些流程很简单。请注意用于创建和访问共享变量和锁的结构。我在算术过程中插入了一个循环,以生成一些cpu用法,以便您可以监视并查看其在多核或多处理器平台上的运行情况。还要注意使用共享变量来控制第二个过程,在这种情况下,告诉它何时退出。最后,共享对象可以是值或数组,请参见https://docs.python.org/2/library/multiprocessing.html
#!/usr/bin/python
from time import sleep
from multiprocessing import Process, Value, Lock
def myfunc(counter, lock, run):
while run.value:
sleep(1)
n=0
for i in range(10000):
n = n+i*i
print( n )
with lock:
counter.value += 1
print( "thread %d"%counter.value )
with lock:
counter.value = -1
print( "thread exit %d"%counter.value )
# =======================
counter = Value('i', 0)
run = Value('b', True)
lock = Lock()
p = Process(target=myfunc, args=(counter, lock, run))
p.start()
while counter.value < 5:
print( "main %d"%counter.value )
n=0
for i in range(10000):
n = n+i*i
print( n )
sleep(1)
with lock:
counter.value = 0
while counter.value < 5:
print( "main %d"%counter.value )
sleep(1)
run.value = False
p.join()
print( "main exit %d"%counter.value)