Die allgemeine Verwendung von Dateisperren und MySQL-Tabellensperren in PHP besteht darin, dass sie nur von einer Person gleichzeitig bedient werden können. Dadurch wird vermieden, dass mehrere Personen gleichzeitig dieselbe Datei bedienen, was zu Datenverlust führt. Lassen Sie mich im Folgenden die Verwendung der PHP-Dateisperre vorstellen.
Der Sperrmechanismus existiert aufgrund der durch Parallelität verursachten Ressourcenkonkurrenz. Um die Wirksamkeit und Integrität von Vorgängen sicherzustellen, kann der Sperrmechanismus verwendet werden, um gleichzeitige Zustände in serielle Zustände umzuwandeln. Als einer der Sperrmechanismen ist die Dateisperre von PHP auch darauf ausgelegt, dem Ressourcenwettbewerb standzuhalten. Nehmen Sie ein Anwendungsszenario an, bei dem fwrite mehrmals in geordneter Weise an das Ende der Datei geschrieben wird. Was passiert ohne Sperren? Mehrere geordnete Schreibvorgänge entsprechen einer Transaktion, und wir müssen zu diesem Zeitpunkt die Integrität dieser Transaktion sicherstellen.
Wenn zwei Programme gleichzeitig Daten in eine Datei schreiben, können wir eine Dateisperre hinzufügen und Programm 1 zuerst ausführen lassen, um die Integrität der Daten sicherzustellen. Entsperren Sie es und lassen Sie dann Programm 2 ausführen. Der Implementierungscode lautet wie folgt:
$fp = fopen('test.txt',"a"); $count = 10; if (flock($fp, LOCK_EX)) { for($i=1;$i<$count;$i++){ fwrite($fp, 'text2_'.$i."rn"); echo "test2".date('h:i:s') . " "; sleep(1); echo "test2".date('h:i:s'); } flock($fp , LOCK_UN); }else{ echo "Couldn't lock the file !"; } fclose($fp);
Für weitere kurze Informationen zu Artikeln zum Thema PHP-Dateisperre beachten Sie bitte die chinesische PHP-Website!