linux/windows平台监控mysql执行的sql语句

linux平台

监控mysql执行的sql语句
 
为了做好配合开发做性能和功能测试,方便监控正在执行的sql语句,

可以在/etc/mysqld中添加如下:
 
log =/usr/local/mysql/var21005/mysql.log
就可以使用:
tail -f mysql.log  www.111cn.net
来监控了
 
如果需要监控慢查询可以添加如下内容:
 
log-slow-queries = /usr/local/mysql/var21005/slowquery.log
long_query_time = 1

windows平台

一windows平台下为例:

修改my.ini,在mysqld下添加log一行,

[mysqld]
log = "D:/tmp/mysql_log/mysql_log.sql"

然后,重新启动mysql,就可以实时看到myql服务器当前正在执行的语句了。

除了上面方法还可以使用慢日志监控mysql执行状态

启用MySQL的log-slow-queries(慢查询记录)。

  在Linux环境下先要找到my.cnf文件(一般在/etc/mysql/),然后可能会发现该文件修改后无法保存,原因是你没有相应的权限,可以从属性中看到该文件的所有者是root,这时要先以root的身份打开它:

  sudo nautilus /etc/mysql

  接着再打开my.cnf文件然后找到[mysqld]标签在下面加上:

  log-slow-queries=/path/slow.log  –慢日志保存路径,该文件自己新建
  long_query_time=2                     –超过2秒的查询
  log-queries-not-using-indexes –记录没有使用索引的查询

保存,关闭。然后如果重启MySQL的话会碰到这样的提示:world-writable config file ‘ etc my.cnf’ is ignored

这时需要你再运行这个代码:

chmod 644 /etc/my.cnf       –644表示rw-r–r– www.111cn.net

然后再重启服务就OK了。

但是要注意的是:log-slow-queries=/path/slow.log为慢查询日志存放的地方,而这个目录要有MySQL的运行帐号的可写权限,一般都将这个目录设置为MySQL的数据存放目录。

我是这么做的:先用root用户进到MySQL的数据存放目录(一般是/var/lib/mysql),新建一个slow.log文件(root用户能保证有权限新建,再运行chmod 644)。然后更改该文件的所有者和所在组:

  chown mysql运行帐户的名字(可以看同文件夹中其他文件的所有者和组)+小数点+组名(方法同用户名) /path/slow.log

或者:

  chown mysql运行帐户的名字(可以看同文件夹中其他文件的所有者和组)  /path/slow.log

  chgrp 组名(方法同用户名) /path/slow.log

这样才能保证MySQL能往slow.log中写日志。

时间: 2024-09-27 04:37:38

linux/windows平台监控mysql执行的sql语句的相关文章

MySql使用show processlist查看正在执行的Sql语句

今天上班例行的查看了下服务器的运行状况,发现服务器特卡,是mysqld这个进程占用CPU到了99%导致的. 比较好奇是那个程序在使用mysql导致cpu这么高的,通过show processlist命令查看了当前正在执行的sql语句,从而定位到了对应的程序,发现代码中有一个死循环在不停的查询导致cpu占用99%,原因找到了问题就好解决了.   这里简单的记录一下processlist的用法: processlist 命令的输出结果显示了有哪些线程在运行,可以帮助识别出有问题的查询语句,两种方式使

MySQL存储过程中实现执行动态SQL语句的方法_Mysql

本文实例讲述了MySQL存储过程中实现执行动态SQL语句的方法.分享给大家供大家参考.具体实现方法如下: mysql> mysql> delimiter $$ mysql> mysql> CREATE PROCEDURE set_col_value -> (in_table VARCHAR(128), -> in_column VARCHAR(128), -> in_new_value VARCHAR(1000), -> in_where VARCHAR(4

mysql命令-常用sql语句命令代码

mysql命令-常用sql语句命令代码 使用G按行垂直显示结果 如果一行很长,需要这行显示的话,看起结果来就非常的难受.在SQL语句或者命令后使用G而不是分号结尾,可以将每一行的值垂直输出.这个可能也是大家对于MySQL最熟悉的区别于其他数据库工具的一个特性了. mysql> select * from db_archivelogG *************************** 1. row ***************************         id: 1  chec

MySQL中优化sql语句查询常用的30种方法

本篇文章是对MySQL中优化sql语句查询常用的30种方法进行了详细的分析介绍,需要的朋友参考下   1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索引而进行全表扫描. 3.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描,如: select id from t where num is null 可以

MySQL的常用SQL语句

修改密码 这是常见的大家一般都要用的 首先安装成功了打开cmd –> mysql -u root -p –>输入你的密码 –>修改mysql root用户密码 格式:mysql> set password for 用户名@localhost = password('新密码'); 举例:mysql> set password for root@localhost = password('root'); 上面例子将用户root的密码更改为root: 如果是学习使用一般密码该简单些

mysql-求助MySQL的关于sql语句怎么写??三表的查询~~~请大神进来帮忙~~~~~

问题描述 求助MySQL的关于sql语句怎么写??三表的查询~~~请大神进来帮忙~~~~~ 现在我有三个表: 表1: pre_common_member_profile: uid(用户的uid), gender(性别), birthyear(出生的年), birthmonth(出生的月), birthday(出生的日) 表2: pre_home_friend: uid(用户的uid), fuid(加为好友的uid) 表3: pre_home_friend_request: fuid(发送好友请求

注解-如何获取这个代码最终执行的SQL语句?

问题描述 如何获取这个代码最终执行的SQL语句? JAVA @Select("SELECT NAME FROM TABLE T WHERE T.FOCUS_ID=#{focusId} AND T.PROS_ID=#{prosupId}") public Bypass queryBypass(@Param("focusId") Integer focusId,@Param("prosupId") Integer prosupId); 在这种执行SQ

常用的MySQL数据库操作sql语句

SELECT 查询语句和条件语句 INSERT 插入语句 UPDATE 更新语句(修改语句) DELETE 删除语句 书写标准:所有SQL操作语句使用大写字母书写,其他均为小写. 练习数据库:newdb 练习表(表名test) 字段: id uid  regdate remark 1  张三 NOW()   学生 2  李四         学生 3  王五         工人 4  赵六         学生 1.查询语句和条件语句 注意:SQL语句中的"`" != "'

0624使用10035事件跟踪无法执行的sql语句

[20160624]使用10035事件跟踪无法执行的sql语句.txt --昨天看一份awr报表,链接如下: http://www.itpub.net/thread-2061952-1-1.html --摘要如下: Top 10 Foreground Events by Total Wait Time Event                              Waits     Total Wait Time (sec)    Wait Avg(ms)  % DB time    W