PHP에서 파일 잠금과 mysql 테이블 잠금의 일반적인 사용법은 한 사람만 동시에 작동할 수 있다는 것입니다. 이는 여러 사람이 동시에 동일한 파일을 작동하여 데이터 손실이 발생하는 상황을 방지합니다. 아래에서 PHP 파일 잠금 사용법을 소개하겠습니다.
동시성으로 인한 리소스 경쟁 때문에 잠금 메커니즘이 존재합니다. 작업의 효율성과 무결성을 보장하기 위해 잠금 메커니즘을 사용하여 동시 상태를 직렬 상태로 변환할 수 있습니다. 잠금 메커니즘 중 하나로 PHP의 파일 잠금도 리소스 경쟁에 대처하도록 설계되었습니다. 응용 프로그램 시나리오를 가정해 보겠습니다. 대규모 동시성이 있는 경우 fwrite를 사용하여 파일 끝에 데이터를 여러 번 순차적으로 기록하면 어떻게 될까요? 여러 순서의 쓰기 작업은 하나의 트랜잭션과 동일하며 현재 이 트랜잭션의 무결성을 보장해야 합니다.
두 개의 프로그램이 동시에 파일에 데이터를 쓰는 경우 데이터의 무결성을 보장하기 위해 파일 잠금을 추가하고 프로그램 1이 실행된 후 프로그램 1이 먼저 실행되도록 할 수 있습니다. 잠금을 해제한 다음 프로그램 2를 실행해 보세요. 구현 코드는 다음과 같습니다.
$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);
PHP 파일 잠금 관련 글을 좀 더 간략하게 이야기하고 싶다면 PHP 중국어 홈페이지를 주목해주세요!