0
点赞
收藏
分享

微信扫一扫

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)


❤️作者主页:小虚竹

❤️作者简介:大家好,我是小虚竹。Java领域优质创作者🏆,CSDN博客专家🏆,华为云享专家🏆,掘金年度人气作者🏆,阿里云专家博主🏆

❤️技术活,该赏

❤️点赞 👍 收藏 ⭐,养成习惯


文章目录

  • ​​问题​​
  • ​​解决方案​​
  • ​​开启慢查询日志​​
  • ​​第一种方式​​
  • ​​windows实战​​
  • ​​slow_query_log 一直为off,没生效​​
  • ​​验证​​
  • ​​linux实战​​
  • ​​验证​​
  • ​​第二种方式​​
  • ​​实操​​
  • ​​验证​​
  • ​​关闭慢查询日志​​
  • ​​第一种方式​​
  • ​​windows实战​​
  • ​​验证​​
  • ​​linux实战​​
  • ​​验证​​
  • ​​第二种方式​​
  • ​​扩展​​

问题

如何开启和关闭mysql系统参数(多环境:windows和linux)

解决方案

以开启关闭慢查询日志为例。

开启慢查询日志

第一种方式

可以在mysql的配置文件里开启慢查询日志。
mysql中“my.ini”文件:

  • 1、linux系统中,默认该文件的位置是“/etc/mysql/my.cnf”;
  • 2、windows系统中,默认该文件的位置是“C:\ProgramData\MySQL\MySQL Server **\Data\my.ini”。

其中C:\ProgramData是隐藏目录,需要显示隐藏目录才能找到。

[mysqld]
slow_query_log = 1
slow_query_log_file = /data/mysql/log/query_log/slow_statement.log
long_query_time = 10
log_output = FILE

配置项说明:

slow_query_log:1代表开启慢查询日志。0:代表关闭慢查询日志。
slow_query_log_file:慢查询日志保存的地方和对应的文件名。
long_query_time:指定SQL语句执行时间超过多少秒时记录慢查询日志。
log_output:File:表示将日志存入文件,默认值是’FILE’;Table:表示将日志存入数据库,这样日志信息就会被写入到mysql.slow_log表中。
经验之谈:当记录到数据表中时,则数据表中记录的慢查询时间只能精确到秒;如果是记录到日志文件中,则日志文件中记录的慢查询时间能够精确到微秒。
建议在实际工作中,将慢查询日志记录到文件中。

重点:配置完成后,要重启mysql服务器!配置才会生效!

windows实战

默认该文件的位置是“C:\ProgramData\MySQL\MySQL Server **\Data\my.ini”。

找到文件:

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_mysql


修改my.ini配置:

# General and Slow logging.
slow_query_log=1
slow_query_log_file="d:/build/mysql/slow_statement.log"
long_query_time=10
log_output=FILE

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_mysql_02

保存配置后,重启mysql服务。

使用管理员权限打开cmd,在cmd输入以下命令,然后回车:

net stop mysql57

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_重启_03


注:不同的mysql版本,服务名可能不一样,可以去服务里找对应的服务名

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_数据库_04


重启mysql服务。

net start

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_数据库_05

查看配置是否生效:

show variables like '%slow_query_log%'; 
show variables like '%long_query_time%';
show variables like '%log_output%';

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_重启_06


mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_mysql_07


mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_重启_08

slow_query_log 一直为off,没生效

咦,就slow_query_log 参数没有生效,检查了参数名,没有写错,那会是什么原因呢?

虚竹哥查了下资料,发现在linux下:slow_query_log_file所在的目录需要MySQL的运行帐号的可写权限,如需变更日志文件目录记得给新目录授予777权限,否则slow_query_log一直为OFF

从这个思路扩展一下,会不会mysql也不会帮忙创建不存在的目录。

slow_query_log_file="d:/build/mysql/slow_statement.log"

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_数据库_09


果然没有帮忙创建目录。尝试把目录补上去,再重启下服务试试:

果然生效了

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_重启_10

慢查询日志文件也生成出来了

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_mysql_11


画重点:slow_query_log_file指定的文件目录一定要存在的!如果不存在,要手动先创建目录,再重启服务!

画重点:slow_query_log_file指定的文件目录一定要存在的!如果不存在,要手动先创建目录,再重启服务!

画重点:slow_query_log_file指定的文件目录一定要存在的!如果不存在,要手动先创建目录,再重启服务!

验证

执行sql语句,触发慢查询机制:

SELECT BENCHMARK(99999999, MD5('mysql'));

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_数据库_12


查看日志内容,如图,已经记录成功:

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_数据库_13

linux实战

先创建慢查询日志的存放目录:

mkdir /usr/local/mysql/data/query_log

给目录读写权限

chmod 777 query_log/

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_mysql_14

默认该文件的位置是“/etc/mysql/my.cnf”。

虚竹哥自定义my.cnf的位置:/etc/my.cnf

​​SQL快速入门-安装MYSQL环境(多环境企业级指导)​​ 找到文件:

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_慢查询_15

修改my.cnf配置:

slow_query_log = 1
slow_query_log_file = /usr/local/mysql/data/query_log/slow_statement.log
long_query_time = 10
log_output = FILE

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_数据库_16


保存配置后,重启mysql服务。

查看下mysql服务状态:

systemctl status

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_数据库_17


服务是开启的,先关闭,再启动 。

systemctl stop mysqld

systemctl start

再查看下mysql服务状态:

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_数据库_18


查看配置是否生效:

show variables like%slow_query_log%;
show variables like%long_query_time%;
show variables like%log_output%;

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_慢查询_19


mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_mysql_20


mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_数据库_21


慢查询日志文件也生成出来了

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_慢查询_22


画重点:slow_query_log_file指定的文件目录一定要存在的!如果不存在,要手动先创建目录,再重启服务!
画重点:slow_query_log_file指定的文件目录一定要存在的!如果不存在,要手动先创建目录,再重启服务!
画重点:slow_query_log_file指定的文件目录一定要存在的!如果不存在,要手动先创建目录,再重启服务!

验证

执行sql语句,触发慢查询机制:

SELECT BENCHMARK(99999999, MD5('mysql'));

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_mysql_23

查看日志内容,如图,已经记录成功:

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_慢查询_24

第二种方式

在MySQL命令行中执行命令开启慢查询日志:

SET GLOBAL slow_query_log = 1;
SET GLOBAL slow_query_log_file = '/data/mysql/log/query_log/slow_statement.log';
SET GLOBAL long_query_time = 10;
SET GLOBAL log_output = 'FILE';

重点:这种方式不需要重启mysql服务。MySQL重启后会失效。

这种方式不用区分什么操作系统

实操

先查看下慢查询日志的相关参数

show variables like '%slow_query_log%'; 
show variables like '%long_query_time%';
show variables like '%log_output%';

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_重启_25


mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_重启_26


mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_重启_27


我们看到slow_query_log 参数值为OFF,说明慢查询日志未开启。

在MySQL命令行中执行命令开启慢查询日志,其他参数就不设置了,第一种方式有配置了:

SET GLOBAL slow_query_log = 1;

再看下慢查询日志的相关参数,已经开启

show variables like '%slow_query_log%';

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_重启_28

同时也生成了慢查询日志文件:

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_mysql_29

验证

执行sql语句,触发慢查询机制:

SELECT BENCHMARK(99999999, MD5('mysql'));

查看日志内容,如图,已经记录成功:

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_慢查询_30

关闭慢查询日志

关闭慢查询日志,只需要在my.cnf文件或者my.ini文件中配置slow_query_log=0或者直接删除此选项即可。

第一种方式

windows实战

修改my.ini配置:

# General and Slow logging.
slow_query_log=0

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_数据库_31

保存配置后,重启mysql服务。

使用管理员权限打开cmd,在cmd输入以下命令,然后回车:

net stop mysql57

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_重启_03


注:不同的mysql版本,服务名可能不一样,可以去服务里找对应的服务名

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_数据库_04


重启mysql服务。

net start

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_数据库_05

手动把之前的慢查询日志先删除:

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_慢查询_35


查看配置是否生效:

show variables like '%slow_query_log%';

配置生效:

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_mysql_36

验证

执行sql语句,看是否还会触发慢查询机制:

SELECT BENCHMARK(99999999, MD5('mysql'));

结果关闭慢查询日志成功:

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_mysql_37

linux实战

修改my.cnf配置:

slow_query_log=0

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_慢查询_38


保存配置后,重启mysql服务。

查看下mysql服务状态:

systemctl status

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_数据库_17


服务是开启的,先关闭,再启动 。

systemctl stop mysqld

systemctl start

再查看下mysql服务状态:

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_数据库_18


手动把之前的慢查询日志先删除:

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_慢查询_41

查看配置是否生效:

show variables like '%slow_query_log%';

配置生效:

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_重启_42

验证

执行sql语句,看是否还会触发慢查询机制:

SELECT BENCHMARK(99999999, MD5('mysql'));

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_数据库_43


结果关闭慢查询日志成功:

mysql出现问题:mysql系统参数如何设置解决方案(mysql 小虚竹)_慢查询_44

第二种方式

在MySQL命令行中执行命令关闭慢查询日志:

SET GLOBAL slow_query_log = 0;

慢查询阀值是10s,改为1s.

set global long_query_time= 1;

修改之后,建议重新开一个会话查询(旧会话查询出的值可能是原来的10s)
重点:这种方式不需要重启mysql服务。MySQL重启后会失效。

举报

相关推荐

0 条评论