首页>>后端>>Python->django怎么往日志中输出(2023年最新分享)

django怎么往日志中输出(2023年最新分享)

时间:2023-12-25 本站 点击:0

导读:今天首席CTO笔记来给各位分享关于django怎么往日志中输出的相关内容,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

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

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

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

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

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

Django部分

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

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

def ajxGetLog(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])

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

if not res[1]:

try:

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

if int(res[0]) 20:

line = int(res[0]) - 20

if int(res[0]) == 0:

line = 1

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

except Exception,e:

print e

return HttpResponse(e)

else:

return HttpResponse(res[1])

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

def ajxGetLogHandle(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])

if not res[1] and res[0].strip():

return HttpResponse(res[0])

else:

return HttpResponse(500)

Django的日志如何配置

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

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

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

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

首先建个管理日志表。

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

我的日志表是这样的

日志ID

管理员ID

管理员姓名

操作类型

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

时间

IP地址

备注

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

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

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

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

EventLog.LogEvent(...)

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

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

结语:以上就是首席CTO笔记为大家整理的关于django怎么往日志中输出的相关内容解答汇总了,希望对您有所帮助!如果解决了您的问题欢迎分享给更多关注此问题的朋友喔~


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:/Python/59994.html