Wie sperre ich die Schnittstelle in PHP, sodass eine Schnittstelle nur eine Anfrage derselben Person gleichzeitig bearbeiten kann?

WBOY
Freigeben: 2016-09-05 08:59:55
Original
2327 Leute haben es durchsucht

Derzeit verwende ich das Festlegen eines Werts in der Sitzung. Jedes Mal, wenn ich eintrete, beurteile ich, ob der Wert vorhanden ist, was bedeutet, dass er gesperrt ist und diese Anforderung nicht ausgeführt wird nicht vorhanden ist, legen Sie den Wert fest und führen Sie nachfolgende Vorgänge aus.

<code>class controller{
    function index(){
        if(isset($_SESSION['lock']))
            return;
            
        $_SESSION['lock'] = 1;
        sleep(1);//这里会查询用户的资格,并给用户发送流量,如果两次同时进来,会造成两次都认为是有资格的,并且会给用户发两次相同流量
        unset($_SESSION['lock']);
    }
}
</code>
Nach dem Login kopieren
Nach dem Login kopieren

Ich dachte, das wäre möglich, und die Sitzung wird sehr schnell in Redis gespeichert. Bis ich gerade nicht schlafen konnte und daran herumfummelte, stellte ich fest, dass es für einen Benutzer immer noch möglich war, mehrere Anfragen auszuführen die gleiche Schnittstelle zur gleichen Zeit.

Wenn Sie mehrere Anfragen von einer Person gleichzeitig wünschen, wird nur die erste bearbeitet. Um festzustellen, ob es sich um dieselbe Person handelt, beurteilen Sie anhand der Sitzung.

Wie stellen Sie dies sicher?

Antwortinhalt:

Derzeit verwende ich das Festlegen eines Werts in der Sitzung. Jedes Mal, wenn ich eintrete, beurteile ich, ob der Wert vorhanden ist, was bedeutet, dass er gesperrt ist und diese Anforderung nicht ausgeführt wird nicht vorhanden ist, legen Sie den Wert fest und führen Sie nachfolgende Vorgänge aus.

<code>class controller{
    function index(){
        if(isset($_SESSION['lock']))
            return;
            
        $_SESSION['lock'] = 1;
        sleep(1);//这里会查询用户的资格,并给用户发送流量,如果两次同时进来,会造成两次都认为是有资格的,并且会给用户发两次相同流量
        unset($_SESSION['lock']);
    }
}
</code>
Nach dem Login kopieren
Nach dem Login kopieren

Ich dachte, das wäre möglich, und die Sitzung wird sehr schnell in Redis gespeichert. Bis ich gerade nicht schlafen konnte und daran herumfummelte, stellte ich fest, dass es für einen Benutzer immer noch möglich war, mehrere Anfragen auszuführen die gleiche Schnittstelle zur gleichen Zeit.

Wenn Sie mehrere Anfragen von einer Person gleichzeitig wünschen, wird nur die erste bearbeitet. Um festzustellen, ob es sich um dieselbe Person handelt, beurteilen Sie anhand der Sitzung.

Wie stellen Sie dies sicher?

Wenn die Datenbank betroffen ist, sperren Sie sie oder stellen Sie alle Anfragen in eine Warteschlange und verarbeiten Sie sie einzeln

Ich habe darüber nachgedacht und sollte zwei Dinge schreiben, eines ist die Eintrittszeit und die Austrittszeit.
Access beginnt mit dem Schreiben der Startzeit und Exit schreibt die Exit-Zeit.
Gehen Sie davon aus, dass der erste Besuch definitiv leer ist, start=02:26:30 end=02:26:50
Wenn ich dann den Besuch erneut starte, fällen Sie ein Urteil:
< 1>Wenn start>end bedeutet, dass während des Zugriffs
hier eine andere Situation vorliegt, das heißt, der Zugriff wird unterbrochen und es bleibt keine Zeit, die Endzeit zu schreiben. Daher muss hier eine Initialisierungsentscheidung getroffen werden, z. B. start> end&&start-end> ;100 Ende direkt auf die aktuelle Zeit ändern, dann ist es für den Zugriff frei
<2> Wenn start Hinweis: Der Zeitstempel sollte wie folgt sein möglichst auf Mikrosekunden genau sein, um die Berechnung zu erleichtern.

kann über die Datenbank verarbeitet werden. Wenn der Benutzer die Anfrage eingibt, wird die Datenbank nicht ausgeführt 标识 标识Verwenden Sie den Cache, um die ID des verarbeiteten Benutzers zu speichern, verarbeiten Sie die ID durch den Filter, und die Benutzeranforderung geht ein. Wenn der Filter feststellt, dass sich die ID nicht im Cache befindet, wird sie hinzugefügt Die ID wird nach der Verarbeitung gelöscht.

Es gibt viele Methoden. Ich hoffe, Sie können es aus der Perspektive der endgültigen Daten beschreiben.

Ihrer Frage nach zu urteilen, hätten Sie eine irreführende Lösung finden müssen. Es wird empfohlen, dass Sie Ihren ursprünglichen Bedarf angeben.

1. Wenn Sie MySQL verwenden, müssen Sie die Sperre aufheben, bevor andere Anforderungen ausgeführt werden können. Sie können einen zum Zähler hinzufügen und die Anfrage wird beendet. Um den Zähler in Zukunft zu löschen, wird diese Methode empfohlen.

3 Darüber hinaus wird die Dateisitzung selbst gesperrt , andere Anfragen werden ebenfalls blockiert


Nachdem Sie eine Datei eingegeben haben, verwenden Sie die Dateisperre, um die Datei zu entsperren, nachdem der Vorgang abgeschlossen ist. Der nächste Benutzer kann weiter zugreifen und weiter sperren

Verwandte Etiketten:
php
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage