php高並發解決方案有哪些

王林
發布: 2023-03-03 18:40:02
原創
6231 人瀏覽過

php高並發解決方案有:1、使用檔案鎖方法解決;2、使用訊息佇列方法解決;3、如果是分散式叢集伺服器,需要一個或多個佇列伺服器;4、使用Memcache鎖方法解決。

php高並發解決方案有哪些

在秒殺、搶火車票等地方,我們通常會遇到高並發的問題,以下提供了四個解決方案:

(推薦教學:php圖文教學

1、使用檔案鎖定

$fp = fopen("order.lock", "r");
if(flock($fp,LOCK_EX)){ 
//..处理订单的代码
flock($fp,LOCK_UN);
}
fclose($fp);
登入後複製

2、使用訊息佇列

我們常用到Memcacheq、Radis。

例如:有100張票可供用戶搶,那麼就可以把這100張票放到快取中,讀寫時不要加鎖。當並發量大的時候,可能有500人左右搶票成功,這樣對於500後面的請求可以直接轉到活動結束的靜態頁面。進去的500個人中有400個人是不可能取得商品的。

所以可以根據進入隊列的先後順序只能由前100個人購買成功。後面400個人就直接轉到活動結束頁面。當然進去500個人只是舉個例子,至於多少可以自己調整。而活動結束頁面一定要用靜態頁面,不要用資料庫。這樣就減輕了資料庫的壓力。

(影片教學建議:php影片教學

3、如果是分散式叢集伺服器,就需要一個或多個佇列伺服器

#小米和淘寶的搶購還是有稍許不同的,小米重在搶的那瞬間,搶到了名額,就是你的,你就可以下單結算。而淘寶則重在付款的時候的過濾,做了多層過濾,比如要賣10件商品,他會讓大於10的用戶搶到,在付款的時候再進行並發過濾,一層層的減少一瞬間的並發量。

4、使用Memcache鎖定

product_lock_key 為票鎖key。

當product_key存在於memcached中時,所有使用者都可以進入下單一流程。

當進入支付流程時,首先往memcached存放add(product_lock_key, “1″),如果返回成功,進入支付流程。如果不成,則表示已經有人進入支付流程,則執行緒等待N秒,遞歸執行add操作。

以上是php高並發解決方案有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板