今天遇到最棘手的问题,就是网站速度很慢,并且是一阵一阵的,用show processlist,
也有可能遭到攻击,对sql进行了优化,尽量减少嵌套查询,而是采用空间换时间,新建表,通过任务更新到新表
processlist命令的输出结果显示了有哪些线程在运行,可以帮助识别出有问题的查询语句,两种方式使用这个命令。
1. 进入mysql/bin目录下输入mysqladmin processlist;
2. 启动mysql,输入show processlist;
如果有 SUPER 权限,则可以看到全部的线程,否则,只能看到自己发起的线程(这是指,当前对应的MySQL帐户运行的线程)。
得到数据形式如下(只截取了三条):
mysql> show processlist;
+-----+-------------+--------------------+-------+---------+-------+----------------------------------+----------
| Id | User | Host | db | Command | Time| State | Info
+-----+-------------+--------------------+-------+---------+-------+----------------------------------+----------
|207|root |192.168.0.20:51718 |mytest | Sleep | 5 | | NULL
|208|root |192.168.0.20:51719 |mytest | Sleep | 5 | | NULL
|220|root |192.168.0.20:51731 |mytest |Query | 84 | Locked |
select bookname,culture,value,type from book where id=001
先简单说一下各列的含义和用途,第一列,id,不用说了吧,一个标识,你要kill一个语句的时候很有用。user列,显示单前用户,如果不是 root,这个命令就只显示你权限范围内的sql语句。host列,显示这个语句是从哪个ip的哪个端口上发出的。呵呵,可以用来追踪出问题语句的用户。 db列,显示这个进程目前连接的是哪个数据库。command列,显示当前连接的执行的命令,一般就是休眠(sleep),查询(query),连接(connect)。time列,此这个状态持续的时间,单位是秒。state列,显示使用当前连接的sql语句的状态,很重要的列,后续会有所有的状态的描述,请注意,state只是语句执行中的某一个状态,一个sql语句,已查询为例,可能需要经过copying to tmp table,Sorting result,Sending data等状态才可以完成,info列,显示这个sql语句,因为长度有限,所以长的sql语句就显示不全,但是一个判断问题语句的重要依据。
这个命令中最关键的就是state列,mysql列出的状态主要有以下几种:
Checking table
正在检查数据表(这是自动的)。
Closing tables
正在将表中修改的数据刷新到磁盘中,同时正在关闭已经用完的表。这是一个很快的操作,如果不是这样的话,就应该确认磁盘空间是否已经满了或者磁盘是否正处于重负中。
Connect Out
复制从服务器正在连接主服务器。
Copying to tmp table on disk
由于临时结果集大于 tmp_table_size,正在将临时表从内存存储转为磁盘存储以此节省内存。
Creating tmp table
正在创建临时表以存放部分查询结果。
deleting from main table
服务器正在执行多表删除中的第一部分,刚删除第一个表。
deleting from reference tables
服务器正在执行多表删除中的第二部分,正在删除其他表的记录。
Flushing tables
正在执行 FLUSH TABLES,等待其他线程关闭数据表。
Killed
发送了一个kill请求给某线程,那么这个线程将会检查kill标志位,同时会放弃下一个kill请求。MySQL会在每次的主循环中检查 kill标志位,不过有些情况下该线程可能会过一小段才能死掉。如果该线程程被其他线程锁住了,那么kill请求会在锁释放时马上生效。
Locked
被其他查询锁住了。
Sending data
正在处理 SELECT 查询的记录,同时正在把结果发送给客户端。
Sorting for group
正在为 GROUP BY 做排序。
Sorting for order
正在为 ORDER BY 做排序。
Opening tables
这个过程应该会很快,除非受到其他因素的干扰。例如,在执 ALTER TABLE 或 LOCK TABLE 语句行完以前,数据表无法被其他线程打开。 正尝试打开一个表。
Removing duplicates
正在执行一个 SELECT DISTINCT 方式的查询,但是MySQL无法在前一个阶段优化掉那些重复的记录。因此,MySQL需要再次去掉重复的记录,然后再把结果发送给客户端。
Reopen table
获得了对一个表的锁,但是必须在表结构修改之后才能获得这个锁。已经释放锁,关闭数据表,正尝试重新打开数据表。
Repair by sorting
修复指令正在排序以创建索引。
Repair with keycache
修复指令正在利用索引缓存一个一个地创建新索引。它会比 Repair by sorting 慢些。
Searching rows for update
正在讲符合条件的记录找出来以备更新。它必须在 UPDATE 要修改相关的记录之前就完成了。
Sleeping
正在等待客户端发送新请求.
System lock
正在等待取得一个外部的系统锁。如果当前没有运行多个 mysqld 服务器同时请求同一个表,那么可以通过增加 --skip-external-locking参数来禁止外部系统锁。
Upgrading lock
INSERT DELAYED 正在尝试取得一个锁表以插入新记录。
Updating
正在搜索匹配的记录,并且修改它们。
User Lock
正在等待 GET_LOCK()。
Waiting for tables
该线程得到通知,数据表结构已经被修改了,需要重新打开数据表以取得新的结构。然后,为了能的重新打开数据表,必须等到所有其他线程关闭这个表。以下几种情况下会产生这个通知:FLUSH TABLES tbl_name, ALTER TABLE, RENAME TABLE, REPAIR TABLE, ANALYZE TABLE, 或 OPTIMIZE TABLE。
waiting for handler insert
INSERT DELAYED 已经处理完了所有待处理的插入操作,正在等待新的请求。
大部分状态对应很快的操作,只要有一个线程保持同一个状态好几秒钟,那么可能是有问题发生了,需要检查一下。
还有其他的状态没在上面中列出来,不过它们大部分只是在查看服务器是否有存在错误是才用得着。
分享到:
相关推荐
博文链接:https://dodomail.iteye.com/blog/245758
社交网站后端项目开发日记(一)(csdn)————程序
安卓期末大作业-日记本(免积分下载) 压缩包内包含源代码,运行各个界面截图,一条日记可以记录2000字符以下的文本、最多8张配图和最多8个视频。每条日记都可以以评论的形式或转发引用的形式追更,评论的最大长度也...
java web+ajax+jQuery+Mysql技术实现网站九宫格日记的开发
⑤分享日记,将自己的心情日记分享到QQ空间、新浪微博等社交网站,分享心情分享生活;⑥导出日记,便于心情日记保存管理。2、语言日记:①新建语音日记;②播放语音日记;③删除语音日记。3、知心电话:①添加手机...
转来的MOSS开发日记,共享一下。开发前期准备 工欲善其事,必先利其器。很多朋友可能和我一样,需要对MOSS 进行开发,但是感觉又是一头雾水,不知道从何做起。 这里,从开发学习环境的搭建开始,开始我们一步一步...
网页设计实习日记范文10篇.pdf网页设计实习日记范文10篇.pdf网页设计实习日记范文10篇.pdf网页设计实习日记范文10篇.pdf网页设计实习日记范文10篇.pdf网页设计实习日记范文10篇.pdf网页设计实习日记范文10篇.pdf网页...
一直有写日记的习惯,突然想找个 日记本程序 ,找了半天也一无所获,所以突然萌生了写一个日记本程序的想法, 本程序由熊海开发,基于ASP/ACCESS架构,本程序可用于微博,日记,博客等用途,后续我也将会继续更新...
明日科技等编著的《实战突击:PHP项目开发案例整合(附光盘)》以会议记录管理系统、留言本、在线投票系统、个人网络日记、在线论坛、博客、物流管理系统、在线考试管理系统、明日编程词典、明日科技企业网站、明日...
PHP实例开发源码—最新仿花生日记淘宝客双端原生APP网站源码.zip
我们暂时只是开发一个网站,所以我们的产品暂时开发所用运行环境为: Windows 系统(Windows 10) Cpu i5-6500 开发软件 eclipse 环境 jdk 9.0 服务器:tomcat 9 详细介绍参考:...
九宫格日记由九个方方正正的格子组成九个格子九个主题,用户只需要在每个格子中填写相应的内容就能完成一篇日记,整个过程只需要几分钟。九宫格日记因其便捷、省时等优点在网上迅速风行开来,倍受学生、年轻人和上班族...
软件开发设计:应用软件开发、系统软件开发、移动应用开发、网站开发C++、Java、python、web、C#等语言的项目开发与学习资料 硬件与设备:单片机、EDA、proteus、RTOS、包括计算机硬件、服务器、网络设备、存储设备...
3月12日:继续深入理解和尝试部门政务网站的架构方法和功能模块实现方法。向师傅和同事们请教相关问题。 3月13日:进行前台的设计实际建设和维护工作。 3月14日:进行细化前台页面工作,着手后台的编码和各项连接...
本文以JSP为开发技术,实现了一个九宫格日志网站。九宫格日志网站的主要使用者分为管理员;个人中心、用户管理、日记信息管理、美食信息管理、景点信息管理、新闻推荐管理、日志展示管理、论坛管理、我的收藏管理、...
个人写的日记,绝对真实。最适合jsp开发人员哦.. 希望各位喜欢
第二章软件需求分析,在本章节中,我们将逐一分析制作过程中遇到的问题,例如:看日记,写日记,删除日记,日记管理等,并且把相关数据做成数据字典;第三章软件概要设计,在这一章节中,我们将把各个问题一一作以...
个人网站是属于一个人在网络空间中的私有家园,可以在个人网站中书写日记,学习心得,或者是对某些流行话题的理解和讨论等。 公司计划开发一个学习型个人网站系统—“E-家园”,要求: 允许任何人查看网站内资料 ...
一直有写日记的习惯,突然想找个日记本程序,找了半天也一无所获,所以突然萌生了写一个日记本程序的想法, 本程序由熊海开发,基于ASP/ACCESS架构,本程序可用于微博,日记,博客等用途,后续我也将会继续更新熊海...
所以突然萌生了写一个日记本程序的想法,本程序由熊海开发,基于ASP/ACCESS架构,本程序可用于微博,日记,博客等用途,后续我也将会继续更新熊海日记本,使用中有任何问题,都可以来我的网站留言。 更新日期:...