제품 폭주 등 동시성 시나리오에서는 과매도가 발생할 수 있습니다. 이때 동시성으로 인한 문제를 해결해야 합니다.
PHP 언어에는 네이티브가 없습니다. 동시성 솔루션이므로 동시성 제어를 달성하려면 다른 방법이 필요합니다.
옵션 1: 파일 잠금 전용 잠금 사용
flock The 함수는 파일 잠금을 획득하는 데 사용됩니다. 이 잠금은 동시에 하나의 스레드에서만 획득할 수 있습니다. 잠금을 획득하지 못한 다른 스레드는 차단되거나 잠금 획득에 실패합니다. 잠금을 획득할 때 먼저 인벤토리를 쿼리하고, 인벤토리가 0보다 큰 경우 주문하고 인벤토리를 줄인 다음 잠금을 해제합니다(권장 학습:
PHP 비디오 튜토리얼)#🎜🎜 #옵션 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에서는 상품 재고를 주문하기 전에 Decr 작업을 수행할 수 있습니다. 반환된 값이 0 이상이면 주문할 수 있습니다. 그렇지 않으면 이 방법이 더 효율적입니다.
if(redis->get('stock_num') > 0){ stock_num = redis->decr('stock_num') if(stock_num >= 0){ //下订单 }else{ //库存不足 } }else{ //库存不足 }
위 내용은 PHP 인터페이스는 동시성을 어떻게 처리합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!