首页 > 系统相关 >CentOS6 基于 Python 安装 Sentry

CentOS6 基于 Python 安装 Sentry

时间:2023-05-17 14:22:05浏览次数:63  
标签:rhel6 sentry x86 Python Sentry CentOS6 2PGDG 64 9.6

概述
Sentry 是一款可用于 Production 环境的错误跟踪工具,可实时通知 Production 环境中用户由于一些不可预料行为 (或者程序写的有问题) 导致程序 Crash 或 Exception,Sentry 可以通过 Integration 如 HipChat 来发送通知,并且可以通过 JIRA Integration 来快速创建 Issue,然后开发者可以根据这个 Issue 快速修复程序,并把这个已修复的 Hotfix 快速部署到生产环境,这样就快速开发快速修补。

Sentry 提供了两种使用方式:

厂商的服务,提供 14 天无限制免费服务,点击查看 官网价格服务 或 使用简介。
源码 自行搭建,包括 Docker 和 Python 两种方式, Python 安装方式 Here, Docker 安装方式 Here。
安装依赖软件
安装 Sentry 需要以下满足以下条件:

基于 UNIX 的操作系统
PostgreSQL:版本 9.5 以上,推荐最新版本 9.6
Redis:最低版本 2.8.9, 推荐 2.8.18, 3.0
Python 2.7 :点击查看安装方式
Pip 8.1+
安装下列软件:python-setuptools, python-dev, libxslt1-dev, gcc, libffi-dev, libjpeg-dev, libxml2-dev, libxslt-dev, libyaml-dev, libpq-dev,推荐 yum 安装。
实际安装过程中,最好预留 1G 的内存,我安装时因为预留内存不够折腾了好久,最后翻 github 的 issue 才意识到是内存的问题。

安装 PostgreSQL
安装新版的 yum 源

我使用的是官方当前最新版本 9.6,其他版本详见官方文档,根据自己要安装的版本及操作系统选择下载 rpm 文件即可。

$ cd ~
$ wget https://download.postgresql.org/pub/repos/yum/9.6/redhat/rhel-6-x86_64/pgdg-redhat96-9.6-3.noarch.rpm
$ rpm -ivh ./pgdg-redhat96-9.6-3.noarch.rpm
移除之前的版本

$ rpm -qa | grep postgre
postgresql84-devel-8.4.3-2PGDG.rhel6.x86_64
postgresql84-libs-8.4.3-2PGDG.rhel6.x86_64
postgresql84-contrib-8.4.3-2PGDG.rhel6.x86_64
postgresql84-server-8.4.3-2PGDG.rhel6.x86_64
postgresql84-8.4.3-2PGDG.rhel6.x86_64

$ yum remove postgresql84 postgresql84-devel postgresql84-libs postgresql84-contrib postgresql84-server
查看安装新版 yum 源后可以安装的版本

$ yum list postgres* | grep 96
postgresql96.x86_64 9.6.2-2PGDG.rhel6 @pgdg96
postgresql96-contrib.x86_64 9.6.2-2PGDG.rhel6 @pgdg96
postgresql96-devel.x86_64 9.6.2-2PGDG.rhel6 @pgdg96
postgresql96-libs.x86_64 9.6.2-2PGDG.rhel6 @pgdg96
postgresql96-server.x86_64 9.6.2-2PGDG.rhel6 @pgdg96
postgresql-jdbc.noarch 42.0.0-1.rhel6 pgdg96
postgresql-jdbc-javadoc.noarch 42.0.0-1.rhel6 pgdg96
postgresql-unit96.x86_64 2.0-1.rhel6 pgdg96
postgresql-unit96-debuginfo.x86_64 2.0-1.rhel6 pgdg96
postgresql96-debuginfo.x86_64 9.6.2-2PGDG.rhel6 pgdg96
postgresql96-docs.x86_64 9.6.2-2PGDG.rhel6 pgdg96
postgresql96-odbc.x86_64 09.06.0100-1PGDG.rhel6 pgdg96
postgresql96-plperl.x86_64 9.6.2-2PGDG.rhel6 pgdg96
postgresql96-plpython.x86_64 9.6.2-2PGDG.rhel6 pgdg96
postgresql96-pltcl.x86_64 9.6.2-2PGDG.rhel6 pgdg96
postgresql96-tcl.x86_64 2.1.1-1.rhel6 pgdg96
postgresql96-tcl-debuginfo.x86_64 2.1.1-1.rhel6 pgdg96
postgresql96-test.x86_64 9.6.2-2PGDG.rhel6 pgdg96
从结果可以看出新版 yum 源可以安装很多依赖,但实际上我们只需要安装 postgresql96、postgresql96-devel、postgresql96-libs、postgresql96-server 四项即可。

$ yum install postgresql96 postgresql96-devel postgresql96-libs postgresql96-server
$ # 初始化数据库
$ /etc/init.d/postgresql-9.6 initdb
$ # 开启数据库
$ /etc/init.d/postgresql-9.6 start
至此,新版 PostgreSQL 就安装好了,接下来是做些连接配置:

$ vim /var/lib/pgsql/9.6/data/pg_hba.conf
将相关连接的 Method 改为 trust:

# TYPE DATABASE USER ADDRESS METHOD

# "local" is for Unix domain socket connections only
local all all trust
# IPv4 local connections:
host all all 127.0.0.1/32 trust
# IPv6 local connections:
host all all ::1/128 trust
# Allow replication connections from localhost, by a user with the
# replication privilege.
#local replication postgres peer
#host replication postgres 127.0.0.1/32 ident
#host replication postgres ::1/128 ident
安装 Redis
安装 redis 相对简单,使用 yum 安装即可

$ yum install redis
$ # 开启redis
$ /etc/init.d/redis start
安装 Sentry
安装软件
$ # 安装环境
$ pip install -U virtualenv
$ virtualenv /www/sentry/
$ source /www/sentry/bin/activate
$ # 安装sentry
$ pip install -U sentry
相关配置
初始化配置,如果不设置路径的话,默认会生成在 ~/.sentry 目录中,推荐使用默认路径。初始化配置包含两个文件,分别是 config.yml 和 sentry.conf.py。

$ sentry init
邮件配置项保存在 config.yml 文件中,Sentry 收到异常时会给自己的邮箱发送邮件通知,所以需要配置下邮件,当然也可以不启用,但不建议这样做。

# 如果不想启用邮件通知,可以将 mail.backend 设置为 dummy
mail.backend: 'smtp'
mail.host: 'localhost'
mail.port: 25
mail.username: ''
mail.password: ''
mail.use-tls: false
mail.from: 'sentry@localhost'
数据库配置项保存在 sentry.conf.py 文件中,使用默认即可,只需要修改 HOST 和 PORT 项。

# ~/.sentry/sentry.conf.py

# for more information on DATABASES, see the Django configuration at:
# https://docs.djangoproject.com/en/1.6/ref/databases/
DATABASES = {
'default': {
'ENGINE': 'sentry.db.postgres',
'NAME': 'sentry',
'USER': 'postgres',
'PASSWORD': '',
'HOST': 'localhost',
'PORT': '5432',
}
}
Redis 项使用默认即可,另外一个需要注意的是 Web 使用的端口配置项 SENTRY_WEB_PORT,默认为 9000 ,实际安装时可以检测下端口是否已被占用,我安装时发现被占用,所以改用了 9999。

使用数据迁移初始化数据
创建数据库

$ createdb -U postgres -E utf-8 sentry
执行数据更新,数据填充完成后会提示是否创建用户,可以选择不创建后续再创建,另外,这一步比较 耗内存,我就是在执行这一步的时候出了很多意外,比如进程被 killed,报很多异常等等。

$ sentry upgrade
$ # 如果没有使用默认目录的话,需要使用如下命令
$ # SENTRY_CONF=/path/to/sentry sentry upgrade
创建用户,需要填写邮箱和密码,创建好后会提示是否作为超级用户,根据自己情况选择即可。

$ sentry createuser
$ # 如果没有使用默认目录的话,需要使用如下命令
$ # SENTRY_CONF=/path/to/sentry sentry createuser
开启服务
开启 web 服务,开启后可以访问 http://[IP或域名]:[前面配置的端口] 进行访问。

$ sentry run web
$ # 如果没有使用默认目录的话,需要使用如下命令
$ # SENTRY_CONF=/path/to/sentry sentry run web
开启后台 worker 服务

$ sentry run worker
$ # 如果没有使用默认目录的话,需要使用如下命令
$ # SENTRY_CONF=/path/to/sentry sentry run worker
开启 cron 进程

$ sentry run cron
$ # 如果没有使用默认目录的话,需要使用如下命令
$ # SENTRY_CONF=/path/to/sentry sentry run cron
Laravel 集成扩展包
Sentry 官方针对各种语言的不同框架都提供了相应的扩展包,当然也包括 laravel。

laravel 集成文档
laravel 扩展库 github 地址
配置好后就可以在自己的项目中愉快的使用了,悟禅小书童 已经使用上了,参考图如下:

 

阅读原文

标签:rhel6,sentry,x86,Python,Sentry,CentOS6,2PGDG,64,9.6
From: https://www.cnblogs.com/276815076/p/17408614.html

相关文章

  • Scala中实现和Python一致的整数除法和整数求余
    \[\color{black}{\text{Inscala,it'sweirdtomimic`%``//`ofpython}}\]/*Python's%operatorreturnsaresultwiththesamesignasthedivisor,and//roundstowardsnegativeinfinity.InScala,%and/don'tbehavethesameway.......
  • python:ERROR: Could not build wheels for wordcloud, which is required to install
    pycharm里无法下载,在下面下载出现问题 需要下载error里的文件https://www.lfd.uci.edu/~gohlke/pythonlibs/#wordcloud这个网站找。输入Python,看自己电脑是怎样的 下载文件后,放到对应位置,下载成功 ......
  • Python枚举类型enum
    为什么需要枚举枚举(Enum)是一种数据类型,也是一种特别的类,是绑定到唯一值的符号表示,可以使用它来创建用于变量和属性的常量集枚举类可以看成是一个下拉菜单,给出特定的选项且这些选项不可修改,更贴近自然语言的方式表达数据,可以让代码更容易阅读、维护,减少转换或者错误值引......
  • 48024 python 代码分析
    ComputerScience220SC(2023)Assignment3(Basicgraphalgorithmsandtraversals)SeeCanvasforduedateThisassignmentrequiresyoutosubmitprogramsinPythonthatyouhavewrittenyourselftotheautomarker,https://www.automarker.cs.auckland.ac.nz.Yo......
  • 【Python】Centos7安装dirsearch
    一、升级Openssl1.1.1 1、官网下载源码:https://www.openssl.org/2、安装#./config--prefix=/datas/soft/openssl-1.1.1no-zlib#make#makeinstall3、新版配置#ln-s/datas/soft/openssl-1.1.1/include/openssl/usr/include/openssl#ln-s/datas/soft/openss......
  • < Python全景系列-3 > Python控制流程盘点及高级用法、神秘技巧大揭秘!
    欢迎来到我们的系列博客《Python全景系列》!在这个系列中,我们将带领你从Python的基础知识开始,一步步深入到高级话题,帮助你掌握这门强大而灵活的编程语法。无论你是编程新手,还是有一定基础的开发者,这个系列都将提供你需要的知识和技能。 这是系列第三篇,在这篇文章中我们将全面深......
  • python 使用企业微信发邮件加加图形化界面
    importsysfromPyQt5.QtWidgetsimportQApplication,QWidget,QLabel,QLineEdit,QTextEdit,QPushButtonimportrequests,base64,hashlibimportsmtplibimportosimportglobfromemail.mime.textimportMIMETextfromemail.mime.multipartimportMIMEMultipa......
  • generate a 3D chart in Python using the CSV data
    Here's an example of how you could use Matplotlib to create a 3D scatter plot from your CSV data:   importpandasaspdimportmatplotlib.pyplotaspltfrommpl_toolkits.mplot3dimportAxes3D#LoadtheCSVdataintoaPand......
  • 用Python开发输入法后台
    首先,安装PIME,github地址:https://github.com/EasyIME/PIME下载安装PIME-1.3.0-stable-setup.exe,就可以得到一个输入法,后端是python,在安装目录下‘C:\ProgramFiles(x86)\PIME\’,python目录就是运行脚本。入口点是'server.py',其中安装目录下的‘PIMELauncher.exe’是负责前后台......
  • python 项目报错 Fatal Python error: _enter_buffered_busy: could not acquire lock
    FatalPythonerror:_enter_buffered_busy:couldnotacquirelockfor<_io.BufferedWritername=''>atinterpretershutdown,possiblyduetodaemonthreadsPythonruntimestate:finalizing(tstate=0x00005654c4008a40)Currentthread0x00007fc......