django性能监测工具silk使用方法(初级)

2023-11-02 08:21

本文主要是介绍django性能监测工具silk使用方法(初级),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

django-silk介绍

web开发过程中,经常要掌握程序的性能状况,遇到性能瓶颈还要进行进一步的分析,如执行时间、网络耗时、数据库连接时间等;如果你是基于django框架开发,那接下来,那么django-silk将会成为你的得力助手。


环境需求

  • Django: 1.11, 2.0
  • Python: 2.7, 3.4, 3.5, 3.6

安装

django-silk地址:
https://github.com/jazzband/django-silk

# pip install -U django-silk

如果你的python版本是3.x,则使用pip3 install -U django-silk

提示:建议使用virtualenv进行开发包的管理

# virtualenv --system-site-packages -p python3 自定义名称
# source 自定义名称/bin/activate

配置

在settings.py文件中加入如下内容:

INSTALLED_APPS = (...'silk'
)MIDDLEWARE = [...'silk.middleware.SilkyMiddleware',...
]

在url.py中加入

urlpatterns += [url(r'^silk/', include('silk.urls', namespace='silk'))]

然后生成silk用的相关数据库表

python manage.py makemigrationspython manage.py migratepython manage.py collectstatic

如果settings.py中没有配置过STATIC_ROOT,在执行“python manage.py collectstatic”的时候,有可能会报错,提示缺少STATIC_ROOT配置。加上即可。如:STATIC_ROOT = BASE_DIR。

在这之后,就可以使用silk了。

查看性能报告

启动项目:

python manage.py runserver

访问:项目网址/silk(如:http://127.0.0.1:8080/silk),可以看到silk自带的页面,如下:
silk首页
通过页面,我们可以看到很多GET、POST请求,以及各种数字。代表silk可以记录的数据

  • 所用时间(Time taken)
  • 数查询(Num. queries)
  • 查询花费的时间(Time spent on queries)
  • 请求/响应标头(Request/Response headers)
  • 请求/响应正文(Request/Response bodies)

点击相关请求还可以获得有关每个请求的更多详细信息:
请求的详细信息
如图例,本次请求的method是POST,访问的url是/admin/,总耗时793毫秒,查询花费2毫秒,共7次查询。如果你想看具体每次查询的内容,可以点击页面左上方的SQL,继而可以看到所有的查询,以及每次查询的消耗时间。
SQL查询详细
如果你想查看SQL具体都执行了什么代码,可以点击继续深入
SQL查询详细的深入查看

如果你想查看查询的过程哪个环节耗费了多少时间,请进入Profiling。需要我们在setting.py中配置

# 使用Python的内置cProfile分析器
SILKY_PYTHON_PROFILER = True
# 生成.prof文件,silk产生的程序跟踪记录,详细记录来执行来哪个文件,哪一行,用了多少时间等信息
SILKY_PYTHON_PROFILER_BINARY = True
# .prof文件保存路径(最好不要像我这样设置在项目目录中)
# 如果没有本设置,prof文件将默认保存在MEDIA_ROOT里
SILKY_PYTHON_PROFILER_RESULT_PATH = os.path.join(BASE_DIR, 'logs')

经过上述设置后,每次请求都会生成一个prof文件,而且名称无意义。所以我们进行性能分析时一定要及时分析,否则回头再找prof文件,就会比较麻烦,不过,也没有那么麻烦。
prof

这些信息在页面中也可以查看,不是必须要生成prof文件。
profiling
.prof是二进制文本文件,一般的编辑器看不到可读内容。所以我们需要借助一些工具。我使用的是SNAKEVIZ。

SNAKEVIZ

安装

# pip install -U snakeviz

查看prof

# snakeviz /path/to/your/program.prof

记录

记录profiling的时候,我们需要给每个请求起个名字,作为标识

from silk.profiling.profiler import silk_profile
...
@silk_profile(name='View Blog Post')  # name=你自己设置的请求标识
def post(request, post_id):p = Post.objects.get(pk=post_id)return render_to_response('post.html', {'post': p})
...

还有一种方法,可以查看具体某一个数据库操作的性能

def post(request, post_id):with silk_profile(name='View Blog Post #%d'%self.pk):p = Post.objects.get(pk=post_id)return render_to_response('post.html', {'post': p})

然后就可以探索了。
进一步的使用方法的心得,以后再记录

参考一篇SnakeViz GitHub的中文翻译:
https://www.helplib.com/GitHub/article_118718

这篇关于django性能监测工具silk使用方法(初级)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/329335

相关文章

Java中Arrays类和Collections类常用方法示例详解

《Java中Arrays类和Collections类常用方法示例详解》本文总结了Java中Arrays和Collections类的常用方法,涵盖数组填充、排序、搜索、复制、列表转换等操作,帮助开发者高... 目录Arrays.fill()相关用法Arrays.toString()Arrays.sort()A

如何使用Lombok进行spring 注入

《如何使用Lombok进行spring注入》本文介绍如何用Lombok简化Spring注入,推荐优先使用setter注入,通过注解自动生成getter/setter及构造器,减少冗余代码,提升开发效... Lombok为了开发环境简化代码,好处不用多说。spring 注入方式为2种,构造器注入和setter

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

MySQL中比较运算符的具体使用

《MySQL中比较运算符的具体使用》本文介绍了SQL中常用的符号类型和非符号类型运算符,符号类型运算符包括等于(=)、安全等于(=)、不等于(/!=)、大小比较(,=,,=)等,感兴趣的可以了解一下... 目录符号类型运算符1. 等于运算符=2. 安全等于运算符<=>3. 不等于运算符<>或!=4. 小于运

使用zip4j实现Java中的ZIP文件加密压缩的操作方法

《使用zip4j实现Java中的ZIP文件加密压缩的操作方法》本文介绍如何通过Maven集成zip4j1.3.2库创建带密码保护的ZIP文件,涵盖依赖配置、代码示例及加密原理,确保数据安全性,感兴趣的... 目录1. zip4j库介绍和版本1.1 zip4j库概述1.2 zip4j的版本演变1.3 zip4

Python 字典 (Dictionary)使用详解

《Python字典(Dictionary)使用详解》字典是python中最重要,最常用的数据结构之一,它提供了高效的键值对存储和查找能力,:本文主要介绍Python字典(Dictionary)... 目录字典1.基本特性2.创建字典3.访问元素4.修改字典5.删除元素6.字典遍历7.字典的高级特性默认字典

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

Nginx安全防护的多种方法

《Nginx安全防护的多种方法》在生产环境中,需要隐藏Nginx的版本号,以避免泄漏Nginx的版本,使攻击者不能针对特定版本进行攻击,下面就来介绍一下Nginx安全防护的方法,感兴趣的可以了解一下... 目录核心安全配置1.编译安装 Nginx2.隐藏版本号3.限制危险请求方法4.请求限制(CC攻击防御)

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法