PHP 使用使用者排隊機制解決網站大訪問量的例子
阿新 • • 發佈:2019-01-07
如果某些網站提供一些查詢服務,這些資料可能在同一時間被多個使用者訪問,如果不採取措施,資料庫可能會因為大量的訪問而崩潰。下面的程式碼主要是解決在同一時刻,僅允許佇列的前十進入相關操作,而其他的使用者只能等待前面的人操作完成後才能進行訪問。
<?php function mysession_open($save_path,$sesssion_name){ global $sesssion_save_path; //定義session的儲存位置 $sesssion_save_path = "你要儲存的session地址"; return true; } function mysession_close(){ return true; } function mysession_read($key) { global $sesssion_save_path; global $online; //全域性變數,用於存取佇列前面的人數 $online = 0; //初始化 $dir = opendir($sesssion_save_path); //讀取資料夾,獲取資料夾數 while ($file = readdir($dir)) { if($file == ".." || $file ==".") { continue; } if(file_exists($sesssion_save_path.$key){ //如果當前session資料夾已經建立 $mytime = fileatime($sesssion_save_path.$key); if(fileatime($sesssion_save_path.$file) < $mytime){ //計算佇列前面人數的數目 $online++; } } else{ //如果當前session檔案沒有建立 $online++;//計算佇列中的人數 } } if(!file_exists($sesssion_save_path.$key)){ //如果檔案不存在將當前數加1 $online++; } return true; } function mysession_write($key,$data){ global $sesssion_save_path; $fileame = $sesssion_save_path.$key; if(!file_exists($fileame)) { $fp = fopen($fileame, "w");//檔案不存在則建立 fputs($fp,""); fclose($fp); } } function mysession_destory($key) { global $sesssion_save_path; $fileame = $sesssion_save_path.$key; if(file_exists($fileame)){ unlink($fileame); } return true; } function mysession_gc($expiry_time) { //刪除所有過期檔案 global $sesssion_save_path; $dir = opendir($sesssion_save_path); while ($file = readdir($dir)) { # code... if($file == ".." || $file == "."){ continue; } if(fileatime($sesssion_save_path.$file) <= time() - $expiry_time){ unlink($sesssion_save_path.$file); } } return true; } //設定使用者自定義Session儲存 session_set_save_handler('mysession_open', 'mysession_close', 'mysession_read', 'mysession_write', 'mysession_destory', 'mysession_gc'); //判斷佇列前面的人數並進行查詢 session_start(); global $online; echo $online; if($online <= 10){ //如果佇列在前十名,則進行操作 //進行資料庫查詢, //...... //...... //...... //...... session_destroy(); } ?>
以上程式碼通過對Session存取方式的自定義,將SessionID以檔名的方式存入了一個資料夾中。每次開啟頁面時,都要通過當前資料夾中檔案的數量判斷當前使用者所在的位置。如果位置在前十名,則進行資料庫相關操作並刪除Session檔案。這樣做,能夠保證資料庫在大規模的訪問下的穩定性。