「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > 一時的なエラー処理のためにPromis Retryデザインパターンを実装する方法は?

一時的なエラー処理のためにPromis Retryデザインパターンを実装する方法は?

2025-03-23に投稿されました
ブラウズ:667

How to Implement Promise Retry Design Patterns for Transient Error Handling?

retry design Patterns

はじめに

パターン#2:条件が満たされるまで再試行

このパターンは、約束の結果で条件が満たされるまで取得します。再試行と最大試行数の間の遅延を指定します。 .then(function(result){ 新しい約束を返す(function(resolve、拒否){ var intervalid = setInterval(function(){ work.requeststatus(result).then(function(result2){ switch(result2.status){ ケース「進行状況」:ブレイク; //何もしません ケース「成功」:ClearInterval(intervalid); Resolve(result2);壊す; ケース「障害」:ClearInterval(intervalid);拒否(result2);壊す; } })。catch(function(error){clearInterval(intervalid); rexy(error)}); }、1000); }); }) .then(function(){console.log( 'done')}) .catch(console.error);

Promise.retry = function(fn, times, delay) {
    return new Promise(function(resolve, reject){
        var error;
        var attempt = function() {
            if (times == 0) {
                reject(error);
            } else {
                fn().then(resolve)
                    .catch(function(e){
                        times--;
                        error = e;
                        setTimeout(function(){attempt()}, delay);
                    });
            }
        };
        attempt();
    });
};

.catch()chains

は解決するまで再試行します。 var p = promise.reject(); for(var i = 0; i work.publish() .then(function(result){ return new Promise(function(resolve, reject){ var intervalId = setInterval(function(){ work.requestStatus(result).then(function(result2){ switch(result2.status) { case "progress": break; //do nothing case "success": clearInterval(intervalId); resolve(result2); break; case "failure": clearInterval(intervalId); reject(result2); break; } }).catch(function(error){clearInterval(intervalId); reject(error)}); }, 1000); }); }) .then(function(){console.log('done')}) .catch(console.error); retry条件が満たされるまで、遅延はない

var max = 5; var p = promise.reject(); for(var i = 0; i

restry条件が出会うまで再試行し、遅延

var max = 5; var p = promise.reject(); for(var i = 0; i

結論
work.publish()
    .then(function(result){
        return new Promise(function(resolve, reject){
            var intervalId = setInterval(function(){
                work.requestStatus(result).then(function(result2){
                    switch(result2.status) {
                        case "progress": break; //do nothing
                        case "success": clearInterval(intervalId); resolve(result2); break;
                        case "failure": clearInterval(intervalId); reject(result2); break;
                    }
                }).catch(function(error){clearInterval(intervalId); reject(error)});
            }, 1000);
        });
    })
    .then(function(){console.log('done')})
    .catch(console.error);

リリースステートメント この記事は、侵害がある場合は1729587561に複製されています。[email protected]に連絡して削除してください。
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3