>백엔드 개발 >PHP 튜토리얼 >PHP 개발의 동시성 문제를 해결하기 위한 여러 구현 방법 사례 발견

PHP 개발의 동시성 문제를 해결하기 위한 여러 구현 방법 사례 발견

jacklove
jacklove원래의
2018-05-22 18:01:131541검색

이 기사에서는 PHP 개발 시 동시성 문제를 해결하기 위한 여러 구현 방법의 사례 발견을 설명합니다.

이 문서의 예에서는 PHP 개발 시 동시성 문제를 해결하기 위한 여러 구현 방법을 설명합니다. 참고하실 수 있도록 자세한 내용은 다음과 같습니다.

제품 성급 구매와 같은 동시 상황에서는 과판매가 발생할 수 있습니다. 이때 동시성으로 인해 발생하는 이러한 문제는 해결해야 합니다.

에는 모국어가 없습니다. PHP는 동시성 솔루션을 제공하므로 동시성 제어를 달성하려면 다른 방법이 필요합니다.

옵션 1: 파일 잠금 전용 잠금 사용

flock 함수는 파일 잠금을 획득하는 데 사용됩니다. 이 잠금은 동시에 하나의 스레드에서만 획득할 수 있습니다. 잠금을 획득하지 못한 다른 스레드는 차단되거나 획득됩니다. 실패

획득 후 잠금에 도달하면 먼저 인벤토리를 쿼리합니다. 인벤토리가 0보다 크면 주문하고 인벤토리를 줄인 다음 잠금을 해제합니다.

옵션 2: Mysql에서 제공하는 비관적 잠금을 사용합니다. 데이터베이스

Innodb 스토리지 엔진은 행 수준 잠금을 지원합니다. 특정 행 데이터가 잠기면 다른 프로세스가 데이터 행에서 작동할 수 없습니다.

첫 번째 쿼리 및 행 잠금:

   
select stock_num from table where id=1 for update
 
if(stock_num > 0){
 
//下订单
 
update table set stock_num=stock-1 where id=1
 
}

옵션 3: 대기열

을 사용하여 사용자의 주문 요청을 대기열에 순차적으로 저장합니다. 대기열의 주문 요청을 처리하기 위해 백그라운드에서 별도의 프로세스가 사용됩니다. 옵션 4: Redis 사용

Redis 작업은 모두 원자적으로 저장할 수 있습니다. Redis에서 상품 재고를 확인하고, 주문하기 전에 재고에 대한 감소 작업을 수행합니다. 반환된 값이 0보다 크거나 같으면 주문할 수 있고, 그렇지 않으면 이 방법이 더 효율적입니다.

if(redis->get('stock_num') > 0){
 
stock_num = redis->decr('stock_num')
 
if(stock_num >= 0){
 
//下订单
 
}else{
 
//库存不足
 
}
 
}else{
 
//库存不足
 
}

캐시에 실패하면 데이터베이스로 가서 데이터를 가져오고 캐시를 재설정합니다. 이때 동시성이 크면 많은 프로세스가 데이터를 가져오기 위해 데이터베이스로 이동합니다. 동시에 많은 요청이 발생하여

데이터베이스에 침투하여 데이터베이스가 실행됩니다. 여기서는 파일 잠금을 사용하여 해결할 수 있습니다.

이 문서에서는 PHP 개발 및 사례 검색의 동시성 문제를 해결하기 위한 여러 구현 방법을 설명합니다. . 더 많은 관련 내용을 보려면 PHP 중국어 웹사이트를 참고하세요.

관련 권장 사항:

json으로 변환할 때 php에서 쿼리한 데이터가 왜곡되고 중국어 코드가 유니코드가 되는 문제를 해결하는 방법은 무엇입니까?

PHP 배열 순회 예시 설명


PHP 배열 분류 및 배열 생성 예시 설명

위 내용은 PHP 개발의 동시성 문제를 해결하기 위한 여러 구현 방법 사례 발견의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.