项目中记录影响性能的缓慢数据库查询
时间:2022-05-07
本文章向大家介绍项目中记录影响性能的缓慢数据库查询,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
如果程序性能随着时间推移不断降低,那很有可能是因为数据库查询变慢了,随着数据库规模的增长,这一情况还会变得更糟。优化数据库有时很简单,需要在程序和数据库之间加入缓存。大多数数据库查询语言都提供了explain语句,用来显示数据库执行查询时采取的步骤。从这些步骤中,我们经常能发现数据库或索引设计的不足之处。过 ,在开始优化查询之前,我们必须要知道哪些查询是值得优化的。在一次典型请求中,可能要执行多条数据库查询,所以经常很难分辨哪一条查询较慢。Flask-SQLAlchemy提供了一个选项,可以记录请求中执行的与数据库查询相关的统计数字。
——Flask Web开发:基于Python的Web应用开发实战
具体操作步骤如下:
1.设置语句查询最低时间值
app.config['FLASKY_DB_QUERY_TIMEOUT']=0.00000000001
2.在每次api请求结束后,判断每条查询语句执行时间是否低于设定的值,如果低于,则记录下查询语句相关信息。
@app.after_request
def after_request(response):
#录影响性能的缓慢数据库查询
for query in get_debug_queries():
if query.duration >= app.config['FLASKY_DB_QUERY_TIMEOUT']:
print '#####Slow query:%s nParameters:%s nDuration:%fsnContext:%sn #####'%
(query.statement, query.parameters, query.duration,query.context)
return response
其中 (query.statement, query.parameters, query.duration,query.context) 属性含义如图:
全部代码如下:
#coding:utf8
from flask import Flask, jsonify
import time
from flask_sqlalchemy import SQLAlchemy, get_debug_queries
db = SQLAlchemy()
app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI']='mysql://root:password@127.0.0.1:3306/database_name?charset=utf8'
app.config['SQLALCHEMY_COMMIT_ON_TEARDOWN']=True
app.config['SECRET_KEY']='rgc is a good boy!hehe!'
# 启用缓慢查询记录功能
# app.config['SQLALCHEMY_RECORD_QUERIES']=True
app.config['FLASKY_DB_QUERY_TIMEOUT']=0.00000000001
db.init_app(app)
class User(db.Model):
__tablename__ = 'user'
id = db.Column('id', db.Integer, primary_key=True, autoincrement=True)
email = db.Column('email', db.String(64), unique=True) # 邮箱
def __init__(self, email):
self.email = email
def to_dict(self):
output_dict = {}
output_dict.update(self.__dict__)
if "_sa_instance_state" in output_dict:
del output_dict['_sa_instance_state']
return output_dict
@app.teardown_request
def handle_teardown_request(ex):
db.session.remove()
@app.after_request
def after_request(response):
#录影响性能的缓慢数据库查询
for query in get_debug_queries():
if query.duration >= app.config['FLASKY_DB_QUERY_TIMEOUT']:
print '#####Slow query:%s nParameters:%s nDuration:%fsnContext:%sn #####'%
(query.statement, query.parameters, query.duration,query.context)
return response
@app.route('/users/<email>')
def line_test(email):
result_id=db.session.query(User.id).filter_by(email=email).first()
return jsonify({'code':200,'email':email,'id':result_id[0]})
if __name__=='__main__':
app.run(debug=True)
运行结果如下:
* Detected change in '/home/rgc/baidu_eye/carrier/test/flask_test_mongo.py', reloading
* Restarting with reloader
#####Slow query:SELECT user.id AS user_id
FROM user
WHERE user.email = %s
LIMIT %s
Parameters:('3@qq.com', 1)
Duration:0.000331s
Context:/home/rgc/baidu_eye/carrier/test/flask_test_mongo.py:47 (line_test)
#####
127.0.0.1 - - [07/Mar/2018 18:37:05] "GET /users/3@qq.com HTTP/1.1" 200 -
通过此方式,把查询缓慢的数据记录到日志中,便可以进行针对性的数据库优化,提升用户体验。
- 一个Oracle bug的手工修复(r6笔记第59天)
- 由drop datafile导致的oracle bug(r6笔记第56天)
- Java中static关键字的作用
- Java基础-20(02)总结,递归,IO流
- Hive四种数据导入方式
- 34c3 部分Web Writeup
- 原来Oracle也不喜欢“蜀黍"(r6笔记第54天)
- Java基础19(01)总结IO流,异常try…catch,throws,File类
- 使用shell生成orabbix自动化配置脚本(r6笔记第53天)
- 现在 tensorflow 和 mxnet 很火,是否还有必要学习 scikit-learn 等框架?
- 数据的标准化与中心化以及R语言中的scale详解
- Java基础19(02)总结IO流,异常try…catch,throws,File类
- HTML5 — header
- 两条报警信息的分析(第二篇)(r6笔记第71天)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Python 利用OpenCV给照片换底色
- Python爬虫实战 批量下载高清美女图片
- Python matplotlib数据可视化 绘制柱形图、堆叠图、折线图、饼图和环图
- Python Matplotlib数据可视化 绘制箱形图、散点图和直方图
- 【Lighthouse教程】scrapy爬虫初探
- Python爬虫 爬取B站视频弹幕 + 绘制词云
- Python爬虫学习笔记 asyncio+aiohttp 异步爬虫原理和解析
- Python数据分析 利用NetworkX绘制网络图
- Python爬虫练习 爬取网络小说保存到txt
- Python爬取链家成都二手房源信息 asyncio + aiohttp 异步爬虫实战
- Python matplotlib数据可视化 subplot绘制多个子图
- python pathlib模块的基本使用和总结
- Python 爬取前程无忧最新招聘数据 matplotlib数据分析与可视化
- Python opencv图像处理基础总结(一)
- Python opencv图像处理基础总结(二) ROI操作与泛洪填充 模糊操作 边缘保留滤波EPF