Thread Mojolicious/Hypnotoad: Horizontale Delegation zwischen Workern?
(4 answers)
Opened by flowdy at 2015-06-20 16:09
Ich suche nach einer Möglichkeit, einem Request in Mojolicious, das betrieben wird mit Mojo::Server::Prefork oder Mojo::Server::Hypnotoad, einen Callback mitzugeben, der dann verwendet wird à la
Code: (dl
)
1 my $user_id = $self->session("user_id"); Zur Klärung, warum ich denke, dass ich das überhaupt benötige. Nicht auszuschließen, dass ich mir einen Knoten ins Hirn gemacht habe und ihr mir helfen könnt, das zu fixen: Die User-Objekte in meiner Webapplikation enthalten komplizierte Datenstrukturen, deren Berechnung viel CPU-Zeit kostet, ergo für aufeinanderfolgende Requests im Speicher vorgehalten werden sollen. Storable und darauf basierende Module gehen wg. Closures leider nicht – zumindest nicht ohne Klimmzüge, die ich selbst als Code-smell betrachten würde. Daraus ergibt sich das Problem, dass, so jedenfalls meine Befürchtung, nicht mehrere Worker Requests abarbeiten können. Wenn zwei Requests vom gleichen User nacheinander ausgelöst werden, die Modifikationen im Datenbestand vornehmen, die wiederum dazu führen, dass Teile der Datenstrukturen und Objekte neu berechnet werden müssen, so muss bei der Abarbeitung des zweiten Requests der verantwortliche Worker-Prozess irgendwie mitkriegen, dass er seine Datenstrukturen erst mal auf den aktuellen Stand bringen muss. Klar sind Workarounds denkbar: So mit Zeitstempeln und entsprechenden Checks, ob irgendwelche Daten veraltet sind. Aber entweder,
Also habe ich bei meinen Recherchen etwas übersehen? Vielen Dank, flowdy package MyClass; sub new {\b\b\b\b\b\b\b\b\buse Moose;
|