求並發大俠給解決方案啊....

來源:互聯網
上載者:User
由於有一段代碼要用到while 迴圈代碼,一旦資料量大了就會失敗,求解決方案啊 ....

while($rows = $query->fetch_array()){

if($rows['mingxi_1']=='1'){    $ds = Ssc_Ds($rs['ball_1']);    $dx = Ssc_Dx($rs['ball_1']);    if($rows['mingxi_2']==$rs['ball_1'] || $rows['mingxi_2']==$ds || $rows['mingxi_2']==$dx){             $msql="update c_bet set js=1 where id='".$rows['id']."'";        $mysqli->query($msql) or die ("修改訂單狀態失敗!!!".$rows['id']);        //給會員賬戶增加獎金        $msql="update k_user set money=money+".$rows['win']." where uid=".$rows['uid']."";        $mysqli->query($msql) or die ("修改失敗!!!".$rows['id']);    }else{        //注單未中獎,修改注單內容        $msql="update c_bet set win=0,js=1 where id=".$rows['id']."";        $mysqli->query($msql) or die ("修改失敗!!!".$rows['id']);    }}

回複內容:

由於有一段代碼要用到while 迴圈代碼,一旦資料量大了就會失敗,求解決方案啊 ....

while($rows = $query->fetch_array()){

if($rows['mingxi_1']=='1'){    $ds = Ssc_Ds($rs['ball_1']);    $dx = Ssc_Dx($rs['ball_1']);    if($rows['mingxi_2']==$rs['ball_1'] || $rows['mingxi_2']==$ds || $rows['mingxi_2']==$dx){             $msql="update c_bet set js=1 where id='".$rows['id']."'";        $mysqli->query($msql) or die ("修改訂單狀態失敗!!!".$rows['id']);        //給會員賬戶增加獎金        $msql="update k_user set money=money+".$rows['win']." where uid=".$rows['uid']."";        $mysqli->query($msql) or die ("修改失敗!!!".$rows['id']);    }else{        //注單未中獎,修改注單內容        $msql="update c_bet set win=0,js=1 where id=".$rows['id']."";        $mysqli->query($msql) or die ("修改失敗!!!".$rows['id']);    }}

1.能不能上完整版的代碼?SQL也不捨不得拿出來?
2.目測是SQL的結果集太多,記憶體可能溢出,而且操作可能耗時
3.解決方案:用redis隊列 或者 MySQL隊列解決

迴圈操作的肯定不能再程式裡這樣寫啊。。。你可以建立一個sql表當隊列,或者直接用redis做隊列。。然後新開一個服務或者指令碼專門處理這個任務

估計是處理速度過慢,導致伺服器無法響應新的請求,導致失敗。從代碼看,你的處理模式有問題,最好不使用迴圈一個一個處理訂單,如果可以的話使用資料庫解決,比如預存程序就比較快。

你的 $rs 應該是大數組,而且你在迴圈中使用了mysql查詢,效率會很低。
建議運行一個cli模式的PHP來非同步處理

不想用隊列給你一個非常簡單暴力的多進程思路

對最大的那個查詢結果集根據ID模數進行分流多進程處理,思路類似以下的虛擬碼

        for ($i=1;$i<=100;$i++){            if($i%5==0){                echo 'mod 1 : '.$i.'
'; } if($i%5==1){ echo 'mod 2 : '.$i.'
'; } if($i%5==2){ echo 'mod 3 : '.$i.'
'; } if($i%5==3){ echo 'mod 4 : '.$i.'
'; } if($i%5==4){ echo 'mod 5 : '.$i.'
'; } }

對所有ID根據資料量進行模數拆分,至於你是全部取出來進行拆分,還是直接開5個PHP進程SQL語句查詢的時候就進行拆分,要根據你的商務邏輯來具體分析了。

SQL語句拆5個進程處理類似如下:

SELECT * FROM member where member_id%5=0;SELECT * FROM member where member_id%5=1;SELECT * FROM member where member_id%5=2;SELECT * FROM member where member_id%5=3;SELECT * FROM member where member_id%5=4;

可以在while(1){
一次性取出部分資料處理,然後分批取出處理完成後跳出迴圈
}

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.