• /
  • EnglishEspañol日本語한국어Português
  • 로그인지금 시작하기

사용자의 편의를 위해 제공되는 기계 번역입니다.

영문본과 번역본이 일치하지 않는 경우 영문본이 우선합니다. 보다 자세한 내용은 이 페이지를 방문하시기 바랍니다.

문제 신고

noticeError

통사론

newrelic.noticeError(error object $error, [object $customAttributes])

앱 작동을 방해하지 않고 브라우저 오류를 식별합니다.

요구 사항

설명

이 호출을 사용하여 앱에서 처리된 오류 또는 기타 기타 오류를 확인하거나 기록합니다. 이는 오류를 포착하고 처리했지만 여전히 앱 작동을 방해하지 않고 오류를 식별하려는 경우에 유용합니다.

또한 API를 사용하면 스크립트 초기화 중 또는 인라인 이벤트 핸들러에서 발생하는 오류와 같이 세부 정보 없이 보고되는 오류를 확인할 수도 있습니다. 오류는 뉴렐릭이 일반적으로 감지하는 다른 오류와 함께 Errors 페이지 에 표시됩니다. 또한 JavaScriptError 이벤트 로 기록됩니다. 예를 들어:

var err = new Error('Report caught error to New Relic');
newrelic.noticeError(err);

참고: 단일 요청에서 1000개 이상의 JavaScriptError 이벤트가 전송되면 1000개의 개별 이벤트만 기록됩니다. 그러나 총 이벤트 수는 내부적으로 보존되며 EXTRAPOLATE 쿼리 절 을 사용하여 액세스할 수 있습니다.

매개변수

매개변수

설명

$error

오류 개체

필수의. 브라우저의 Errors 페이지 에서 데이터를 분석할 때 사용할 수 있는 의미 있는 오류 메시지를 제공하세요.

$customAttributes 물체

선택 과목. 사용자 정의 속성을 나타내는 이름/값 쌍을 포함하는 객체입니다.

중요하지 않은 오류

이 예는 newrelic.noticeError API를 사용하여 애플리케이션을 방해하지 않으려는 발견된 오류를 보고하는 방법을 보여줍니다. 이는 중요하지 않은 오류가 사용자 경험에 영향을 미치지 않지만 여전히 개발자에게 보고하려는 경우에 유용합니다. 예제 코드는 잘못된 JSON의 경우 기본 foo 객체를 안전하게 사용합니다.

var foo;
try {
foo = JSON.parse('{ "bar"');
} catch (err) {
// Report caught error to New Relic
newrelic.noticeError(err);
foo = { bar: 'default value' };
}
alert(foo.bar);

선택적 오류가 있는 콜백

이 예제는 Node.js에서 대중화되고 Browserify 개발에서 일반적으로 사용되는 오류 및 응답 패턴 콜백을 사용할 때 New Relic에 오류를 보고하는 방법을 보여줍니다. alert(body); 을 자신의 관련 메시지로 바꿀 수 있습니다.

var xhr = require('xhr');
xhr('http://localhost:8080', function(err, resp, body) {
// Report unthrown error to New Relic
if (err) return newrelic.noticeError(err);
// Handle successful response
alert(body);
});

프라미스 기반 API 예시

Promise는 비동기식 상호 작용을 처리하기 위한 단일 패턴을 제공하여 비동기식 오류를 쉽게 처리할 수 있도록 합니다. 그러나 이렇게 하면 오류를 완전히 무시할 수 있으므로 개발자가 볼 수 없는 방식으로 응용 프로그램이 손상됩니다. 이 예제에서는 이러한 비동기 오류를 New Relic에 보고하여 간과되지 않도록 합니다.

var rest = require('rest');
rest('/').then(function(res) {
// Handle successful response
alert(res.entity);
}, function(err) {
// Report unthrown error to New Relic
newrelic.noticeError(err);
});

사용자 정의 속성 캡처 예

try {
// code that throws an error
} catch (err) {
newrelic.noticeError(err, { attribute1: 'value1', attribute2: 2 });
}

브라우저 제한 사항(Apple Safari 및 Microsoft Internet Explorer만 해당)

오류가 발견되어 다시 발생하면 스택 추적이 없습니다. 이러한 경우 newrelic.noticeError API가 모든 브라우저 유형에 대한 스택 추적을 보고하도록 하려면 이를 catch 문의 API에 전달해야 합니다.

try {
throw errorObject;
} catch (err) {
newrelic.noticeError(err);
throw err; // loses stack trace!
}
Copyright © 2024 New Relic Inc.

This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply.