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

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: Sentry 开发者贡献指南 - 后端服务(Python/Go/Rust/NodeJS)

服务管理 (devservices)



SentryDocker 提供了一个抽象,以在开发中运行所需的服务,称为 devservices


Usage: sentry devservices [OPTIONS] COMMAND [ARGS]...
  Manage dependent development services required for Sentry.
  Do not use in production!
Options:
  --help  Show this message and exit.
Commands:
  attach  Run a single devservice in foreground, as...
  down    Shut down all services.
  rm      Delete all services and associated data.
  up      Run/update dependent services.


查看服务的日志


# Follow snuba logs
docker logs -f sentry_snuba


为 redis、postgres 和 clickhouse 运行 CLI 客户端


# redis
docker exec -it sentry_redis redis-cli
# clickhouse
docker exec -it sentry_clickhouse clickhouse-client
# psql
docker exec -it sentry_postgres psql -U postgres


移除容器状态


如果你真的搞砸了你的容器或卷,你可以使用 devservices rm 重新开始。


# 删除与所有服务关联的所有数据(容器、卷和网络)
sentry devservices rm


例如,假设我们在进行迁移时设法损坏了 postgres 数据库,并且您想重置 postgres 数据,您可以执行以下操作:


# 删除与单个服务关联的所有数据(容器、卷和网络)
sentry devservices rm postgres


端口分配



以下是 Sentry 服务使用的端口或开发设置中 Sentry 服务的任何依赖项的简单列表。它有两个目的:


  • 找出为什么在您的工作机器上使用端口以及杀死哪个进程以使其空闲。
  • 找出哪些端口可以安全地分配给新服务。


Port Service Description
9000 Clickhouse Devservice clickhouse. Snuba 的数据库。
8123 Clickhouse
9009 Clickhouse
3021 Symbolicator Devservice symbolicator. 用于处理堆栈跟踪。
1218 Snuba Devservice snuba. 用于搜索事件。
9092 Kafka Devservice kafka. 用于 relay-sentry 通信和可选的用于 sentry-snuba 通信
6379 Redis Devservice redis (或者可能通过 rustier 设置中的 Homebrew 安装),负责缓存、relay 项目配置和 Celery 队列
5432 Postgres Devservice postgres(或者可能通过 rustier 设置中的 Homebrew 安装)
7899 Relay Devservice relay. 为 SDK 提供将事件发送到的 API(也称为事件摄取event ingestion)。Webpack 在 8000 端口反向代理到此服务器。使用 sentry devserver 启动/停止。
8000 Sentry Dev Sentry API +前端。Webpack 监听此端口并代理 API 请求 Django app
8001 uWSGI 使用 sentry devserver 启动/停止。为 Django app/API 提供服务。Webpack 在 8000 端口反向代理到此服务器。
7999 Sentry frontend prod proxy 用于测试针对 prod API 的本地 UI 更改
8000 Develop docs 围绕本文档的网站。 Sentry Dev 的冲突
3000 User docs 面向用户的文档。如果 Relay 在 devservice 之外运行,则可能与 Relay 冲突。
9001 Sentry Dev Styleguide server 运行 sentry devserver --styleguide 时绑定
9000 sentry run web sentry run web 的传统默认端口,更改为 9001 以避免与 Clickhouse 冲突。
9001 sentry run web 没有 webpack 或 Relay 的准系统前端。Sentry Dev 可能更好。与 Sentry Dev Styleguide server 冲突
8000 Relay mkdocs documentation 在某些时候,这将合并到我们现有的文档存储库中。与 Sentry Dev 的冲突

  • Relay
  • Snuba
  • Develop docs
  • User docs


找出您的机器上正在运行的内容


  • 使用 lsof -nP -i4 | grep LISTENmacOS 上查找被占用的端口。
  • Docker for MacDashboard UI 显示您正在运行的 docker 容器/开发服务以及分配的端口启动/停止选项。


异步 Worker




Sentry 带有一个内置队列,以更异步的方式处理任务。例如,当一个事件进入而不是立即将其写入数据库时,它会向队列发送一个 job,以便可以立即返回请求,并且后台 worker 会实际处理保存该数据。

Sentry 依赖 Celery 库来管理 worker

  • ttps://docs.celeryproject.org/


注册任务


Sentry 使用特殊的装饰器配置任务,使我们能够更明确地控制可调用对象。


from sentry.tasks.base import instrumented_task
@instrumented_task(
    name="sentry.tasks.do_work",
    queue="important_queue",
    default_retry_delay=60 * 5,
    max_retries=None,
)
def do_work(kind_of_work, **kwargs):
    # ...


有几个重要的点:

  • _必须_声明 task 名称。
    Task 名称是 Celery 如何识别消息(请求)以及需要哪个函数和工作线程来处理这些消息。如果 task 没有命名,celery 将从模块函数名称派生一个名称, 这使得名称与代码的位置相关联,并且对于未来的代码维护更加脆弱。
  • Task 必须接受 \*\*kwargs 来处理滚动兼容性。
    这确保 task 将接受恰好在队列中的任何消息,而不是因未知参数而失败。它有助于回滚更改,部署不是即时的,并且可能会使用多个版本的参数生成消息。
    虽然这允许在不完全任务失败的情况下向前和向后滚动, 但在更改参数时仍必须注意 worker 处理具有参数和参数的消息。这确实减少了这种迁移中所需更改的数量,并为 operator 提供了更多的灵活性, 但是由于未知参数而导致的消息丢失仍然是不可接受的。
  • Task _应该_在失败时自动重试。
  • Task 参数_应该_是原始类型并且很小。
    Task 参数被序列化到通过 broker 发送的消息中,worker 需要再次反序列化它们。对复杂类型执行此操作是脆弱的,应该避免。例如。更喜欢将 ID 传递给 task, 该 ID 可用于从缓存而不是数据本身加载数据。 Task 参数被序列化到通过 broker 发送的消息中,worker 需要再次对它们进行反序列化。对复杂类型执行此操作是脆弱的,应该避免。例如,宁愿向 task 传递 ID,该 ID 可用于从缓存加载数据,而不是数据本身。
    类似地,为了保持消息 brokerworker 有效运行, 将大值序列化到消息中会导致大消息大队列和更多(反)序列化开销,因此应该避免
  • 必须将 task 的模块添加到 CELERY_IMPORTS
    src/sentry/conf/server.py. Celery worker 必须按 name 查找 task, 只有当 worker 导入带有装饰任务函数的模块时才能这样做, 因为这是按 name 注册 task 的内容。因此,每个包含 task 的模块都必须添加到 src/sentry/conf/server.py 中的 CELERY_IMPORTS 设置中。


运行 Worker


可以使用 Sentry CLI 运行 Worker


$ sentry run worker


启动 Cron 进程


Sentry 通过 cron 进程安排 routine job


SENTRY_CONF=/etc/sentry sentry run cron


配置 Broker


Sentry 支持两个主要 broker,可根据您的 workload 进行调整:RabbitMQRedis


Redis


默认 brokerRedis,可以在大多数情况下工作。使用 Redis 的主要限制是所有待处理的工作都必须放在内存中。


BROKER_URL = "redis://localhost:6379/0"


如果您的 Redis 连接需要密码进行身份验证,则需要使用以下格式:


BROKER_URL = "redis://:password@localhost:6379/0"


RabbitMQ


如果您在 高 workload 下运行,或者担心将待处理的 workload 放入内存中,那么 RabbitMQ 是支持 Sentry worker 的理想选择。


BROKER_URL = "amqp://guest:guest@localhost:5672/sentry"


Email



Sentry 提供对出站传入电子邮件的支持。

入站电子邮件的使用相当有限,目前仅支持处理对 errornote 通知的回复。


出站 Email


您需要为出站电子邮件配置 SMTP 提供商。


  • mail.backend
  • 在 `config.yml` 中声明。
    用于发送电子邮件的后端。选项是 smtpconsoledummy
    默认为 smtp。如果您想禁用电子邮件传送,请使用 dummy
  • mail.from
  • 在 `config.yml` 中声明。
    From header 中用于出站电子邮件的电子邮件地址。
    默认为 root@localhost。强烈建议更改此值以确保可靠的电子邮件传送。
  • mail.host
  • 在 `config.yml` 中声明。
    用于 SMTP 连接的主机名。
    默认为 localhost.
  • mail.port
  • 在 `config.yml` 中声明。
    用于 SMTP 连接的连接端口。
    默认为 25
  • mail.username
  • 在 `config.yml` 中声明。
    使用 SMTP 服务器进行身份验证时使用的用户名。
    默认为 (empty)
  • mail.password
  • 在 `config.yml` 中声明。
    使用 SMTP 服务器进行身份验证时使用的密码。
    默认为 (empty)
  • mail.use-ssl
  • 在 `config.yml` 中声明。
    Sentry 在连接到 SMTP 服务器时是否应该使用 SSL?
    默认为 false
  • mail.use-tls
  • 在 `config.yml` 中声明。
    Sentry 在连接到 SMTP 服务器时应该使用 TLS 吗?
    默认为 false
  • mail.list-namespace
  • 在 `config.yml` 中声明。
    此 Sentry 服务器发送的电子邮件的邮件列表命名空间。这应该是您拥有的域(通常与 mail.from 配置参数值的域部分相同)或 localhost


入站 Email


对于配置,您可以从不同的后端进行选择。


Mailgun


首先选择一个域来处理入站电子邮件。我们发现如果您维护一个与其他任何事物分开的域,这是最简单的。在我们的示例中,我们将选择 inbound.sentry.example.com。您需要根据 Mailgun 文档为给定域配置 DNS 记录。

mailgun 中创建一个新路由:


Priority:
  0
Filter Expression:
  catch_all()
Actions:
  forward("https://sentry.example.com/api/hooks/mailgun/inbound/")
Description:
  Sentry inbound handler


使用适当的设置配置 Sentry


# 您的 Mailgun API key(用于验证传入的 webhook)
mail.mailgun-api-key: ""
# 将 SMTP hostname 设置为您配置的入站域
mail.reply-hostname: "inbound.sentry.example.com"
# 通知 Sentry 发送适当的邮件头以启用
# 收到答复
mail.enable-replies: true


就是这样!您现在可以通过电子邮件客户端响应有关错误的活动通知。


节点存储



Sentry 提供了一个名为 ‘nodestore’ 的抽象,用于存储 key/valueblob

默认后端只是将它们作为 gzipped blob 存储在默认数据库的 ‘nodestore_node’ 表中。


Django 后端


Django 后端使用 gzipped json blob-as-text 模式将所有数据存储在 ‘nodestore_node’ 表中。


后端不提供任何选项,因此只需将其设置为空字典即可。


SENTRY_NODESTORE = 'sentry.nodestore.django.DjangoNodeStorage'
SENTRY_NODESTORE_OPTIONS = {}


自定义后端


如果你有一个最喜欢的数据存储解决方案,它只需要在一些规则下运行,它就可以与 Sentryblob 存储一起工作:


  • 设置 key/value
  • 获取 key
  • 删除 key

有关实现自己的后端的更多信息,请查看 sentry.nodestore.base.NodeStorage


文件存储



Sentry 提供了一个名为 ‘filestore’ 的抽象,用于存储文件(例如发布工件)。

默认后端将文件存储在不适合生产使用的 /tmp/sentry-files 中。


文件系统后端


filestore.backend: "filesystem"
filestore.options:
  location: "/tmp/sentry-files"


Google Cloud 存储后端


除了下面的配置之外,您还需要确保 shell 环境设置了变量 GOOGLE_APPLICATION_CREDENTIALS。有关详细信息,请参阅 用于设置身份验证的 Google Cloud 文档。


filestore.backend: "gcs"
filestore.options:
  bucket_name: "..."


Amazon S3 后端


S3 存储后端支持使用 access keyIAM 实例角色进行身份验证。使用后者时,省略 access_keysecret_key。默认情况下,S3 对象是使用 public-read ACL 创建的,这意味着除了 PutObjectGetObjectDeleteObject 之外, 所使用的帐户/角色还必须具有 PutObjectAcl 权限。如果您不希望您上传的文件可公开访问,您可以将 default_acl 设置为 private


filestore.backend: "s3"
filestore.options:
  access_key: "..."
  secret_key: "..."
  bucket_name: "..."
  default_acl: "..."


MinIO S3 后端


filestore.backend: "s3"
filestore.options:
  access_key: "..."
  secret_key: "..."
  bucket_name: "..."
  endpoint_url: "https://minio.example.org/"


时间序列存储



Sentry 提供存储时间序列数据的服务。这主要用于显示事件和项目的汇总信息,以及(实时)计算事件发生率。


RedisSnuba 后端(推荐)


这是唯一一个 100% 正确工作的后端


SENTRY_TSDB = 'sentry.tsdb.redissnuba.RedisSnubaTSDB'


该后端与 Snuba 通信以获取与事件摄取(event ingestion)相关的指标,并与 Redis 通信以获取其他所有内容。 Snuba 需要运行自己的结果消费者(outcomes consumer),目前这不是 devservices 的一部分。

包装的 Redis TSDB 可以这样配置(有关 Redis 选项,请参阅下文):


SENTRY_TSDB_OPTIONS = {
    'redis': ... # RedisTSDB 的选项字典在这里
}


Dummy 后端


顾名思义,所有 TSDB 数据将在写入时删除并在读取时替换为零:


SENTRY_TSDB = 'sentry.tsdb.dummy.DummyTSDB'


Redis 后端


“裸”Redis 后端读取和写入所有数据到 Redis。与事件摄取(Organization Stats)相关的各个列将显示归零数据,因为该数据仅在 Snuba 中可用。


SENTRY_TSDB = 'sentry.tsdb.redis.RedisTSDB'


默认情况下,这将使用名为 defaultRedis 集群。要使用不同的集群,请提供 cluster 选项,如下所示:


SENTRY_TSDB_OPTIONS = {
    'cluster': 'tsdb',
}


写 Buffer



Sentry 通过在一段时间内 buffer 写入和刷新对数据库的批量更改来管理数据库行争用。如果您具有高并发性,这将非常有用,尤其是当它们经常是同一个事件时。

例如,如果您碰巧每秒接收 100,000 个事件,并且其中 10% 向数据库报告连接问题(它们将被组合在一起), 启用 buffer 后端将改变事情,以便每个计数更新实际上是放入队列中,所有更新都以队列可以跟上的速度执行。


配置


要指定后端,只需修改配置中的 SENTRY_BUFFERSENTRY_BUFFER_OPTIONS 值:


SENTRY_BUFFER = 'sentry.buffer.base.Buffer'


Redis


配置 Redis 后端需要队列,否则您将看不到任何收益(事实上,您只会对性能产生负面影响)。


配置是直截了当的:


SENTRY_BUFFER = 'sentry.buffer.redis.RedisBuffer'


默认情况下,这将使用名为 defaultRedis 集群。要使用不同的集群,请提供 cluster 选项,如下所示:


SENTRY_BUFFER_OPTIONS = {
    'cluster': 'buffer',
}


指标



Sentry 提供了一种称为 ‘metrics’ 的抽象,用于内部监控,通常是计时和各种计数器。


默认后端只是丢弃它们(尽管某些值仍保留在内部时间序列数据库中)。


Statsd 后端


SENTRY_METRICS_BACKEND = 'sentry.metrics.statsd.StatsdMetricsBackend'
SENTRY_METRICS_OPTIONS = {
    'host': 'localhost',
    'port': 8125,
}


Datadog 后端


Datadog 将要求您将 datadog 包安装到您的 Sentry 环境中:


$ pip install datadog


在你的 sentry.conf.py 中:


SENTRY_METRICS_BACKEND = 'sentry.metrics.datadog.DatadogMetricsBackend'
SENTRY_METRICS_OPTIONS = {
    'api_key': '...',
    'app_key': '...',
    'tags': {},
}


安装后,Sentry 指标将通过 HTTPS 发送到 Datadog REST API。


DogStatsD 后端


使用 DogStatsD 后端需要一个 Datadog Agent 与 DogStatsD 后端一起运行(默认情况下在端口 8125)。


您还必须将 datadogPython 包安装到您的 Sentry 环境中:


$ pip install datadog


在你的 sentry.conf.py 中:


SENTRY_METRICS_BACKEND = 'sentry.metrics.dogstatsd.DogStatsdMetricsBackend'
SENTRY_METRICS_OPTIONS = {
    'statsd_host': 'localhost',
    'statsd_port': 8125,
    'tags': {},
}


配置完成后,指标后端将发送到 DogStatsD 服务器,然后通过 HTTPS 定期刷新到 Datadog


Logging 后端


LoggingBackend 将所有操作报告给 sentry.metricslogger。除了指标名称和值之外,日志消息还包括额外的数据,例如可以使用自定义格式化程序显示的 instancetags 值。


SENTRY_METRICS_BACKEND = 'sentry.metrics.logging.LoggingBackend'
LOGGING['loggers']['sentry.metrics'] = {
    'level': 'DEBUG',
    'handlers': ['console:metrics'],
    'propagate': False,
}
LOGGING['formatters']['metrics'] = {
    'format': '[%(levelname)s] %(message)s; instance=%(instance)r; tags=%(tags)r',
}
LOGGING['handlers']['console:metrics'] = {
    'level': 'DEBUG',
    'class': 'logging.StreamHandler',
    'formatter': 'metrics',
}


配额



使用 Sentry 的工作方式,您可能会发现自己处于这样一种情况:您会看到太多的入站流量,而没有一个好的方法来丢弃多余的消息。对此有几种解决方案,如果您遇到此问题,您可能希望全部使用它们。


事件配额


Sentry 中限制工作负载的主要机制之一涉及设置事件配额。这些可以在每个项目和系统范围内进行配置,并允许您限制在 60 秒时间内接受的最大事件数。


配置


主要实现使用 Redis,只需要你配置连接信息:


SENTRY_QUOTAS = 'sentry.quotas.redis.RedisQuota'


默认情况下,这将使用名为 defaultRedis 集群。要使用不同的集群,请提供 cluster 选项,如下所示:


SENTRY_QUOTA_OPTIONS = {
    'cluster': 'quota',
}


如果您有其他需求,您可以像 Redis 实现一样自由扩展基本 Quota 类。


全系统速率限制


您可以配置系统范围的最大每分钟速率限制:


system.rate-limit: 500


例如,在您项目的 sentry.conf.py 中,您可以执行以下操作:


from sentry.conf.server import SENTRY_OPTIONS
SENTRY_OPTIONS['system.rate-limit'] = 500


或者,如果您导航到 /manage/settings/,您将找到一个管理面板,其中包含一个用于设置 Rate Limit 的选项,该选项存储在上述配额实施中。


基于用户的速率限制


您可以配置基于用户的每分钟最大速率限制:


auth.user-rate-limit: 100
auth.ip-rate-limit: 100


基于项目的速率限制


要进行基于项目的速率限制,请单击项目的 Settings。在 Client Keys (DSN)tab 下,找到你想要限速的 key,点击对应的 Configure 按钮。这应该会显示 key/project-specific 的速率限制设置。


Notification 速率限制


在某些情况下,可能会担心限制诸如出站电子邮件通知之类的内容。为了解决这个问题,Sentry 提供了一个支持任意速率限制的速率限制子系统。


配置


与事件配额一样,主要实现使用 Redis


SENTRY_RATELIMITER = 'sentry.ratelimits.redis.RedisRateLimiter'


默认情况下,这将使用名为 default 的 Redis 集群。要使用不同的集群,请提供 cluster 选项,如下所示:


SENTRY_RATELIMITER_OPTIONS = {
    'cluster': 'ratelimiter',
}


Notification 摘要



Sentry 提供了一项服务,该服务将在通知发生时收集通知,并安排它们作为聚合 “digest” 通知进行传送。


配置


尽管 digest 系统配置了一组合理的默认选项,但可以使用 SENTRY_DIGESTS_OPTIONS 设置来微调 digest 后端行为,以满足您独特安装的需要。所有后端共享下面定义的一组通用选项,而某些后端还可能定义特定于其各自实现的附加选项。


minimum_delay

: minimum_delay 选项定义了默认的最小时间量(以秒为单位),以在初始调度后在调度 digest 之间等待交付。这可以在 Notification 设置中按项目覆盖。

maximum_delay

: maximum_delay 选项定义了在调度 digest 之间等待传送的默认最长时间(以秒为单位)。这可以在 Notification 设置中按项目覆盖。

increment_delay

: increment_delay 选项定义了在最后一次处理 digest 之后的 maximum_delay 之前,事件的每个观察应该延迟调度多长时间。

capacity

: capacity 选项定义了时间线内应包含的最大 item 数。这是硬限制还是软限制取决于后端 - 请参阅 truncation_chance 选项。

truncation_chance

: truncation_chance 选项定义了 add 操作触发时间线截断以使其大小接近定义容量的概率。值为 1 将导致时间线在每次 add 操作时被截断(有效地使其成为硬限制),而较低的概率会增加时间线超过其预期容量的机会,但通过避免截断来执行操作会提高 add 的性能,截断是一项潜在的昂贵操作,尤其是在大型数据集上。


后端


Dummy 后端


Dummy 后端禁用摘要调度,所有通知都会在发生时发送(受速率限制)。这是在版本 8 之前创建的安装的默认 digest 后端。

可以通过 SENTRY_DIGESTS 设置指定 dummy 后端:


SENTRY_DIGESTS = 'sentry.digests.backends.dummy.DummyBackend'


Redis 后端


Redis 后端使用 Redis 来存储 schedule 和待处理 notification 数据。这是自版本 8 以来创建的安装的默认 digest 后端。

Redis 后端可以通过 SENTRY_DIGESTS 设置来指定:


SENTRY_DIGESTS = 'sentry.digests.backends.redis.RedisBackend'


Redis 后端接受基本集之外的几个选项,通过 SENTRY_DIGESTS_OPTIONS 提供:

cluster : cluster 选项定义了应该用于存储的 Redis 集群。如果未指定集群,则使用 default 集群。


在将数据写入 digest 后端后更改 cluster 值或集群配置可能会导致意外影响 - 即,它会在集群大小更改期间造成数据丢失的可能性。应在运行系统上小心调整此选项。

ttl : ttl 选项定义 recordtimelinedigest 的生存时间(以秒为单位)。


这可以(也应该)是一个相对较高的值,因为 timelinedigestrecord 在处理后都应该被删除——这主要是为了确保在配置错误的情况下过时的数据不会停留太久 . 这应该大于最大调度延迟,以确保不会过早驱逐数据。


示例配置


SENTRY_DIGESTS = 'sentry.digests.backends.redis.RedisBackend'
SENTRY_DIGESTS_OPTIONS = {
    'capacity': 100,
    'cluster': 'digests',
}


Relay


Relay 是一种用于事件过滤、速率限制和处理的服务。它可以作为:

  • Sentry 安装的存储端点。Relay developer documentation
  • 您的应用程序和 Sentry 之间的附加中间层。Relay product documentation

Snuba


后端 Chart 渲染


Sentry 的前端为用户提供了各种类型的详细交互式图表,高度符合 Sentry 产品的外观和感觉。从历史上看,这些图表只是我们在 Web 应用程序中才有的东西。


然而,在某些情况下,在应用程序的某些上下文中显示图表非常有价值。例如

  • Slack 展开 Discover 图表、指标警报通知、问题详细信息或 Sentry 中的任何其他链接,其中在 Slack 中查看图表可能很有用。
  • 通知摘要电子邮件。将趋势可视化为图表。

幸运的是,Sentry 为内部 Chartcuterie NodeJS 服务提供了内置功能,它可以通过 HTTP API 以图像格式生成图形。图表是使用前端使用的相同 ECharts 库生成的。 ChartcuterieSentry 的前端共享代码,这意味着可以在前端和后端 Chartcuterie 生成的图表之间轻松维护图表的外观。



在 Sentry 的后端使用 Chartcuterie


使用 Chartcuterie 生成图表非常简单。


导入 generate_chart 函数,提供 chart 类型和 data 对象,获取公共图片 URL


from sentry.charts import generate_chart, ChartType
# The shape of data is determined by the RenderDescriptor in the
# configuration module for the ChartType being rendered.
data = {}
chart_url = generate_chart(ChartType.MY_CHART_TYPE, data)


配置 chart 以进行渲染


Chartcuteriesentry.io 加载一个外部 JavaScirpt 模块,该模块决定了它如何呈现图表。该模块直接配置 EChart 的 options 对象, 包括在 POST /render 调用时提供给 Chartcuterie 的系列数据的转换。


该模块作为 getsentry/sentry 的一部分存在, 可以在 static/app/chartcuterie/config.tsx 中找到。


服务初始化


可以配置一个可选的初始化函数 init 在服务启动时运行。这个函数可以访问 Chartcuterie 的全局 echarts 对象, 并且可以使用它来注册实用程序(例如 registerMaps)。


添加/删除 chart 类型


Chart 渲染是基于 每个 "chart type" 配置的。对于每种类型的 chart,您都需要在前端应用程序和后端 chart 模块中声明一个众所周知的名称。


  1. 在前端,在 static/app/charctuerie/types.tsx 中添加一个 ChartType
  1. 在 static/app/chartcuterie/config.tsx中注册 chartRenderDescriptor,它描述了外观和系列转换。您可以为此使用 register 函数。
  1. 在后端,在 sentry.charts.types 模块中添加一个匹配的 ChartType
  1. Sentry 中部署您的更改。配置模块将在 5 分钟内自动传播到 Chartcuterie
    您无需部署 Charcuterie


不要在配置模块的同时部署使用新 chart type 的功能。由于存在传播延迟,因此不能保证新 chart type 在部署后立即可用。


配置模块包括部署的 sentry.io 提交 SHA,它允许 Chartcuterie 在每个轮询 tick 时检查它是否收到了新的配置模块。


在开发中运行 Chartcuterie


要在本地开发人员环境中启用 Chartcuterie,请首先在 config.yml 中启用它:


# 启用 charctuerie
chart-rendering.enabled: true


目前您需要在您的开发环境中手动构建配置模块。


yarn build-chartcuterie-config


然后您可以启动 Chartcuterie devservice。如果 devservice 没有启动, 请检查 chart-render.enabledkey 是否正确设置为 true(使用 sentry config get chart-rendering.enabled)。


sentry devservices up chartcuterie


您可以通过检查日志来验证服务是否已成功启动


docker logs -f sentry_chartcuterie


应该是这样的


info: Using polling strategy to resolve configuration...
info: Polling every 5s for config...
info: Server listening for render requests on port 9090
info: Resolved new config via polling: n styles available. {"version":"xxx"}
info: Config polling switching to idle mode
info: Polling every 300s for config...


您的开发环境现在已准备好调用 Chartcuterie 的本地实例。


在本地更新 chart type


当前,您需要在每次更改时使用 yarn build-chartcuterie-config 重建配置模块。这在未来可能会得到改善。


工作原理



下面是 Chartcuterie service 的几个 service 图以及它如何与 Sentry 应用程序服务器交互。


Chartcuterie 启动


微信图片_20220613005703.png

来自 Sentry 的 Render 调用


微信图片_20220613005714.png

相关文章
|
3月前
|
算法 Go Python
获取指定范围符合正态分布的随机数Go/Python
获取指定范围符合正态分布的随机数Go/Python
55 0
|
3月前
|
Go Docker Python
docker的python与go镜像的制作
docker的python与go镜像的制作
56 1
|
3月前
|
前端开发 API 开发者
深度剖析:AJAX、Fetch API如何成为Python后端开发者的最佳拍档!
深度剖析:AJAX、Fetch API如何成为Python后端开发者的最佳拍档!
53 4
|
3月前
|
算法 安全 Go
RSA加密算法详解与Python和Go实现
RSA加密算法详解与Python和Go实现
300 1
|
4月前
|
安全 API 开发者
Web 开发新风尚!Python RESTful API 设计与实现,让你的接口更懂开发者心!
在当前的Web开发中,Python因能构建高效简洁的RESTful API而备受青睐,大大提升了开发效率和用户体验。本文将介绍RESTful API的基本原则及其在Python中的实现方法。以Flask为例,演示了如何通过不同的HTTP方法(如GET、POST、PUT、DELETE)来创建、读取、更新和删除用户信息。此示例还包括了基本的路由设置及操作,为开发者提供了清晰的API交互指南。
136 6
|
3月前
|
算法 安全 Go
Python与Go语言中的哈希算法实现及对比分析
Python与Go语言中的哈希算法实现及对比分析
65 0
|
3月前
|
安全 测试技术 Go
Python 和 Go 实现 AES 加密算法的技术详解
Python 和 Go 实现 AES 加密算法的技术详解
182 0
|
3月前
|
机器学习/深度学习 自然语言处理 Go
Python与Go在AIGC领域的应用:比较与分析
Python与Go在AIGC领域的应用:比较与分析
89 0
|
4月前
|
安全 数据安全/隐私保护 开发者
重塑信任:Python开发者如何利用OAuth与JWT,打造安全无虞的授权机制
【9月更文挑战第7天】随着Web应用的复杂度增加,用户数据保护变得至关重要。本文通过问答形式,探讨Python开发者如何利用OAuth和JWT构建高效且安全的授权机制。OAuth让第三方应用能在不获取用户凭据的情况下访问特定服务,保护用户隐私;JWT则通过安全令牌实现身份验证。结合二者,开发者能打造符合现代安全标准的授权体系,提升系统安全性和灵活性。 示例代码展示了如何使用`requests-oauthlib`简化OAuth流程,并用`PyJWT`生成及验证JWT。这种组合不仅加强了安全性,还优化了用户体验。
70 1
|
4月前
|
JSON 安全 API
Python开发者必看:OAuth与JWT授权机制的惊天秘密😱
【9月更文挑战第9天】在现代软件开发中,尤其在Web和移动应用领域,用户认证与授权至关重要。对Python开发者而言,OAuth和JWT是提升应用安全性与用户体验的关键技术。OAuth通过“授权而不认证”的理念保障用户数据安全,JWT则利用JSON Web Tokens实现无缝的信息传递。两者结合可构建高效且安全的认证体系。掌握这些技术,将使你的应用更加出色。
34 0