Docker部署Sentry并用在Tornado中收集错误日志.md

一、Sentry安装

1、下载

git clone https://github.com/getsentry/onpremise

2、编写配置文件构建docker镜像

cd onpremise
vim ./config.yml # 可以配置邮箱信息用以发告警邮件
make build

3、创建sentry的配置和数据库目录

mkdir -p data/{sentry,postgres} 

4、命令生成Sentry的Secret Key

docker-compose run --rm web config generate-secret-key
vim docker-compose.yml # 将上一步输出的secret key 设置成环境变量 SENTRY_SECRET_KEY的值

5、初始化Sentry的数据库,创建超级用户

docker-compose run --rm web upgrade

6、启动

# -d是为了在后台运行
docker-compose up -d

二、在Tornado中集成

1、sentry-sdk从PyPI 安装

pip install  sentry-sdk

注意:如果您使用的是Python 3.6,则还需要以下aiocontextvars软件包

$ pip install --upgrade aiocontextvars

2、在启动服务器之前初始化SDK

import sentry_sdk
from sentry_sdk.integrations.tornado import TornadoIntegration

sentry_sdk.init(
    dsn="https://examplePublicKey@o0.ingest.sentry.io/0",
    integrations=[TornadoIntegration()]
)

# Your app code here, without changes

class MyHandler(...):
    ...

注意:Sentry会把请求数据附加到所有事件:HTTP方法,URL,标头,表单数据,JSON有效负载。Sentry不包括原始文件和分段文件上传。Sentry还排除个人身份信息(例如用户ID,用户名,Cookie,授权标头,IP地址),除非将其设置send_default_pii为True。

bug  tornado 
更新时间:2018-08-01 15:10:50

本文由 智慧煮粥 创作,如果您觉得本文不错,请随意赞赏
采用 知识共享署名4.0 国际许可协议进行许可
本站文章除注明转载/出处外,均为本站原创或翻译,转载前请务必署名
原文链接:http://zz.zzhub.cn/archives/dockersentryrizhi
最后更新:2018-08-01 15:10:50

评论

Your browser is out of date!

Update your browser to view this website correctly. Update my browser now

×