sentry(react)

1央碟、注冊(cè)賬號(hào)并創(chuàng)建項(xiàng)目

訪問 sentry 的官網(wǎng):https://sentry.io/
注冊(cè)的時(shí)候會(huì)創(chuàng)建組織,注冊(cè)完成后新建項(xiàng)目均函,選擇 React 創(chuàng)建即可

image.png

創(chuàng)建后會(huì)有一個(gè)官方指導(dǎo)亿虽,該如何使用代碼
image.png

創(chuàng)建的時(shí)候根據(jù)上圖的顯示在入口文件配置

import React from 'react';
import ReactDOM from 'react-dom';
import App from './App';
import * as Sentry from '@sentry/browser'; 
Sentry.init({
  dsn: "https://c3091a23d06449af9224614f42a1e1ce@o477214.ingest.sentry.io/5908174",
  tracesSampleRate: 1.0,
  release: 'test0003',
});
ReactDOM.render(<App />, document.getElementById('root'));

2、前端啟動(dòng)

首先安裝 sentry 的瀏覽器包

yarn add @sentry/browser

拋出一個(gè)錯(cuò)誤,然后在 App 中加入了一個(gè) button苞也,并且點(diǎn)擊后會(huì)出現(xiàn)錯(cuò)誤代碼洛勉,導(dǎo)致程序報(bào)錯(cuò)

function App() {
  return (
    <button  
      onClick={() => {  
        const a = {}  
      
        // 此處同樣會(huì)報(bào)錯(cuò)  
        console.log(a.name.name)  
      
        // 拋出錯(cuò)誤  
        new Error('拋出錯(cuò)誤')  
      }}  
    >  
      throw error  
    </button>  
  );
}

export default App;

此時(shí)啟動(dòng)該項(xiàng)目,然后點(diǎn)擊 button如迟,查看 console 就可以發(fā)現(xiàn)出現(xiàn)了報(bào)錯(cuò)

image.png

然后再去我們的系統(tǒng)查看收毫,在問題導(dǎo)航處就會(huì)發(fā)現(xiàn)一個(gè)新的 issue
image.png

打開后可以看到詳細(xì)信息,其中會(huì)發(fā)現(xiàn)并不能準(zhǔn)確的找到源代碼的錯(cuò)誤位置殷勘,只是會(huì)有整個(gè)錯(cuò)誤的路徑和出錯(cuò)人的操作系統(tǒng)此再,瀏覽器信息等
image.png

因此我們需要配置配置sourceMap來定位源碼,上傳 sourceMap 到 sentry 上(我所使用的是webpack的插件@sentry/webpack-plugin

首先安裝下面兩個(gè)包

yarn add @sentry/cli @sentry/webpack-plugin

然后在 webpack.config.js 代碼中配置如下代碼

new SentryPlugin({  
   authToken: 'fc5860731d134aa2b30f247734e97fd6bd3fd9d33aa8423987e6d2df46c5844f',
   org: "project-p0",
   project: "react",
   release: 'test0003',

   // webpack-specific configuration
   include: "./build/static/js",
   urlPrefix: '~/',
   ignore: ["node_modules", "webpack.config.js"]  
 })

如果使用creat-react-app創(chuàng)建的項(xiàng)目需要在根目錄創(chuàng)建一個(gè)config-overrides.js

const { override, addWebpackPlugin } = require('customize-cra');
const SentryPlugin = require('@sentry/webpack-plugin');  
  
module.exports = override(addWebpackPlugin(
    new SentryPlugin({  
        authToken: 'fc5860731d134aa2b30f247734e97fd6bd3fd9d33aa8423987e6d2df46c5844f',
        org: "project-p0",
        project: "react",
        release: 'test0003',

        // webpack-specific configuration
        include: "./build/static/js",
        urlPrefix: '~/',
        ignore: ["node_modules", "webpack.config.js"]  
    })
));
image.png

填寫authToken

image.png

填寫org

image.png

填寫project(這里是有兩個(gè)react項(xiàng)目我用的是第二個(gè)所以project為react)
image.png

Tips

???1.插件方法SentryWebpackPlugin中要設(shè)置release參數(shù)指定版本,同時(shí)Sentry.init方法中也要release參數(shù)指定版本,兩個(gè)版本號(hào)需要保持一致,sourceMap才會(huì)生效

???2.即便上傳了sourceMap和保持release版本號(hào)一致,還需要一個(gè)文件路徑的配置,方便sourceMap定位到要訪問的文件

???3.需要指定urlPrefix參數(shù)urlPrefix不設(shè)置的話,默認(rèn)為~/,~代表網(wǎng)站的協(xié)議和域名

???4.map文件一般被webpack打包在根目錄/static/js/的文件夾下,如訪問https://dsx2016.com,那么map文件就是https://dsx2016.com/static/js/xxx.map,所以要指定urlPrefix為"~/static/js"

???5.如果經(jīng)過nginx等代理導(dǎo)致目錄更深一級(jí)等,就加入到對(duì)應(yīng)的前綴即可,如果nginx代理網(wǎng)站為https://dsx2016.com/home,那么map文件就是https://dsx2016.com/home/static/js/xxx.map,所以要指定urlPrefix為"~/home/static/js",具體的目錄看具體的場(chǎng)景,直接看打包好部署的map在哪個(gè)文件即可

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末玲销,一起剝皮案震驚了整個(gè)濱河市输拇,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌贤斜,老刑警劉巖策吠,帶你破解...
    沈念sama閱讀 218,607評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異瘩绒,居然都是意外死亡猴抹,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門锁荔,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蟀给,“玉大人,你說我怎么就攤上這事堕战±だ#” “怎么了?”我有些...
    開封第一講書人閱讀 164,960評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵嘱丢,是天一觀的道長(zhǎng)薪介。 經(jīng)常有香客問我,道長(zhǎng)越驻,這世上最難降的妖魔是什么汁政? 我笑而不...
    開封第一講書人閱讀 58,750評(píng)論 1 294
  • 正文 為了忘掉前任道偷,我火速辦了婚禮,結(jié)果婚禮上记劈,老公的妹妹穿的比我還像新娘勺鸦。我一直安慰自己,他們只是感情好目木,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,764評(píng)論 6 392
  • 文/花漫 我一把揭開白布换途。 她就那樣靜靜地躺著,像睡著了一般刽射。 火紅的嫁衣襯著肌膚如雪军拟。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,604評(píng)論 1 305
  • 那天誓禁,我揣著相機(jī)與錄音懈息,去河邊找鬼。 笑死摹恰,一個(gè)胖子當(dāng)著我的面吹牛辫继,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播俗慈,決...
    沈念sama閱讀 40,347評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼姑宽,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了闺阱?” 一聲冷哼從身側(cè)響起低千,我...
    開封第一講書人閱讀 39,253評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎馏颂,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體棋傍,經(jīng)...
    沈念sama閱讀 45,702評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡救拉,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,893評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了瘫拣。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片亿絮。...
    茶點(diǎn)故事閱讀 40,015評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖麸拄,靈堂內(nèi)的尸體忽然破棺而出派昧,到底是詐尸還是另有隱情,我是刑警寧澤拢切,帶...
    沈念sama閱讀 35,734評(píng)論 5 346
  • 正文 年R本政府宣布蒂萎,位于F島的核電站,受9級(jí)特大地震影響淮椰,放射性物質(zhì)發(fā)生泄漏五慈。R本人自食惡果不足惜纳寂,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,352評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望泻拦。 院中可真熱鬧毙芜,春花似錦、人聲如沸争拐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽架曹。三九已至隘冲,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間音瓷,已是汗流浹背对嚼。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評(píng)論 1 270
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留绳慎,地道東北人纵竖。 一個(gè)月前我還...
    沈念sama閱讀 48,216評(píng)論 3 371
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像杏愤,于是被迫代替她去往敵國(guó)和親靡砌。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,969評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容