概述

如果您使用 PyCharm 进行开发,则需要配置一些内容才能运行和调试。

本文档描述了一些对 sentry 开发有用的配置

配置

Python 解释器:(确保它是 venv 解释器)例如 ~/venv/sentry/bin/python

要创建配置(run/debug 配置),只需转到 Run | Edit Configurations...(也可在默认工具栏中使用)。

Test runner

Sentry 使用 pytest 进行单元测试。

创建 pytest 配置(在 Python tests 下)

设定目标(Set Target): Custom

附加参数(Additional Arguments): tests/sentry

具有所需一切的 Dev server

用于在所有设置(webworkercron)的情况下运行(非调试):

  • 创建另一个 Python 配置
  • 脚本路径(Script path): <venv dir>/bin/sentry e.g. ~/venv/sentry/bin/sentry
  • 参数(Parameters): devserver --workers
  • Python 解释器(Python interpreter): venv interpreter
  • 工作目录(Working dir): (sentry 安装目录中的 src 路径) e.g. ~/dev/sentry/src

Note: 您将无法使用此配置调试 Web WorkerWeb Worker 是通过调用 uwsgi 服务器启动的)。

使用 PyCharm 进行调试

devserver 命令的存在主要是为了在单独的进程中生成守护进程,这意味着在默认模式下将 debugger 附加到它并不是很有用。

Web server

devserver 命令有一个特殊的标志,它将导致 web server 在同一进程的线程中启动(而不是作为 web 守护进程)。这允许启动 devserver 的相同 PyCharm "Debug" 动作附加到 web server 并在其后端命中断点。

克隆你的 devserver 运行配置并将 --debug-server 添加到 "Parameters" 字段的末尾。通过选择 "Debug" 而不是 "Run" 来启动它。

--debug-server 标志可能会导致进程无法正确响应 SIGINT 并且关闭得比原始配置更不优雅。建议保留两者,将第一个与 Run 命令一起使用,将第二个与 Debug 命令一起使用。

您可以将 --workers 标志与 --debug-server 一起保留,但请注意,不可能将断点附加到 workers ,也不能附加到由 devserver 产生的任何其他守护进程。

独立守护进程

要将 debugger 附加到除 web 之外的单个守护程序,请为守护程序创建运行配置。以下属性应与您的 devserver 配置相同。(您可以克隆它并仅更改 Parameters 字段。)

  • 脚本路径(Script path): <venv dir>/bin/sentry,例如: ~/venv/sentry/bin/sentry
  • Python 解释器(Python interpreter): venv interpreter
  • 工作目录(Working dir): (sentry 安装目录中的 src 路径)例如 ~/dev/sentry/src

将新运行配置的参数设置为启动守护程序的 run 命令,例如:

  • run cron
  • run worker -c 1

提示和故障排除

  • 如果您想调试它,相同的一组修改将适用于 getentry 项目的运行配置。
  • PyCharmCompound 运行配置类型对于一次启动多个运行配置很有用。如果您正在调试一个或多个与开发服务器协同的独立守护进程,那么设置一个可能会很方便。

  • 如果您希望 Sentry 在调试环境中的行为不同于常规运行中的行为,您可以添加任意环境变量,然后在您的 .sentry/sentry.conf.py 文件中检查它们。

    例如,下面的屏幕截图显示了调试时禁用 APM 采样的设置(因为在断点处停止会污染时间测量)。请注意,PYCHARM_DEBUG 是一个任意名称;它对 PyCharmSentry 没有特殊意义。

  • 如果您单独运行的守护进程不工作,您可以通过调试 devserver --debug-server 并在 src/sentry/runner/commands/devserver.py 上插入断点来进行故障排除。 这将让您手动检查 devserver 命令正在运行的命令。(在底部附近寻找 manager.add_process 调用。)尝试调整运行配置中的参数以匹配这些命令,如果它们还没有的话。

更多

Sentry 开发者贡献指南 - 配置 PyCharm的更多相关文章

  1. Sentry 开发者贡献指南 - 数据库迁移

    Django 迁移是我们处理 Sentry 中数据库更改的方式. Django 迁移官方文档:https://docs.djangoproject.com/en/2.2/topics/migratio ...

  2. Sentry 开发者贡献指南 - 后端服务(Python/Go/Rust/NodeJS)

    内容整理自官方开发文档 系列 1 分钟快速使用 Docker 上手最新版 Sentry-CLI - 创建版本 快速使用 Docker 上手 Sentry-CLI - 30 秒上手 Source Map ...

  3. Sentry 开发者贡献指南 - SDK 开发(性能监控)

    内容整理于官方开发文档 系列 Docker Compose 部署与故障排除详解 K8S + Helm 一键微服务部署 Sentry 开发者贡献指南 - 前端(ReactJS生态) Sentry 开发者 ...

  4. Sentry 开发者贡献指南 - SDK 开发(事件负载)

    内容整理自官方开发文档 系列 Docker Compose 部署与故障排除详解 1 分钟快速使用 Docker 上手最新版 Sentry-CLI - 创建版本 快速使用 Docker 上手 Sentr ...

  5. Sentry 开发者贡献指南 - SDK 开发(性能监控:Sentry SDK API 演进)

    内容整理自官方开发文档 本文档的目标是将 Sentry SDK 中性能监控功能的演变置于上下文中. 我们首先总结了如何将性能监控添加到 Sentry 和 SDK, 然后我们讨论 identified ...

  6. Sentry 开发者贡献指南 - Feature Flag

    功能 flag 在 Sentry 的代码库中声明. 对于自托管用户,这些标志然后通过 sentry.conf.py 进行配置. 对于 Sentry 的 SaaS 部署,Flagr 用于在生产中配置标志 ...

  7. Sentry 开发者贡献指南 - Django Rest Framework(Serializers)

    Serializer 用于获取复杂的 python 模型并将它们转换为 json.序列化程序还可用于在验证传入数据后将 json 反序列化回 Python 模型. 在 Sentry,我们有两种不同类型 ...

  8. Sentry 开发者贡献指南 - 前端 React Hooks 与虫洞状态管理模式

    系列 Sentry 开发者贡献指南 - 前端(ReactJS生态) Sentry 开发者贡献指南 - 后端服务(Python/Go/Rust/NodeJS) 什么是虫洞状态管理模式? 您可以逃脱的最小 ...

  9. Sentry 开发者贡献指南 - 前端(ReactJS生态)

    内容整理自官方开发文档 系列 1 分钟快速使用 Docker 上手最新版 Sentry-CLI - 创建版本 快速使用 Docker 上手 Sentry-CLI - 30 秒上手 Source Map ...

随机推荐

  1. [BUUCTF]PWN6——ciscn_2019_c_1

    [BUUCTF]PWN6--ciscn_2019_c_1 题目网址:https://buuoj.cn/challenges#ciscn_2019_c_1 步骤: 例行检查,64位,开启了nx保护 nc ...

  2. Linux centos 安装Docker

    安装docker需要centos7 内核3.1以上 基本上centos7以上的都支持, 然后先更新到最新 sudo yum update 然后直接安装 sudo yum install docker ...

  3. Python的 垃圾回收机制

    垃圾回收 1. 小整数对象池 整数在程序中的使用非常广泛,Python为了优化速度,使用了小整数对象池, 避免为整数频繁申请和销毁内存空间. Python 对小整数的定义是 [-5, 257) 这些整 ...

  4. IO多路复用之select总结(转载)

    1.基本概念 IO多路复用是指内核一旦发现进程指定的一个或者多个IO条件准备读取,它就通知该进程.IO多路复用适用如下场合: (1)当客户处理多个描述字时(一般是交互式输入和网络套接口),必须使用I/ ...

  5. Libevent使用例子

    初等: 客户端代码: #include<sys/types.h> #include<sys/socket.h> #include<netinet/in.h> #in ...

  6. Spring核心原理之 IoC容器中那些鲜为人知的细节(3)

    本文节选自<Spring 5核心原理> Spring IoC容器还有一些高级特性,如使用lazy-init属性对Bean预初始化.使用FactoryBean产生或者修饰Bean对象的生成. ...

  7. C笔试题:将int型数组强制转换为char*,再求strlen,涉及大小端

    1 #include<stdio.h> 2 #include<string.h> 3 int main() 4 { 5 int a[2000]; 6 char *p = (ch ...

  8. NLTK 3.2.5 documentation Installing NLTK

    Installing NLTK NLTK requires Python versions 2.7, 3.4, or 3.5 Mac/Unix Install NLTK: run sudo pip i ...

  9. 【剑指Offer】二叉搜索树的后序遍历序列 解题报告(Python)

    [剑指Offer]二叉搜索树的后序遍历序列 解题报告(Python) 标签(空格分隔): 剑指Offer 题目地址:https://www.nowcoder.com/ta/coding-intervi ...

  10. Revolving Digits(hdu4333)

    Revolving Digits Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...