2014-06-13 14 views
7

Posiadam aktora, a przy niektórych komunikatach uruchamiam metodę zwracającą Future.Kontekst wykonawczy dla kontraktów terminowych w Aktorach

def receive: Receive = { 

    case SimpleMessge() => 
     val futData:Future[Int] = ... 
     futData.map { data => 
      ... 
     } 
} 

Czy można przekazać rzeczywisty kontekst, aby czekać na te dane? Lub Await jest najlepszy, co mogę zrobić, jeśli potrzebuję tych danych w SimpleMessage?

+0

Czego dokładnie szukasz z danymi pochodzącymi z przyszłości? – cmbaxter

+0

To są dane z mojego db (mongo) i chcę je filtrować, a tylko część z nich zapisywać do innej kolekcji. Ale w zasadzie są to dane db, nie mogę tego uruchomić w tle, i muszę poczekać, aby zakończyć tę akcję przed następnym * SimpleMessage *. –

+0

Czy wysyła wiadomość do "nadawcy", czy nie? –

Odpowiedz

10

Jeśli naprawdę trzeba czekać na przyszłość, aby zakończyć przed przetworzeniem następną wiadomość, możesz spróbować czegoś takiego:

object SimpleMessageHandler{ 
    case class SimpleMessage() 
    case class FinishSimpleMessage(i:Int) 
} 

class SimpleMessageHandler extends Actor with Stash{ 
    import SimpleMessageHandler._ 
    import context._ 
    import akka.pattern.pipe 

    def receive = waitingForMessage 
    def waitingForMessage: Receive = { 

    case SimpleMessage() => 
     val futData:Future[Int] = ... 
     futData.map(FinishSimpleMessage(_)) pipeTo self 
     context.become(waitingToFinish(sender)) 
    } 

    def waitingToFinish(originalSender:ActorRef):Receive = { 
    case SimpleMessage() => stash() 

    case FinishSimpleMessage(i) => 
     //Do whatever you need to do to finish here 
     ... 
     unstashAll() 
     context.become(waitingForMessage) 

    case Status.Failure(ex) => 
     //log error here 
     unstashAll() 
     context.become(waitingForMessage)  
    } 
} 

W tym podejściu, możemy przetworzyć SimpleMessage a następnie włącz obsługę logiki ukryta wszystkie kolejne SimpleMessage s otrzymane, dopóki nie otrzymamy wyniku z przyszłości. Kiedy otrzymamy wynik, niepowodzenie lub nie, odetniemy wszystkie pozostałe, które otrzymaliśmy, czekając na przyszłość i udając się na naszą wesołą drogę.

Ten aktor po prostu przełącza się między dwoma stanami, co pozwala tylko w pełni przetworzyć jeden plik SimpleMessage na raz, bez konieczności blokowania przyszłości.

+2

faktycznie zaimportować context.dispatcher działa – Oleg