解析Sentry?Relay?二次開發(fā)調(diào)試
開發(fā)
要構(gòu)建 Relay
,我們需要最新的穩(wěn)定版 Rust
。crate
被拆分為具有多個(gè)功能的工作區(qū),因此在運(yùn)行構(gòu)建或運(yùn)行測(cè)試時(shí),請(qǐng)始終確保傳遞 --all
和 --all-features
標(biāo)志。processing
功能還需要 C
編譯器和 CMake
。
要安裝開發(fā)環(huán)境,必須安裝 librdkafka
并在 path
上。 在 macOS
上,我們需要使用 brew install librdkafka
安裝它,因?yàn)榘惭b腳本使用 brew --prefix
來(lái)確定正確的位置。
我們使用 VSCode
進(jìn)行開發(fā)。此存儲(chǔ)庫(kù)包含配置代碼樣式、linter
和有用功能的設(shè)置文件。 首次打開項(xiàng)目時(shí),請(qǐng)確保 安裝推薦擴(kuò)展,因?yàn)樗鼈儗⒃试S編輯器在編碼期間提供幫助。
存儲(chǔ)庫(kù)的根目錄包含一個(gè) Makefile
,其中包含用于開發(fā)的有用命令:
make check
: 運(yùn)行代碼格式檢查和linter
。這在打開pull request
之前很有用。make test
: 運(yùn)行單元測(cè)試、集成測(cè)試和 Python 包測(cè)試(有關(guān)更多信息,請(qǐng)參見(jiàn)下文)。make all
: 運(yùn)行所有檢查和測(cè)試。這會(huì)運(yùn)行在CI
中也執(zhí)行的大多數(shù)任務(wù)。make clean
: 刪除所有構(gòu)建工件、virtualenv
和緩存文件。
集成測(cè)試要求 Redis
和 Kafka
在其默認(rèn)配置中運(yùn)行。 獲取所有必需服務(wù)的最便捷方式是通過(guò) sentry devservices
,這需要最新的 Sentry
開發(fā)環(huán)境。
sentry devservices
https://develop.sentry.dev/services/devservices
構(gòu)建和運(yùn)行
重建和運(yùn)行 Relay
的最簡(jiǎn)單方法是使用 cargo
。根據(jù)配置,您可能需要運(yùn)行 Sentry
的本地實(shí)例。
# 第一次初始化 Relay cargo run --all-features -- config init # 重建并運(yùn)行所有功能 cargo run --all-features -- run
標(biāo)準(zhǔn)構(gòu)建命令也可用作 make
目標(biāo)。請(qǐng)注意,發(fā)布版本仍會(huì)生成調(diào)試信息。
# 在調(diào)試模式下不進(jìn)行優(yōu)化構(gòu)建。 make build # 使用發(fā)布優(yōu)化和調(diào)試信息進(jìn)行構(gòu)建。 make release
為了在進(jìn)行一些更改后快速驗(yàn)證 Relay
是否編譯,您還可以使用 cargo check
:
cargo check --all --all-features
功能
默認(rèn)情況下,Relay
編譯時(shí)不使用 processing 模式。 這是用于作為代理運(yùn)行的中繼的配置。有兩個(gè)可選功能:
processing
: 啟用事件處理(event processing)
和攝取(ingestion)
功能。這允許在配置中啟用 processing。啟用后,Relay
會(huì)將事件生成到Kafka topic
中,而不是轉(zhuǎn)發(fā)到配置的上游。此外,它將執(zhí)行完整的事件規(guī)范化
、過(guò)濾
和速率限制
。ssl
: 在服務(wù)器中啟用SSL
支持。
要啟用功能,請(qǐng)將其傳遞給 cargo
調(diào)用。例如,要在啟用了 processing
功能的情況下跨所有 workspace crates
運(yùn)行測(cè)試,請(qǐng)運(yùn)行:
cargo run --features=processing
測(cè)試
測(cè)試套件包括單元測(cè)試、集成測(cè)試套件和 Python
包的單獨(dú)測(cè)試套件。單元測(cè)試是作為 Rust crates
的一部分實(shí)現(xiàn)的,可以通過(guò)以下方式運(yùn)行:
# 測(cè)試默認(rèn)功能 make test-rust # 為所有功能運(yùn)行 Rust 測(cè)試 make test-rust-all
集成測(cè)試套件需要 python
。默認(rèn)情況下,集成測(cè)試套件將創(chuàng)建一個(gè) virtualenv
,構(gòu)建啟用處理的 Relay
二進(jìn)制文件,并運(yùn)行一組集成測(cè)試:
# 創(chuàng)建一個(gè)新的 virtualenv,構(gòu)建 Relay 并運(yùn)行集成測(cè)試 make test-integration # 手動(dòng)構(gòu)建和運(yùn)行單個(gè)測(cè)試 make build .venv/bin/pytest tests/integration -k <test_name>
Linting
我們使用來(lái)自最新穩(wěn)定通道的 rustfmt
和 clippy
進(jìn)行代碼格式化和 linting
。 要確保正確設(shè)置這些工具并使用正確的配置運(yùn)行,請(qǐng)使用以下 make
目標(biāo):
# 格式化整個(gè)代碼庫(kù) make format # 在整個(gè)代碼庫(kù)上運(yùn)行 clippy make lint
Python 和 C-ABI
潛在地,還需要將新功能添加到 Python
包中。這首先需要在 C ABI
中公開新功能。 為此,請(qǐng)參閱 Relay C-ABI readme。
- Relay C-ABI readme
https://getsentry.github.io/relay/relay_cabi/
我們強(qiáng)烈建議在 virtual
environment 中開發(fā)和測(cè)試 python
包。更新和測(cè)試 ABI
后,確保 virtualenv
處于活動(dòng)狀態(tài)并安裝構(gòu)建原生庫(kù)的包。有兩種安裝方法:
# 安裝發(fā)布版本,推薦: pip install --editable ./py # 安裝調(diào)試版本,安裝速度更快,但運(yùn)行時(shí)慢得多: RELAY_DEBUG=1 pip install --editable ./py
對(duì)于測(cè)試,我們使用無(wú)處不在的 pytest
。 同樣,確保您的 virtualenv
處于活動(dòng)狀態(tài)并且已安裝最新版本的原生庫(kù)。然后,運(yùn)行:
# 創(chuàng)建一個(gè)新的 virtualenv,安裝發(fā)布版本并運(yùn)行測(cè)試 make test-python # 手動(dòng)運(yùn)行單個(gè)測(cè)試 .venv/bin/pytest py/tests -k <test_name>
開發(fā) Server
如果你安裝了 systemfd
和 cargo-watch
,make devserver
命令可以自動(dòng)重新加載 Relay
:
cargo install systemfd cargo-watch make devserver
SSL
該存儲(chǔ)庫(kù)包含用于開發(fā)目的的 SSL-certificate
+ private key
。它有兩種格式:一種是 (.pem
, .cert
) 對(duì),一種是 .pfx
(PKCS #12
) 文件。
密碼,.pfx
文件是 password
。
與 Sentry 一起使用
要使用現(xiàn)有的 Sentry devserver
、self-hosted Sentry
安裝或 Sentry SaaS
開發(fā) Relay
,請(qǐng)將 .relay/config.yml
中的 upstream
配置為 Sentry server
的 URL
。 例如,在本地開發(fā)中將 relay.upstream
設(shè)置為 http://localhost:8000/
。
要使用本地 development Sentry
測(cè)試 processing
模式,請(qǐng)使用以下配置:
relay: # 指向您的 Sentry devserver URL: upstream: http://localhost:8000/ # 監(jiān)聽(tīng) 3000 以外的端口: port: 3001 logging: # 啟用完整的日志記錄和回溯: level: trace enable_backtraces: true limits: # 在 ^C 上加速 shutdown shutdown_timeout: 0 processing: # 啟用存儲(chǔ)規(guī)范化的 processing 模式并將數(shù)據(jù)發(fā)布到 Kafka: enabled: true kafka_config: - { name: "bootstrap.servers", value: "127.0.0.1:9092" } - { name: "message.max.bytes", value: 2097176 } redis: "redis://127.0.0.1"
請(qǐng)注意,Sentry devserver
還在 processing
模式下在端口 3000
上以類似配置啟動(dòng) Relay
。 該 Relay
不會(huì)干擾您的開發(fā)構(gòu)建。為確保 SDK
發(fā)送到您的開發(fā)實(shí)例,請(qǐng)更新 DSN
中的端口:
發(fā)布管理
我們使用 craft 來(lái)發(fā)布新版本。有兩個(gè)單獨(dú)的項(xiàng)目要發(fā)布:
- Relay binary 從根文件夾中發(fā)布。在該目錄中運(yùn)行
craft prepare
和craft publish
以分別創(chuàng)建發(fā)布版本并發(fā)布它。我們使用日歷版本控制并與Sentry
協(xié)調(diào)發(fā)布。
Relay Python library 和 C-ABI
從 py/
子文件夾中發(fā)布。切換到該目錄并運(yùn)行 craft prepare
和 craft publish
。我們?cè)陂_發(fā)周期中使用語(yǔ)義版本控制和發(fā)布。
- craft
https://github.com/getsentry/craft
- 日歷化版本
- 語(yǔ)義版本控制
變更日志說(shuō)明
對(duì)于暴露給 Python package 的更改,請(qǐng)?jiān)?py/CHANGELOG.md
中添加一個(gè)條目。這包括但不限于事件規(guī)范化
、PII 清理
和協(xié)議
。對(duì)于 Relay server 的更改,請(qǐng)?jiān)?CHANGELOG.md
的以下標(biāo)題下添加一個(gè)條目:
Features
: 用于新的用戶可見(jiàn)功能。Bug Fixes
: 用于用戶可見(jiàn)的錯(cuò)誤修復(fù)。Internal
: 用于內(nèi)部操作中的功能和錯(cuò)誤修復(fù),尤其是processing
模式。
在 changelog
條目中,請(qǐng)?zhí)砑又赶虼?PR
的鏈接(考慮更具描述性的消息):
- ${getCleanTitle()}. (${PR_LINK})
如果以上都不適用,您可以通過(guò)在 PR
描述中添加 #skip-changelog
來(lái)選擇退出。
更多
Sentry Web 前端監(jiān)控 - 最佳實(shí)踐(官方教程)
Sentry 后端監(jiān)控 - 最佳實(shí)踐(官方教程)
到此這篇關(guān)于Sentry Relay 二次開發(fā)調(diào)試簡(jiǎn)介的文章就介紹到這了,更多相關(guān)Sentry Relay 二次開發(fā)調(diào)試簡(jiǎn)介內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python實(shí)現(xiàn)內(nèi)存監(jiān)控系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)內(nèi)存監(jiān)控系統(tǒng),通過(guò)系統(tǒng)命令或操作系統(tǒng)文件獲取到內(nèi)存信息,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-06-06Python Pandas知識(shí)點(diǎn)之缺失值處理詳解
這篇文章主要給大家介紹了關(guān)于Pandas知識(shí)點(diǎn)之缺失值處理的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05Python設(shè)計(jì)模式之代理模式實(shí)例詳解
這篇文章主要介紹了Python設(shè)計(jì)模式之代理模式,結(jié)合實(shí)例形式較為詳細(xì)的分析了代理模式的概念、原理及Python定義、使用代理模式相關(guān)操作技巧,需要的朋友可以參考下2019-01-01Python對(duì)象的屬性訪問(wèn)過(guò)程詳解
這篇文章主要介紹了Python對(duì)象的屬性訪問(wèn)過(guò)程詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-03-03在pytorch中對(duì)非葉節(jié)點(diǎn)的變量計(jì)算梯度實(shí)例
今天小編就為大家分享一篇在pytorch中對(duì)非葉節(jié)點(diǎn)的變量計(jì)算梯度實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-01-01selenium動(dòng)態(tài)數(shù)據(jù)獲取的方法實(shí)現(xiàn)
本文主要介紹了selenium動(dòng)態(tài)數(shù)據(jù)獲取的方法實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07如何用python獲取EXCEL文件內(nèi)容并保存到DBC
很多時(shí)候,使用python進(jìn)行數(shù)據(jù)分析的第一步就是讀取excel文件,下面這篇文章主要給大家介紹了關(guān)于如何用python獲取EXCEL文件內(nèi)容并保存到DBC的相關(guān)資料,需要的朋友可以參考2023-12-12