如何查看django的日志(2023年最新解答)

我想请说下,如何查看django的日志(2023年最新解答)
最新回答
干凈没朋友

2024-11-26 08:18:39

导读:很多朋友问到关于如何查看django的日志的相关问题,本文首席CTO笔记就来为大家做个详细解答,供大家参考,希望对大家有所帮助!一起来看看吧!

如何将服务端log实时在页面输出展示

在部署状态页面点击查看日志,将会打开日志页面,下个图就是日志的输出页面。

简约时尚小清新的日志页面出来了,是不是很想一个terminal,有没有觉得俺弄的页面很漂亮。哈哈哈哈,写不好前端的运维不是好DBA。

刚开始拿到这个需求,咋觉得很难。因为在服务器上我们看一个日志,经常会tail-f看着刷屏的感觉倍爽。如何在web页面上实现tailf的效果呢?

后来想想这样实现是可行的。前端写一个js定时器,不断的发ajax请求到后台,每回取出一段日志。后台取日志可以直接调用系统命令,或者直接调取shell脚本,取日志,判断日志文件是否存在,是否为空,返回数据的起始位置等,都可以交给shell来做。事实上我就是这么干的。后台程序写一堆shell命令调用有点别扭。想到解决方案之后,实现的过程就比较简单了。我的开发环境是基于python的Django框架来做的,现在就展示这个功能的实现过程。

Django部分

点击查看日志的链接之后会调到views里的ajxGetLog方法,该方法需要两个参数,项目id和主机id,这两个参数主要是用来确定日志文件的位置。该方法返回行号。

execcommand是封装的一个subprocess.Popen的一个工具函数,返回一个列表分别是标准输出,错误输出和shellreturncode

defajxGetLog(request,pid,hid):

project=Project.objects.get(pk=pid)

host=Host.objects.get(pk=hid)

scriptname='%s%s'%(base_path,'get_log.sh')

res=execcommand(['sh',scriptname,host.hostname,project.servicename])

#如果错误输出不为空,直接返回错误输出

ifnotres[1]:

try:

#res[0]为行号,如果大于20行,从当前行的上面20行开始输出,为了用户体验,你懂得

ifint(res[0])20:

line=int(res[0])-20

ifint(res[0])==0:

line=1

returnrender(request,'logs.html',{'pid':pid,'hid':hid,'line':line})

exceptException,e:

printe

returnHttpResponse(e)

else:

returnHttpResponse(res[1])

html部分首席写一个ajax请求,传递到后台取日志内容的方法,传递三个参数项目id,主机id,和行号,后台将会返回对应行号的日志内容。该方法代码如下:

defajxGetLogHandle(request,pid,hid,line):

project=Project.objects.get(pk=pid)

host=Host.objects.get(pk=hid)

scriptname='%s%s'%(base_path,'get_log.sh')

res=execcommand(['sh',scriptname,host.hostname,project.servicename,line])

ifnotres[1]andres[0].strip():

returnHttpResponse(res[0])

else:

returnHttpResponse(500)

django日志文件如何按时间日期切割,原生不支持吗

django日志文件如何按时间日期切割

linux下处理tomcat日志切割与删除操作:

System.out和System.err都被打印到catalina.out。catalina.out不会rotate。一般在部署tomcat后,运行久了,catalina.out文件会越来越大,对系统的稳定造成了一定的影响。

1、可通过修改conf/logging.properties日志配置文件来屏蔽掉这部分的日志信息。

将level级别设置成WARNING就可以大量减少日志的输出,当然也可以设置成OFF,直接禁用掉。

一般日志的级别有:

2、使用cronolog工具切分Tomcat的catalina.out日志文件,下载、安装cronolog。

用whichcronolog可以查到安装的路径,这个路径待会在修改catalina.sh时会用到。

修改catalina.sh将183行修改成184行内容,注释掉355行,368、369行替换成370、371行,379、380行替换成381、382行。

这样在/usr/local/tomcat/logs每天会自动生成catalina.%Y-%m-%d.out文件,下面要做的是定期清理这些过期的文件,可以通过crontab来实现。

Django日志功能踩坑

在Django按天记录日志里采用的TimedRotatingFileHandler进行日志处理,期望得到的效果是每天的日志单独存放在一个文件里。

但实际运行中,遇到两个棘手的问题。一个是用django自带的runserver直接运行,在rollover时会报错,提示有别的程序在占用日志文件。另一个是用IIS部署时,发现并不会自动rollover,所有日志仍然存在一个单独的文件里。

第一个问题直接用--noreload参数即可,原因之前也写过[Django]日志功能异常。

第二个问题挺奇怪,可能的原因是设置参数'when':'D'并不能够达成预期目的,这个参数的意思是按照间隔1天(默认为1天)的方式记录日志。但如果一直有日志数据报出,那么这个间隔1天的条件永远无法得到满足,结果就是一直无法触发rollover。

解决办法就是修改参数'when':'midnight',这样每天新日志消息一到来,就会触发日志文件的rollover,实现预期效果。

Django的日志如何配置

python的话,你可以把python的安装环境加到系统变量(我记得是自动添加的,可以在dos下直接运行python)

至于django的话,可以直接运行django-adminstartprojectmysite2(django-admin不用.py),不用pythondjango-admin.pystartprojectmysite2(如果要的话,需要在python安装包下的script添加到系统环境变量)

怎么查看django的url访问的log

最简单的形式

fromdjango.conf.urlsimportpatterns,url

urlpatterns=patterns('',

url(r'^articles/2003/$','news.views.special_case_2003'),

url(r'^articles/(\d{4})/$','news.views.year_archive'),

url(r'^articles/(\d{4})/(\d{2})/$','news.views.month_archive'),

url(r'^articles/(\d{4})/(\d{2})/(\d+)/$','news.views.article_detail'),

)

其中,正则表达式中组匹配出来的结果可以作为positionalparameters传递给view.

怎么实现后台django系统操作日志

怎么实现后台django系统操作日志

首先建个管理日志表。

然后建个类负责日志表的操作

我的日志表是这样的

日志ID

管理员ID

管理员姓名

操作类型

操作名称(执行什么操作)

时间

IP地址

备注

------------------------------

当然根据你的需要,可以建立更复杂的日志表。

我有个日志类,里面有个静态方法。

需要记录日志的时候,我就调用

EventLog.LogEvent(...)

--------------------------------

至于显示,就简单了。随便你怎么查询,最简单的绑定到DataGrid即可

结语:以上就是首席CTO笔记为大家整理的关于如何查看django的日志的全部内容了,感谢您花时间阅读本站内容,希望对您有所帮助,更多关于如何查看django的日志的相关内容别忘了在本站进行查找喔。