مراقبة الخلل عن بعد الخفير في تطبيقات التفاعل الأمامية

نحن نبحث في استخدام Sentry مع React.





هذه المقالة جزء من سلسلة تبدأ برسالة خطأ ترقب باستخدام مثال: الجزء 1 .



رد فعل التنفيذ



نحتاج أولاً إلى إضافة مشروع Sentry جديد لهذا التطبيق ؛ من موقع Sentry. في هذه الحالة ، نختار React.



سنعيد تنفيذ زرينا ، Hello و Error ، في تطبيق React. نبدأ بإنشاء تطبيق المبتدئين الخاص بنا:



npx create-react-app react-app


ثم نقوم باستيراد حزمة Sentry:



yarn add @sentry/browser


وتهيئته:



React-app / src / index.js



...
import * as Sentry from '@sentry/browser';

const RELEASE = '0.1.0';
if (process.env.NODE_ENV === 'production') {
  Sentry.init({
    dsn: 'https://303c04eac89844b5bfc908ceffc6757c@sentry.io/1289887',
    release: RELEASE,
  });
}
...


ملاحظات:



  • أثناء التطوير ، لدينا آليات أخرى لمراقبة المشكلات ، مثل وحدة التحكم ، لذلك نقوم فقط بتمكين Sentry لبناء الإنتاج


ثم نقوم بتنفيذ زري Hello و Error ونضيفهم إلى التطبيق:



React-app / src / Hello.js



import React, { Component } from 'react';
import * as Sentry from '@sentry/browser';

export default class Hello extends Component {
  state = {
    text: '',
  };
  render() {
    const { text } = this.state;
    return (
      <div>
        <button
          onClick={this.handleClick}
        >
          Hello
        </button>
        <div>{text}</div>
      </div>
    )
  }

  handleClick = () => {
    this.setState({
      text: 'Hello World',
    });
    try {
      throw new Error('Caught');
    } catch (err) {
      if (process.env.NODE_ENV !== 'production') {
        return;
      }
      Sentry.captureException(err);
    }
  }
}


response-app / src / MyError.js



import React, { Component } from 'react';

export default class MyError extends Component {
  render() {
    return (
      <div>
        <button
          onClick={this.handleClick}
        >
          Error
        </button>
      </div>
    )
  }

  handleClick = () => {
    throw new Error('Uncaught');
  }
}


React-app / src / App.js



...
import Hello from './Hello';
import MyError from './MyError';

class App extends Component {
  render() {
    return (
      <div className="App">
        ...
        <Hello />
        <MyError />
      </div>
    );
  }
}

export default App;


المشكلة (خرائط المصدر)



يمكننا اختبار Sentry من خلال تجميع إنتاج عن طريق إدخال:



yarn build


ومن مجلد البناء أدخل:



npx http-server -c-1


المشكلة التي سنواجهها على الفور هي أن إدخالات خطأ الحارس تشير إلى أرقام الأسطر في الحزمة المصغرة ؛ غير مفيد للغاية.





Sentry , . localhost ( Sentry).



( )



-. , GitHub Pages (). :



  1. build docs .



  2. GitHub Pages ( GitHub), docs master



  3. GitHub





: , , create-create-app . package.json:



"homepage": "https://larkintuckerllc.github.io/hello-sentry/"


:



https://larkintuckerllc.github.io/hello-sentry/





Hello.





, :





:



  • , BRAVO.




, Error.





, :





()







JavaScript . React, React 16 " ".



– React, JavaScript , , . , .











. React 16, , - , React.



Dan Abramov — Error Handling in React 16

, , , , , (, , ). , Error; .



, .



react-app / src / MyRenderError



import React, { Component } from 'react';

export default class MyRenderError extends Component {
  state = {
    flag: false,
  };
  render() {
    const { flag } = this.state;
    return (
      <div>
        <button
          onClick={this.handleClick}
        >
          Render Error
        </button>
        { flag && <div>{flag.busted.bogus}</div> }
      </div>
    )
  }

  handleClick = () => {
    this.setState({
      flag: true,
    });
  }
}


:



  • , React flag.busted.bogus,







( componentDidCatch); , , , :



react-app / src / ErrorBoundary.js



import React, { Component } from 'react';
import * as Sentry from '@sentry/browser';

export default class ErrorBoundary extends Component {
  constructor(props) {
    super(props);
    this.state = { hasError: false };
  }

  componentDidCatch(err, info) {
    this.setState({ hasError: true });
    Sentry.captureException(err);
  }

  render() {
    if (this.state.hasError) {
      return <h1>Something went wrong.</h1>;
    }
    return this.props.children;
  }
}


, :



react-app / src / App.js



...
import MyRenderError from './MyRenderError';

class App extends Component {
  render() {
    return (
      <ErrorBoundary>
        <div className="App">
          ...
        </div>
      </ErrorBoundary>
    );
  }
}
...


Render Error Sentry.









, .



P.S.



P.S. Sentry https://t.me/sentry_ru




All Articles