`
kongzimengsheng1
  • 浏览: 68506 次
  • 性别: 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

    MOSS 2007开发日记

    以下是对"MOSS 2007开发日记"中可能涉及的关键知识点的详细解释: 1. **SharePoint架构**:理解MOSS 2007的基础架构至关重要,包括前端Web服务器、应用服务器、数据库服务器和客户端组件。这些组件如何协同工作对于...

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

    "社交网站后端项目开发日记(一)" 本文主要介绍了社交网站后端项目的开发日记,涵盖了项目的基本概念、技术栈选型、项目搭建、依赖管理、SpringBoot基础知识等方面。 一、项目概述 社交网站后端项目旨在开发一个...

    花生日记APP官网网站模板源码

    综上所述,"花生日记APP官网网站模板源码"是一个包含完整结构和样式的网站开发资源,适用于快速创建一个与官方风格一致的网站,同时具备了必要的功能页面、图标、地图以及隐私政策,且考虑了SEO和跨平台的用户体验。...

    java oa项目开发日记

    - 下载JBoss 3.0的安装包,推荐直接从官方网站获取最新版本的安装文件。 2. **安装流程**: - 在Windows环境下完成JBoss的初始安装,便于调试和测试。 - 完成安装后,将JBoss移植到目标服务器,如Linux服务器,...

    一个嵌入式工程师的stm32开发日记

    嵌入式工程师是指那些专注于在特定硬件平台上进行软件开发和系统集成的专业人员。...作者通过这份开发日记,不仅记录了自己在STM32开发上的点点滴滴,也为其他同行或爱好者提供了一条学习和思考的路径。

    九宫格日记网站

    总的来说,"九宫格日记网站"项目是一个综合性的实践,涵盖了Web开发的多个关键领域。通过这个项目,开发者可以提升其在Java Web编程、前端交互设计以及数据库管理等方面的能力,并且理解如何将这些技术融合到一个...

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

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

    心情日记本1.0

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

    在线日记本源码_网站在线聊天留言源码.rar

    在线日记本源码和网站在线聊天留言源码是构建交互式、社交化网站的重要组成部分,它们...这样的源码对于想要创建个性化社交网站的开发者来说极具价值,可以作为基础进行二次开发,添加更多特色功能,满足不同用户需求。

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

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

    简单的JAVA日记本程序源代码

    3. IO流:用于读取和保存日记内容,JAVA的FileInputStream和FileOutputStream被用来进行文件的读写操作。 4. String类:在处理日记文本时,JAVA的String类提供了丰富的字符串操作方法。 二、图形用户界面(GUI) 1....

    基于javaweb的日记网

    【标题】:“基于javaweb的日记网”指的是一个使用Java Web技术开发的在线日记应用程序。这个项目的核心是利用Web技术来提供一个平台,让用户能够方便地创建、编辑和存储他们的个人日记。Java Web是一种广泛使用的...

    ASP源码—(青春日记)多用户网络日记系统.zip

    3. **日记查看与管理**:用户能够查看自己的所有日记,按照日期、标题或其他自定义方式进行排序。此外,还应有删除日记的功能,以便用户可以清理不再需要的条目。 4. **安全性与隐私保护**:由于日记通常包含个人...

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

    3. **数据库管理**:更新网站涉及后台数据库的操作,包括数据录入和实时更新。这需要掌握SQL语言和数据库管理系统,如SQLServer2000,以确保数据的安全性和准确性。 4. **Dreamweaver与Photoshop**:这两款Adobe...

    MOSS开发日记电子书

    《MOSS开发日记》这本书是针对SharePoint MOSS 2007开发的一本实践指南,虽然出版时针对的是2007版本,但其中的许多概念和技术在SharePoint 2010甚至后续版本中仍然适用。SharePoint是微软推出的企业级协作平台,...

    网站开发文档

    网站开发文档是构建一个网站的重要指导文件,它涵盖了从项目规划到最终实现的各个阶段。在本案例中,我们看到的是一个个人主页的开发过程,它旨在宣传个人、分享兴趣并建立与同好者的交流平台。 首先,【网站定位】...

    基于HTML5技术的日记分享交流网站.docx

    开发日记分享交流网站前,进行了详细的分析,包括可行性分析、需求分析、整体设计等。这些分析结果为网站的开发和测试提供了依据。 在开发过程中,使用了Eclipse作为开发工具,MySQL作为数据库管理系统。这些技术的...

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

    【标题】: "基于ASP的网上日记本网站" 是一个典型的Web开发项目,它利用ASP(Active Server Pages)技术构建了一个在线平台,用户可以在这里撰写、查看和管理个人的日记。这个项目不仅包含了网站的源代码,还附带了...

    基于Web的信息技术网站开发与设计答辩ppt

    基于Web的信息技术网站开发与设计答辩ppt 在信息技术快速发展的时代,基于Web的信息技术课程网站后台的开发与设计成为了一个热门话题。本资源是一份毕业设计的答辩ppt,展示了基于Web的信息技术课程网站后台的开发...

Global site tag (gtag.js) - Google Analytics