当前位置: 首页 > news >正文

秦皇岛网站备案个人网站用什么程序

秦皇岛网站备案,个人网站用什么程序,wordpress大幅广告,建站一条龙设计制作TIPS 本文基于MySQL 8.0 本文探讨如何深入SQL内部,去分析其性能,包括了三种方式: SHOW PROFILEINFORMATION_SCHEMA.PROFILINGPERFORMANCE_SCHEMA SHOW PROFILE SHOW PROFILE是MySQL的一个性能分析命令,可以跟踪SQL各种资源消耗。…

TIPS
本文基于MySQL 8.0
本文探讨如何深入SQL内部,去分析其性能,包括了三种方式:

  • SHOW PROFILE
  • INFORMATION_SCHEMA.PROFILING
  • PERFORMANCE_SCHEMA

SHOW PROFILE

SHOW PROFILE是MySQL的一个性能分析命令,可以跟踪SQL各种资源消耗。使用格式如下:

SHOW PROFILE [type [,type] ... ][FOR QUERY n][LIMIT row_count [OFFSET offset]]
type:{ALL					显示所有信息| BLOCK IO				显示阻塞的输入输出次数| CONTEXT SWITCHES		显示自愿及非自愿的上下文切换次数| CPU					显示用户与系统CPU使用时间| IPC					显示消息发送与接收的次数| MEMORY				显示内存相关的开销,目前未实现此功能| PAGE FAULTS			显示页错误相关开销信息| SOURCE				列出相应操作对应的函数名及其在源码中的位置(行)| SWPS					显示swap交换次数
}

默认情况下,SHOW PROFILE只展示Status和Duration两列,如果想展示更多信息,可指定type。
使用步骤如下:

  • 使用如下命令,查看是否支持SHOW PROFILE功能,yes表示支持。MySQL5.0.37开始,MySQL支持SHOW PROFILE。
select @@have_profiling;
  • 查看当前是否启用了SHOW PROFILE,0表示未启用,1表示已启用
select @@profiling;
  • 使用如下命令为当前会话开启或关闭性能分析,设成1表示开启,0表示关闭
set profiling = 1;
  • 使用SHOWPROFILS命令,可为最近发送的SQL语句做一个概要的性能分析。展示的条目数由profiling_history_size会话变量控制,该变量的默认值是15,最大值为100.将值设置为0具有禁用分析的实际效果。
-- 默认展示15条
show profiles;
-- 使用profiling_history_size调整展示的条目数
set profiling_history_size = 100;
  • 使用show profile分析指定查询:
SHOW PROFILES;

在这里插入图片描述

SHOW PROFILE;

在这里插入图片描述
默认情况下,只展示Status和Duration两列,如果想展示更多信息,可指定type。

SHOW PROFILE FOR QUERY 154;

在这里插入图片描述
展示CPU相关的开销

SHOW PROFILE CPU FOR QUERY 184;

在这里插入图片描述
分析完成后,记得关掉SHOW PROFILE功能;

TIPS

  • MySQL官方文档申明SHOW PROFILE已被废弃,并建议使用PerforMance Schema作为代替品。
  • 在某些系统上,性能分析只有部分功能可用。比如,部分功能在Windows系统下无效(show profile使用了getrusage()这个API,而在Windows系统上将会返回false,因为Windows不支持这个API);此外,性能分析是进程级的,而不是线程级的,这就意味着其他线程的活动可能会影响到一看到的计时信息。

INFORMATION_SCHEMA.PROFILING

INFORMATION_SCHEMA.PROFILING用来做性能分析,它的内容对应SHOW PROFILE和SHOW PROFILES语句产生的信息。除非设置了set profiling = 1否则该表不会有任何数据。该表包括以下字段:

  • QUERY_ID:语句的唯一标识
  • SEQ:一个序号,展示具有相同QUERY_ID值的行的显示顺序
  • STATE:分析状态
  • DURATION:在这个状态下持续了多久(秒)
  • CPU_USER,CPU_SYSTEM:用户和系统CPU使用情况(秒)
  • CONTEXT_VOLUNTARY,CONTEXT_INVOLUNTARY:发生了多少次自愿和非自愿的上下文切换
  • BLOCK_OPS_IN,BLOCK_OPS_OUT:块输入和输出操作的数量
  • MESSAGES_SENT,MESSAGES_RECEIVED:发送和接收的消息数
  • PAGE_FAULTS_MAJOR,PAGE_FAULTS_MINOR:主要和次要的页错误信息
  • SWAPS:发生了多少SWAP
  • SOURCE_FUNCTION,SOURCE_FILE,SOURCE_LINE:当前状态实在源码的哪里执行的

TIPS

  • SHOW PROFILE本质上使用的也是INFORMATION_SCHEMA.PROFILING表;
  • INFORMATION_SCHEMA.PROFILING表已被废弃,在未来可能会被删除。未来将可使用Performance Schema替代。
  • 下面两个SQL是等价的:
    SHOW PROFILE FOR QUERY 1;
    SELECT STATE,FORMAT(DURATION,6) AS DURATION FROM INFORMATION_SCHEMA.PROFILING WHERE QUERY_ID = 1 ORDER BY SEQ;

PERFORMANCE_SCHEMA

PERFORMANCE_SCHEMA是MySQL建议的性能分析方式,未来SHOW PROFILE,INFORMATION_SCHEMA.PROFILING都会废弃。PERFORMANCE_SCHEMA在MySQL5.6引入,因此,在此之上的更高的版本才能使用。可使用**SHOW VARIABLES LIKE ‘performance_schema’;**查看启用情况,MySQL5.7开始默认启用。

下面来用PERFORMANCE_SCHEMA去实现SHOW PROFILE类似的效果:

  • 查看是否开启性能监控
SELECT * FROM performance_schema.setuo_actors;

在这里插入图片描述
默认是开启的。

  • 也可以执行类似如下的SQL语句,只监控指定用户执行的SQL:
UPDATE performance_schema.setup_actors SET ENABLED = 'NO',HISTORY = 'NO' WHERE HOST = '%' AND USER = '%';INSERT INTO performance_schema.setup_actors (HOST,USER,ROLE,ENABLED,HISTORY) VALUE
('localhost','test_user','%','YES','YES');

这样,就只会监控localhost服务器上test_user用户发送过来的SQL。其他服务器、其他用户发过来的SQL统统不监控。

  • 执行如下SQL语句,开启相关监控项:
UPDATE performance_schema.setup_instruments SET ENABLED = 'YES',TIMED = 'YES' WHERE NAME LIKE '%statement/%';UPDATE performance_schema.setup_instruments SET ENABLED = 'YES',TIMED = 'YES' WHERE NAME LIKE '%stage/%';UPDATE performance_schema.setup_consumers SET ENABLED = 'YES' WHERE NAME LIKE '%events_statements_%';UPDATE performance_schema.setup_consumers SET ENABLED = 'YES' WHERE NAME LIKE '%events_stages_%';
  • 使用开启监控的用户,执行SQL语句,比如:
select * from employees where emp_no = '10001';

在这里插入图片描述

  • 执行如下SQL,获得语句的EVENT_ID:
SELECT EVENT_ID,TRUNCATE(TIMER_WAIT/1000000000000,6) AS Duration,SQL_TEXT
FROM performance_schema.events_statements_history_long
WHERE SQL_TEXT LIKE '%10001%';

在这里插入图片描述
这一步类似于SHOW PROFILES。

  • 执行如下SQL语句做性能分析,这样就可以知道这条语句各个阶段的信息了。
SELECT event_name AS State,TRUNCATE(TIMER_WAIT/1000000000000,6) AS Duration 
FROM performance_schema.events_stages_history_long
WHERE NESTING_EVENT_ID = 869;

在这里插入图片描述

http://www.yayakq.cn/news/150429/

相关文章:

  • 搭建简单的网站邢台网约车平台有哪些
  • 网站建设摊销方法网页论坛怎么实现
  • 江苏网站备案流程图做网站的那些事
  • 怎么什么软件可以吧做网站网站建设服务天软科技
  • wordpress子站点解析网站建站制作
  • 地方网站做相亲赢利点在哪如何用工控做网站
  • 宁波网站推广平台咨询公司安徽省住房和城乡建设厅官网网站
  • 北京营销型网站建设价格公司域名邮箱怎么注册
  • 苗木企业网站建设源代码网站挣钱网
  • 电商加盟网站建设中国企业500强排名2021
  • 中国外贸网站大全怎么做网站程序
  • 网站怎么做的支付宝接口东莞网站建设方案报价
  • 找钢网网站建设百度云登录
  • 免费建站网站制作模板上海手机站网站建设
  • 广州网站制作网页企业网站seo名称
  • 郫都区规划建设局网站wordpress媒体库略缩图
  • 重庆模板自助建站蓟县集团网站建设
  • 网站制作网站制作公司网站建设免费空间注册导航
  • 企业网站源码变现方法名匠装饰公司
  • 做移动网站点击软件吗图片瀑布流网站
  • 微网站建设公司哪家好建模网站素材
  • 中山市企业网站建立外包公司是什么
  • 在哪下载免费的英文版网站模板上海网网站建设
  • 网站建设返回函数wordpress 插件角色
  • 软件营销网站建设安顺公司做网站
  • 为什么网站生成后不显示余杭区建设规划局网站
  • 校园网站开发的目的开发网站开发工程师招聘要求
  • 河间米各庄网站建设制作wordpress的文章采集
  • wap网站的未来网站建设的网络
  • 网站建设完成外网无法访问公司做网站需要