python 3 的主管演员策略

supervisor actor strategy for python 3

有没有人有一个很好的简单示例来说明如何在 Python 3+ 中使用 supervisor actor? 我看到了 http://www.gevent.org/contents.html and http://quantmind.github.io/pulsar/overview.html 但它没有任何示例。

您可能想看看 Thespian:http://thespianpy.com。特别是示例部分,并建议如果它没有提供您正在寻找的信息,可以通过那里的问题添加什么。

这是代码....

#!/usr/bin/env python3.5

import random
from time import sleep
from thespian.actors import *

class Add(object):
    def __init__(self, val): self.value = val
    def __str__(self): return self.value

class Print(object):
    def __init__(self, val): self.value = val
    def __str__(self): return self.value

class Remove(object):
    def __init__(self, i): self.id = i
    def __str__(self): return self.value

class Reexecute(object):
    def __init__(self, i): self.id = i
    def __str__(self): return self.value

class Greeting(object):
    def __init__(self, i, msg):
        self.id = i
        self.message = msg
    def __str__(self):
        return "id: "+str(self.id)+" ["+self.message+"]"

class Hello(Actor):
    def __init__(self, start_args=None):
        self.count = 0
    def receiveMessage(self, message, sender):
        try:
            self.count+=1
            if isinstance(message, Greeting):
                if (random.uniform(0, 1) > 0.5):
                    raise Exception("break............ id: "+str(message.id)+" ["+message.message+"]")
                sleep(0.2)
                print("id: "+str(message.id)+" ["+message.message+"]")
                self.send(sender, Remove(message.id))
        except Exception as e:
            print(e)
            self.send(sender, Reexecute(message.id))

class Supervisor(Actor):
    def __init__(self, start_args=None):
        self.hello = None
        self.count = 0
        self.queue = {}
        self.finalValue = ""
    def receiveMessage(self, message, sender):
        if (self.hello == None): self.hello = self.createActor(Hello)
        if isinstance(message, Add):
            # send to execute
            self.count+=1
            greeting = Greeting(self.count, message.value)
            print("add: "+str(greeting))
            self.queue[self.count] = greeting
            greeting.sendTo = [self.hello, sender]
            self.send(self.hello, greeting)
        elif isinstance(message, Remove):
            print("Remove: "+str(self.queue.get(message.id)))
            greeting = self.queue.pop(message.id)
            self.finalValue = self.finalValue+" "+str(greeting.message)
        elif isinstance(message, Reexecute):
            print("reexecute: "+str(message.id))
            greeting = Greeting(message.id, str(self.queue.get(message.id)))
            greeting.sendTo = [self.hello, sender]
            self.send(self.hello, greeting)
        elif isinstance(message, Print):
            print(self.finalValue)
    def receiveMsg_ChildActorExited(self, message, sender):
        print("ChildActorExited")
        print(message)


if __name__ == "__main__":
    supervisor = ActorSystem().createActor(Supervisor)
    ActorSystem().tell(supervisor, Add("Hello"))
    ActorSystem().tell(supervisor, Add("World"))
    ActorSystem().tell(supervisor, Add("Actor"))
    ActorSystem().tell(supervisor, Add("in"))
    ActorSystem().tell(supervisor, Add("Python"))
    sleep(5)
    ActorSystem().tell(supervisor, Print(""))
    print("I just sent a hi....")
    # ActorSystem().tell(supervisor, ActorExitRequest())