PCB SQL SERVER 数据库阻塞进程关系以思维导图方式呈现的实现方法-阿里云开发者社区

开发者社区> 优惠码大使> 正文

PCB SQL SERVER 数据库阻塞进程关系以思维导图方式呈现的实现方法

简介: PCB SQL SERVER 数据库阻塞进程关系以思维导图方式呈现的实现方法 最近公司数据库同步机制常发生阻塞,时不时的导致PCB工程系统卡死现象,只有找到阻塞源头并处理掉,才以消除阻塞,但数据库中查看会话阻塞是通过二维表方式展示的父子会话进程ID的,是很难清楚的展示各会话进程ID的关系图的。
+关注继续查看

PCB SQL SERVER 数据库阻塞进程关系以思维导图方式呈现的实现方法

        最近公司数据库同步机制常发生阻塞,时不时的导致PCB工程系统卡死现象,只有找到阻塞源头并处理掉,才以消除阻塞,但数据库中查看会话阻塞是通过二维表方式展示的父子会话进程ID的,是很难清楚的展示各会话进程ID的关系图的。

举例:这好比公路上的汽车我们开车前行,遇到前方塞车了,前方的车阻塞你,但后方又继续来车,你也成为后方的车阻塞者。

如果能以思维导图的方式展示那不完美了,我们可以通过此图可很快的找找到阻焊塞的源头,只要把源头打通,道路才能保持畅通。

一.阻塞查询相关SQL语句
查询当前数据库阻塞:

select * from sys.sysprocesses where blocked<>0
查询阻塞的会话在执行的SQL以及运行状态:
select * from sys.sysprocesses where spid=197
查询阻塞会话执行所有DB库

select * from sys.sysdatabases WHERE dbid = 7
通过sql_handle句柄来查询正在跑的SQL的SQL_TEXT文本内容,即SQL内容:
SELECT * FROM ::FN_GET_SQL(0x0300FF7F587A2F063508ED005E9B000001000000)
删除进程会话ID

KILL 197

二.阻塞进程思维导图----展示效果
通过如图展示,非常清楚的知道阻塞进程源头来自哪个进程号了【源头:会话进程ID 536导致整个数据库阻塞】

三.HTML实现代码

   HTML实现代码:(用百度他们家的echar套用数据即可实现)

   http://pcbren.cn/DB_BlockedView.html

四.阻塞进程数据源

   通过此SQL取出2部份数据
 1.EChart nodes 节点数据
 2.EChart links 关连关系数据

复制代码
--查询当前数据库阻塞进程插入临时表
select * INTO #sysprocesses FROM sys.sysprocesses where blocked<>0

--获取进程节点【数据给到EChart nodes】
--将数据按3个等级分类,按实例图展示效果
SELECT
' {category:'+ (CASE WHEN PerentCount = 0 THEN '0' WHEN ChildCount > 0 THEN '1' ELSE '2' END) +', name: '''+ CAST(spid AS VARCHAR(1000))
+''', value : '+ (CASE WHEN PerentCount = 0 THEN '3' WHEN ChildCount > 0 THEN '2' ELSE '1' END) + '},'
FROM
(

SELECT  
    (SELECT COUNT(1) FROM #sysprocesses  WHERE blocked = t.spid) ChildCount
    ,(SELECT  COUNT(1) FROM #sysprocesses  WHERE spid = t.spid) PerentCount
    ,spid
FROM 
(
SELECT spid spid
FROM #sysprocesses
UNION ALL 
SELECT blocked spid
FROM #sysprocesses
) t
GROUP BY spid

) t

--获取节点之前的关连关系【数据给到EChart links】
SELECT '{source : '''+ CAST(spid AS VARCHAR(1000)) +''', target : '''+ CAST(blocked AS VARCHAR(1000))+''', weight : 1},'
FROM #sysprocesses

drop table #sysprocesses
复制代码

作者:pcbren

QQ交流群:PCB之脚本也泛滥

博客地址:https://www.cnblogs.com/pcbren/

声明:本博客原创文字只代表本人工作中在某一时间内总结的观点或结论,与本人所在单位没有直接利益关系。非商业,未授权,贴子请以现状保留,转载时必须保留此段声明,且在文章页面明显位置给出原文连接。

如果大家感觉我的博文对大家有帮助,请推荐支持一把。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
ECS使用体验
在阿里云领取了一个服务器,分享一下使用体验
9 0
编码 5 分钟,命名 2 小时?Java 开发都需要参考的一份命名规范!
简洁清爽的代码风格应该是大多数工程师所期待的。在工作中笔者常常因为起名字而纠结,命名已经成为我工作中的拦路虎,夸张点可以说是编程5分钟,命名两小时!
13 0
面试官问:ZooKeeper是强一致的吗?怎么实现的?
Zookeeper通过ZAB保证分布式事务的最终一致性。 ZAB全称Zookeeper Atomic Broadcast(ZAB,Zookeeper原子消息广播协议)
6 0
不要再封装各种 Util 工具类了,这个神级框架值得拥有!
Hutool 谐音 “糊涂”,寓意追求 “万事都作糊涂观,无所谓失,无所谓得” 的境界。 Hutool 是一个 Java 工具包,也只是一个工具包,它帮助我们简化每一行代码,减少每一个方法,让 Java 语言也可以 “甜甜的”。Hutool 最初是我项目中 “util” 包的一个整理,后来慢慢积累并加入更多非业务相关功能,并广泛学习其它开源项目精髓,经过自己整理修改,最终形成丰富的开源工具集。(FROM 自作者简介)
6 0
从零实现一个日志框架(带源码)
Java里的各种日志框架,相信大家都不陌生。Log4j/Log4j2/Logback/jboss logging等等,其实这些日志框架核心结构没什么区别,只是细节实现上和其性能上有所不同。本文带你从零开始,一步一步的设计一个日志框架
17 0
ECS使用有感
我是一名即将步入社会的大学生,随着网络法等相关专业知识的学习愈发强烈。查询资料时,常常会浏览到制作精美的个人站,因此产生了建设自己个人站的设想,但是由于业余时间少之甚少,同时听闻购买域名与服务器的价格不菲,因此计划一直未能实现
6 0
Spring 中经典的 9 种设计模式,打死也要记住啊!
实现方式: BeanFactory。Spring中的BeanFactory就是简单工厂模式的体现,根据传入一个唯一的标识来获得Bean对象,但是否是在传入参数后创建还是传入参数前创建这个要根据具体情况来定。
21 0
ECS使用有感
我是一名即将步入社会的大学生,随着网络法等相关专业知识的学习愈发强烈。查询资料时,常常会浏览到制作精美的个人站,因此产生了建设自己个人站的设想,但是由于业余时间少之甚少,同时听闻购买域名与服务器的价格不菲,因此计划一直未能实现
8 0
从零到一上手玩转云服务器体验报告
1,动手实战-初识上云基础,动手实操ECS云服务器新手上路 2,动手实战-上云必备环境准备,动手实操快速搭建LAMP环境 3,动手实战-云上多产品学习,使用ECS服务器部署MySQL数据库 4,动手实战-最佳应用实践,使用PolarDB和ECS搭建门户网站
5 0
使用有感
我是一名即将步入社会的大学生,随着网络法等相关专业知识的学习愈发强烈。查询资料时,常常会浏览到制作精美的个人站,因此产生了建设自己个人站的设想,但是由于业余时间少之甚少,同时听闻购买域名与服务器的价格不菲,因此计划一直未能实现
5 0
+关注
优惠码大使
阿里云优惠码bieryun.com
171
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载