Dieser Artikel stellt hauptsächlich die Methode zur automatischen Bestätigung der Redis-Warteschlange von E-Commerce-Bestellungen in PHP vor. Ich hoffe, dass er für alle hilfreich ist.
1. Szenario
In der E-Commerce-Plattform haben wir die meisten nach Erhalt der Ware erstellt Die Nutzer werden den Wareneingang nicht aktiv bestätigen, was bei der Zahlungsabwicklung zu diversen Reklamationen seitens der Händler führt. Daher erfolgt je nach Nachfrage eine automatische Bestätigung des Wareneingangs x Tage nach der Lieferung. Bei der sogenannten automatischen Empfangsbestätigung von Bestellungen handelt es sich um die Ausführung einer Update-Anweisung zu einem bestimmten Zeitpunkt, um den Status der Bestellung zu ändern.
2. Ideen
Die umständlichste Methode besteht darin, qualifizierte Bestellungen über geplante Linux-Hintergrundaufgaben abzufragen . Idealerweise funktioniert dieser Ansatz, wenn Bestellungen jede Minute aktualisiert werden müssen. Allerdings ist die Plattform zu klein und die Lieferzeit des Verkäufers ist größtenteils intensiv und wird nicht auf jede Minute der 24 Stunden verteilt. Dann gibt es für geplante Aufgaben zu viele Abfragen und es ist nicht geeignet. Hier können Sie zunächst die Bestellinformationen, die den Empfang automatisch bestätigen, in anderen Medien wie Redis, Memcache, Rabbitmq speichern und dann das Skript ausführen, um die Bestellinformationen zur Beurteilung von den vorherigen Medien abzurufen. Dies kann die Abfrage erheblich reduzieren Druck auf die Datenbank.
Produzent der Redis-Warteschlange
In diesem Zusammenhang entscheiden wir uns dafür, jeden Tag um zwei Uhr morgens geplante Linux-Aufgaben zu verwenden Die Bestellinformationen werden abgefragt und dann in Redis gespeichert. Bei der Abfrage der Bestellung werden die vorherigen Daten nach der Lieferzeit sortiert Die erste Bestellung, die aus der Warteschlange entfernt wird, muss die Bestellung sein, die der angegebenen automatischen Empfangszeit am nächsten liegt. Der Code lautet wie folgt
$successCount=0; $failCount=0; $screen_time = 3600*24*9;//设置筛选天数 $data = array(); $now_time = time(); //查询符合要求的数据 $sql="select id,send_time as deliver_time from `order` where is_send=1 and is_del=0 and is_cancel=0 and is_token=0 and send_time>0 and send_time + {$screen_time} < $now_time order by send_time asc"; $res = $con->query($sql); //当队列还有数据时将数据记录并清除 while($redis->LLEN('auto_recevice_order')){ $txt = '执行时间:'.date('Y-m-d H:i:s').',信息:'.$redis->RPOP('auto_recevice_order'); file_put_contents('./autoToken/fail_log.txt',$txt."\r\n".PHP_EOL,FILE_APPEND); $failCount++; } //重新填充数据进队列 while ($row = $res->fetch_assoc()) { $successCount++; $redis->LPUSH('auto_recevice_order',json_encode($row1)); } $con->close(); $success=date('Y-m-d H:i:s').':[推送成功]:本次成功推送数据:'.$successCount.'条;记录上次处理失败数据:'.$failCount."条\r\n"; file_put_contents('./success_log.txt',$success."\r\n".PHP_EOL,FILE_APPEND);
Der Verbraucher der Redis-Warteschlange
Der Verbraucher der Warteschlange wurde nicht bestanden. Um geplante Aufgaben unter Linux auszuführen, verwenden Sie den Bildschirm- und PHP-CLI-Modus von Linux, um das PHP-Skript auszuführen. Verbraucher müssen lediglich die Bestellinformationen kontinuierlich aus der Warteschlange lesen und dann die Lieferzeit in der Bestellung ermitteln Wenn die Voraussetzungen für den automatischen Empfang erfüllt sind, führen Sie die Update-Anweisung aus. Wenn die Lieferzeit noch nicht erreicht ist und die Lücke zwischen der Lieferzeit und der Lieferzeit relativ groß ist, können Sie das PHP-Skript gleichzeitig für eine bestimmte Anzahl von Malen in den Ruhezustand versetzen. Diese Zeitspanne kann angepasst werden Die erhaltenen Bestellungen, die nicht den Zeitanforderungen entsprechen, müssen in die Redis-Warteschlange verschoben werden, und sie befinden sich ebenfalls an der Spitze der Warteschlange. Damit Sie es beim nächsten Mal bekommen. Der Code lautet wie folgt:
$set_time = 3600*24*10;//设置几天后自动收货 while(true){ if($i%30==0){ usleep(10);//防止while 循环使CPU使用率过高 } if($redis->LLEN('auto_recevice_order')){ $data = json_decode($redis->RPOP('auto_recevice_order')); $id = (int)$data->id;//将数据转化为整形 $deliver_time = (int)$data->deliver_time;//将数据转化为整形 $res1 = $res2 =false; $now_time = time(); if(($deliver_time+$set_time)<$now_time){ $sql1 = "update `order` set `is_token`='1',`token_time` = $now_time where id=$id and is_send=1 and is_del=0 and is_cancel=0 and is_token=0 and send_time + {$set_time} < $now_time"; $res1 = $con->query($sql1);//更新数据 $rows = mysqli_affected_rows($con); if($rows){ $ip = $this->getIp(); $sql2 = "insert into `order_log`(`order_id`,`log_msg`,`log_ip`,`log_role`,`log_user`,`log_order_state`,`log_time`) VALUES($id,'系统自动收货','$ip','系统','服务器','收货',$now_time)";//写入订单日志 $res2 = $con->query($sql2);//添加日志数据 } } if($res1==false){//将没达到条件的数据重新插入队列中 $redis->RPUSH('auto_recevice_order',json_encode(array('id'=>$id,'deliver_time'=>$deliver_time))); } } $i++; }
Um das PHP-Skript hier auszuführen, müssen Sie den Linux-Bildschirm oder den Supervisor oder den Nohup-Daemon verwenden. Für spezifische Verwendungszwecke können Sie sich an Baidu wenden. Es ist am besten, die erforderlichen Protokolldatensätze im selben Skript zu haben.
3. Denken
Mit dem Wachstum des Geschäfts müssen mehrere Bestellungen gleichzeitig in der Warteschlange bearbeitet werden. und Wenn jeweils nur eine relevante Bestellinformation aus der Warteschlange abgerufen werden kann, kann das Modell eines Produzenten und mehrerer Konsumenten übernommen werden. In diesem Fall kann ein Sperrmechanismus verwendet werden, um sicherzustellen, dass eine Nachricht nur einen Konsumenten erreichen kann. Wenn die Redis-Daten eine bestimmte Menge erreichen, können die Ausführungshäufigkeit des Herstellers und die entsprechenden Bedingungen entsprechend angepasst werden.
Der obige Artikel über PHP zur Realisierung der automatischen Bestätigung der Zustellung von E-Commerce-Bestellungen mithilfe der Redis-Warteschlange ist der gesamte vom Herausgeber geteilte Inhalt. Ich hoffe, dass er Ihnen eine Referenz geben kann, und ich hoffe auch, dass dies für alle der Fall ist unterstützt Script Home.
Wie bestätigt eine E-Commerce-Website automatisch den Empfang
PHP-Methode zum Erhalten von 6-stelligen Zufallszahlen, die in Redis nicht vorhanden sind
PHP implementiert Redis Nachrichtenwarteschlange So posten Sie auf Weibo
Das obige ist der detaillierte Inhalt vonPHP-Methode zur Realisierung einer automatischen Bestätigung der Redis-Warteschlange für den E-Commerce-Bestelleingang. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!