自作のWordPressのプラグインで/wp-content/uploads/以下の画像ファイルを別フォルダーにコピーする処理をしています。
その際、failed to open stream http request failed http/1.1 429 too many requests と表示され処理が失敗する場合があります。
エラーは100%発生するわけではなく、かといってサーバー負荷レンタルサーバー会社(エックスサーバー)に確認しております。
特定の時間でのみ発生するというわけでもないようです。
【サーバー環境・仕様】
WordPress5.8
Welcartプラグイン使用
PHP 7.4.25
以下、エラー該当部分のコードとなります。
PHP
1 $cnt = 7; 2 3 for ($i=0; $i<$cnt; $i++) { 4 //画像フォルダのパスをhttpsで取得 5 $bathpath[$i] = usces_the_itemImageURL($i,'return'); 6 7 //画像ファイル名を指定 8 if($i === 0) { 9 $file[$i] = usces_the_itemCode('return').".jpg"; 10 } 11 else { 12 $file[$i] = usces_the_itemCode('return')."_".$i.".jpg"; 13 } 14 15 //上記の処理はファイル名を商品コード.jpgとしていますが、ファイル名のつけ間違いがあった場合、 16 //正しいファイル名に直すため入れています。 17 18 if (!copy($bathpath[$i],pulugin_temp_dir.$file[$i])) { 19 echo $file[$i].'をコピーできませんでした。'; 20 } 21 }
画像のファイルパスの取得をhttpsからサーバーの絶対パスに変更しても症状は改善しませんでした。
どうぞ、お知恵を貸していただけますでしょうか。
追記:
http(s)経由である必要はございません。
処理タイミングは投降・更新ボタンを押した際です。
チェックボックスでオンオフの処理を入れているので、投降・更新ボタンを押した場合に必ず処理が走るわけではございません。
また、画像は cnt= 7としているため、ループは最大で7回、頻度はこの処理が1日に2~3回発生する程度です。
httpsでの処理が問題なのかと、パスを/home/~に変えてもやはりエラーが発生しました。
この処理の目的ですが、他のサーバーに商品画像、商品CSVをアップロードするために作成しています。