Skip to content

retry

Promise를 반환하는 함수가 성공할 때까지 반복해서 실행해요.

typescript
const result = await retry(asyncFunc, options);

사용법

retry(func, options?)

비동기 함수가 실패했을 때 자동으로 재시도하고 싶을 때 retry를 사용하세요. API 호출이나 네트워크 요청처럼 일시적으로 실패할 수 있는 작업에 유용해요.

재시도 횟수, 재시도 간격, 취소 시그널을 설정할 수 있어요. 재시도 간격은 고정값이거나 재시도 횟수에 따라 동적으로 계산하는 함수를 사용할 수 있어요.

typescript
import { retry } from 'es-toolkit/function';

// 기본 사용법 (무한 재시도)
const data1 = await retry(async () => {
  const response = await fetch('/api/data');
  if (!response.ok) throw new Error('Failed to fetch');
  return response.json();
});

// 재시도 횟수 제한
const data2 = await retry(async () => {
  return await fetchData();
}, 3);

// 재시도 간격 설정 (100ms)
const data3 = await retry(
  async () => {
    return await fetchData();
  },
  {
    retries: 3,
    delay: 100,
  }
);

// 동적 재시도 간격 (지수 백오프)
const data4 = await retry(
  async () => {
    return await fetchData();
  },
  {
    retries: 5,
    delay: attempts => Math.min(100 * Math.pow(2, attempts), 5000),
  }
);

특정 에러에서만 재시도하고 싶을 때 shouldRetry 옵션을 사용할 수 있어요.

typescript
import { retry } from 'es-toolkit/function';

class NetworkError extends Error {
  constructor(public status: number) {
    super(`Network error: ${status}`);
  }
}

// 500 에러 이상에서만 재시도
const data5 = await retry(
  async () => {
    const response = await fetch('/api/data');
    if (!response.ok) {
      throw new NetworkError(response.status);
    }
    return response.json();
  },
  {
    retries: 3,
    shouldRetry: (error, attempt) => error instanceof NetworkError && error.status >= 500,
  }
);

AbortSignal을 사용해서 재시도를 취소할 수도 있어요.

typescript
import { retry } from 'es-toolkit/function';

const controller = new AbortController();

// 5초 후 재시도 취소
setTimeout(() => controller.abort(), 5000);

try {
  const data = await retry(
    async () => {
      return await fetchData();
    },
    {
      retries: 10,
      delay: 1000,
      signal: controller.signal,
    }
  );
  console.log(data);
} catch (error) {
  console.log('재시도가 취소되거나 실패했습니다:', error);
}

파라미터

  • func (() => Promise<T>): 재시도할 비동기 함수예요.
  • options (number | RetryOptions, 선택): 재시도 횟수나 옵션 객체예요.
    • retries (number, 선택): 재시도할 횟수예요. 기본값은 Infinity로 무한 재시도해요.
    • delay (number | (attempts: number) => number, 선택): 재시도 간격(밀리초)이에요. 숫자나 함수를 사용할 수 있어요. 기본값은 0이에요.
    • signal (AbortSignal, 선택): 재시도를 취소할 수 있는 시그널이에요.
    • shouldRetry ((error: unknown, attempt: number) => boolean, 선택): 재시도 여부를 결정하는 함수예요. false를 반환하면 즉시 에러를 던져요.
      • error: 발생한 에러 객체예요.
      • attempt: 현재 시도 횟수예요 (0부터 시작).

반환 값

(Promise<T>): 함수가 성공적으로 실행된 결과값을 반환해요.

에러

재시도 횟수가 초과되거나 AbortSignal로 취소되면 마지막 에러를 던져요.

MIT 라이선스에 따라 배포됩니다.