getDb()->getAll($sql); $c = count($logs); $sc = 0; $trxIds = array_column($logs, 'redpack_trx_id'); $redpacks = $objRedpack->objTable->getAll(['transfer_trx_id' => $trxIds], ['_field' => 'id, transfer_trx_id']); $redpacks = arrayFormatKey($redpacks, 'transfer_trx_id', 'id'); foreach ($logs as $log) { $trxId = $log['redpack_trx_id']; $redpackId = $redpacks[$trxId] ?: 0; if (!$redpackId) { Eos::log("logId:{$log['id']} miss redpack id"); continue; } $i = 0; do { sleep($i * 0.1); $json = Eos::grabRedpack($redpackId, $trxId, $log['id'], $log['player'], $log['quantity'], $log['net_id']); $ret = json_decode($json, true); $i += 1; } while ($i < 3 && !$ret['transaction_id']); if ($ret['transaction_id']) { $sc += 1; Eos::log("logId:{$log['id']} fix success"); } else { Eos::log("logId:{$log['id']} fix error"); } $req = $log['req_times'] + 1; $objLog->updateObject(['req_times' => $req], ['id' => $log['id']]); } $ct = microtime(true) - $st; Eos::log("处理{$c}记录,成功{$sc},耗时{$ct}");