您好,登錄后才能下訂單哦!
本篇內容介紹了“怎么用php腳本實現定時更新商品列表”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
電商項目中為了提高抗并發能力,需要對商品列表做緩存,以下是更新緩存用的腳本:
//PRODUCTION_為緩存商品列表的臨時key //PRODUCTION為緩存商品列表key $con = mysqli_connect($db_config['host'],$db_config['user'],$db_config['passwd'],$db_config['database']); $redis = new Redis(); $redis->connect($redis_config['host']); $redis->del(PRODUCTION_); $sql = "select * from production ORDER BY created_at"; $result = mysqli_query($con,$sql); $artimages = []; while($row = mysqli_fetch_assoc($result)){ $redis->lPush(PRODUCTION_,json_encode($row)); } /* *之所以不直接更新到商品列表是因為當商品列表數據量比較大的時候,腳本執行的時間長, *在del PRODUCTION之后 lPush PRODUCTION之前 用戶訪問網站的時候會出現讀取不到 *商品列表的情況。 *先存入臨時列表,再最后rename為實際被查詢的key */ $redis->rename(PRODUCTION_,PRODUCTION);
上訴腳本只是一個demo,實際應用時需要加鎖,否則在腳本未執行完,又到了crontab下一次自動執行的時候,就會出錯。
以下是crontab腳本:
* * * * * root /usr/local/php/bin/php /xxx/xxxx/xxx/production.php >/dev/null 2>&1 root 是執行腳本的用戶 /usr/local/php/bin/php php腳本解釋器,如果不寫全路徑的話會報錯 >/dev/null 2>&1 忽略日志輸出
“怎么用php腳本實現定時更新商品列表”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。