`
kongzimengsheng1
  • 浏览: 66547 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

网站开发日记(3)

阅读更多
今天遇到最棘手的问题,就是网站速度很慢,并且是一阵一阵的,用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 已经处理完了所有待处理的插入操作,正在等待新的请求。
 大部分状态对应很快的操作,只要有一个线程保持同一个状态好几秒钟,那么可能是有问题发生了,需要检查一下。
 还有其他的状态没在上面中列出来,不过它们大部分只是在查看服务器是否有存在错误是才用得着。
分享到:
评论

相关推荐

    网站开发日记(11)

    博文链接:https://dodomail.iteye.com/blog/245758

    社交网站后端项目开发日记(一)(csdn)————程序.pdf

    社交网站后端项目开发日记(一)(csdn)————程序

    安卓期末大作业(AndroidStudio开发),日记本app,可以登录和搜索,代码注释详细,能正常运行

    安卓期末大作业-日记本(免积分下载) 压缩包内包含源代码,运行各个界面截图,一条日记可以记录2000字符以下的文本、最多8张配图和最多8个视频。每条日记都可以以评论的形式或转发引用的形式追更,评论的最大长度也...

    九宫格日记网站

    java web+ajax+jQuery+Mysql技术实现网站九宫格日记的开发

    心情日记本1.0

    ⑤分享日记,将自己的心情日记分享到QQ空间、新浪微博等社交网站,分享心情分享生活;⑥导出日记,便于心情日记保存管理。2、语言日记:①新建语音日记;②播放语音日记;③删除语音日记。3、知心电话:①添加手机...

    MOSS开发日记,MOSS 2007 开发日记 - 中国网络编辑整理

    转来的MOSS开发日记,共享一下。开发前期准备 工欲善其事,必先利其器。很多朋友可能和我一样,需要对MOSS 进行开发,但是感觉又是一头雾水,不知道从何做起。 这里,从开发学习环境的搭建开始,开始我们一步一步...

    网页设计实习日记范文10篇.pdf

    网页设计实习日记范文10篇.pdf网页设计实习日记范文10篇.pdf网页设计实习日记范文10篇.pdf网页设计实习日记范文10篇.pdf网页设计实习日记范文10篇.pdf网页设计实习日记范文10篇.pdf网页设计实习日记范文10篇.pdf网页...

    日记系统源代码

    一直有写日记的习惯,突然想找个 日记本程序 ,找了半天也一无所获,所以突然萌生了写一个日记本程序的想法, 本程序由熊海开发,基于ASP/ACCESS架构,本程序可用于微博,日记,博客等用途,后续我也将会继续更新...

    实战突击 PHP项目开发案例整合.pdf

    明日科技等编著的《实战突击:PHP项目开发案例整合(附光盘)》以会议记录管理系统、留言本、在线投票系统、个人网络日记、在线论坛、博客、物流管理系统、在线考试管理系统、明日编程词典、明日科技企业网站、明日...

    PHP实例开发源码—最新仿花生日记淘宝客双端原生APP网站源码.zip

    PHP实例开发源码—最新仿花生日记淘宝客双端原生APP网站源码.zip

    基于SSM框架的在线日记管理系统设计与实现.zip

    我们暂时只是开发一个网站,所以我们的产品暂时开发所用运行环境为: Windows 系统(Windows 10) Cpu i5-6500 开发软件 eclipse 环境 jdk 9.0 服务器:tomcat 9 详细介绍参考:...

    Java开发九宫格记忆网笔记便签日记程序完整练手项目流程实战_优秀案例实例源代码源码.zip

    九宫格日记由九个方方正正的格子组成九个格子九个主题,用户只需要在每个格子中填写相应的内容就能完成一篇日记,整个过程只需要几分钟。九宫格日记因其便捷、省时等优点在网上迅速风行开来,倍受学生、年轻人和上班族...

    QT(C++)开发小众日记app项目.zip

    软件开发设计:应用软件开发、系统软件开发、移动应用开发、网站开发C++、Java、python、web、C#等语言的项目开发与学习资料 硬件与设备:单片机、EDA、proteus、RTOS、包括计算机硬件、服务器、网络设备、存储设备...

    本科计算机毕业实习日记

    3月12日:继续深入理解和尝试部门政务网站的架构方法和功能模块实现方法。向师傅和同事们请教相关问题。 3月13日:进行前台的设计实际建设和维护工作。 3月14日:进行细化前台页面工作,着手后台的编码和各项连接...

    java毕业设计源码 基于ssm美好生活日志网日记网站含论文ppt

    本文以JSP为开发技术,实现了一个九宫格日志网站。九宫格日志网站的主要使用者分为管理员;个人中心、用户管理、日记信息管理、美食信息管理、景点信息管理、新闻推荐管理、日志展示管理、论坛管理、我的收藏管理、...

    计算机实习日记15篇

    个人写的日记,绝对真实。最适合jsp开发人员哦.. 希望各位喜欢

    [计算机毕设]基于asp的网上日记本网站(源代码+项目报告).zip

    第二章软件需求分析,在本章节中,我们将逐一分析制作过程中遇到的问题,例如:看日记,写日记,删除日记,日记管理等,并且把相关数据做成数据字典;第三章软件概要设计,在这一章节中,我们将把各个问题一一作以...

    ACCP毕业设计---E家园

    个人网站是属于一个人在网络空间中的私有家园,可以在个人网站中书写日记,学习心得,或者是对某些流行话题的理解和讨论等。 公司计划开发一个学习型个人网站系统—“E-家园”,要求: 允许任何人查看网站内资料 ...

    熊海日记本 v1.4.rar

    一直有写日记的习惯,突然想找个日记本程序,找了半天也一无所获,所以突然萌生了写一个日记本程序的想法, 本程序由熊海开发,基于ASP/ACCESS架构,本程序可用于微博,日记,博客等用途,后续我也将会继续更新熊海...

    熊海日记本 1.4.rar

    所以突然萌生了写一个日记本程序的想法,本程序由熊海开发,基于ASP/ACCESS架构,本程序可用于微博,日记,博客等用途,后续我也将会继续更新熊海日记本,使用中有任何问题,都可以来我的网站留言。 更新日期:...

Global site tag (gtag.js) - Google Analytics