安装sentry && supervisor 来收集异常

sentry是个优秀以及方便的可以来收集各种异常的系统,作为企业,很有必要自己搭建一个sentry服务器来收集本公司的项目中各种异常。

 

大多数步骤,通过这个教程即可,中间有一些暗礁要一一度过。

下面是一些命令和步骤:

easy_install -UZ virtualenv
virtualenv /www/sentry/
source /www/sentry/bin/activate
这三个命令是在/www/sentry下搭建一套虚拟环境,这样你装的各种python包环境,不会流入到系统里面
easy_install -UZ sentry
安装需要的包,因为伟大的wall,好几个包下不下来,要根据提示,一一下回索要的tar.gz ,然后解压,运行 python setup.py install
easy_install -UZ sentry[mysql]
到这一步,算是安装完成了,下面开始金牌娱乐官方网站。
sentry init /etc/sentry.conf.py
然后更改 sentry.conf.py

DATABASES = {

‘default’: {

‘ENGINE’: ‘django.db.backends.mysql’,

 

‘NAME’: ‘sentry’,

‘USER’: ‘root’,

‘PASSWORD’: ‘xxxxx’,

‘HOST’: ‘127.0.0.1’,

‘PORT’: ‘3306’,

}

}

SENTRY_URL_PREFIX = ‘http://sentry.shallwe.net:9000’ # 这里的端口号千万要写上,不然在web里会遇到麻烦

SENTRY_WEB_HOST = ‘0.0.0.0’
SENTRY_WEB_PORT = 9000

剩下的自己看着金牌娱乐官方网站

 

剩下开始处理暗礁,下面的bug,官方暂时没出补丁,要手工改。

进入mysql,

mysql>   create database sentry character set utf8;

要设置成utf8,不然在sentry web页面里就无法正常输入中文

然后进入 vim  /www/sentry/lib/python2.7/site-packages/Django-1.4.5-py2.7.egg/django/conf/global_settings.py

最后加上几句:

SOCIAL_AUTH_UID_LENGTH = 222
SOCIAL_AUTH_NONCE_SERVER_URL_LENGTH = 200
SOCIAL_AUTH_ASSOCIATION_SERVER_URL_LENGTH = 135
SOCIAL_AUTH_ASSOCIATION_HANDLE_LENGTH = 125

来设置django的某些金牌娱乐官方网站,不然会提示字符太长之类的错误

暗礁已过,剩下的就好办了

 

sentry --config=/etc/sentry.conf.py upgrade
在这一步里输入用户名和密码

sentry --config=/etc/sentry.conf.py start
现在就可以到web页面里看了,看完之后,把这个进程关掉,等会用supervisor启动它

第二大步骤,将sentry用supervisor启动
easy_install supervisor
echo_supervisord_conf > /etc/supervisord.conf
在 supervisord.conf中加入
[program:sentry-web]
directory=/www/sentry/
command=/www/sentry/bin/sentry  --config=/etc/sentry.conf.py start http
autostart=true
autorestart=true
redirect_stderr=true
运行supervisord
最后,要每次重启后都要启动supervisord
我是centos,在/etc/rc.local中加上
/usr/local/bin/supervisord  -c /etc/supervisord.conf &
真的最后一步了,我的机器上运行着apache,所以做了个反向代理,使得我可以通过80端口也可以访问sentry的web

<VirtualHost *:80>
ServerAdmin shallwe@shallwe.net
DocumentRoot “/usr/local/web/”
ServerName sentry.shallwe.net
<Directory />
Options FollowSymLinks
AllowOverride all
Order allow,deny
Allow from all
</Directory>
ProxyPass / http://localhost:9000/
ProxyPassReverse / http://localhost:9000/
ProxyPreserveHost On
ErrorLog “logs/todo-error_log”
CustomLog “/dev/null” common
</VirtualHost>



												

			

Leave a Reply