【MySQL】数据目录与日志开篇

1. MySQL 配置文件


2. MySQL 服务器数据目录


3. 一般查询日志和慢查询日志

在配置文件中进行日志控制:

bash 复制代码
[mysqld]
# 日志写入表和文件
log_output=FILE,TABLE

# 开启一般查询日志 
# general_log=1

# 指定一般查询日志的文件名 
# general_log_file=/var/lib/mysql/general.log

# 开启慢查询日志
slow_query_log=1
 
# 指定慢查询日志的文件名 
# slow_query_log_file=/var/lib/mysql/slow_query.log

运行时的日志控制:

sql 复制代码
-- 动态配置 通用查询日志 和 慢查询日志 的输出目的地
SET GLOBAL log_output = [FILE, TABLE, NONE]

-- 动态配置 通用查询日志
SET GLOBAL general_log = [OFF,ON];

-- 动态配置 慢查询日志
SET GLOBAL slow_query_log = [OFF,ON];

运行时查看日志的配置信息:

注意事项:

  1. 如果必须开启这两种日志,推荐使用 FILE 方式,因为它对服务器性能的影响最小。

  2. 写入 TABLE,虽然便于查询和分析(使用客户端与 SQL 语句来筛选和查看日志),但性能开销较大,因为每次日志记录都是一次数据库写入操作,通常仅用于临时调试。

  3. 即使已经配置开启了通用查询日志和慢查询日志,如果 log_output 设置为 NONE,那么也不会有任何日志被记录。

  4. 通用查询日志和表输出会带来巨大性能开销。


慢查询日志详解:

执行时间超过 long_query_time 的所有查询都会被记录,默认 10s。

这在需要进行 SQL 优化时非常关键。通常使用 mysqldumpslow 这个客户端程序来分析慢查询日志,并结合 EXPLAIN 命令来获取执行计划。

该日志在默认情况下,不记录 DDL 语句,并且只记录使用索引的查询。如果配置使其记录不使用索引的查询,最好使用 log_throttle_queries_not_using_indexes 控制未使用索引的查询的记录频率,否则日志将急速膨胀。


相关推荐
卓怡学长1 分钟前
基于 SpringBoot 的生活信息分享平台,从 0 到 1 完整实现(附源码 + 数据库)
java·数据库·spring boot·tomcat·maven
ID_180079054733 分钟前
Python解析小红书(XHS)笔记评论 API,json数据返回参考
java·服务器·数据库
reasonsummer4 分钟前
【教学类-160-03】20260410 AI视频培训-练习3“豆包AI视频《孔子教育之旅》+豆包图片风格:中国风(平面图)”
数据库
曹牧8 分钟前
oracle kv字符串转换为多行两列
数据库·oracle
CV艺术家19 分钟前
java原mysql切换国产达梦数据库
数据库·mysql
好大哥呀19 分钟前
如何在Spring Boot中配置数据库连接?
数据库·spring boot·后端
xcLeigh26 分钟前
IoTDB数据订阅API实战:实时消费数据+TsFile订阅全攻略
数据库·api·iotdb·数据备份·tsfile·数据订阅
许杰小刀29 分钟前
使用 Python 将 Excel 数据批量导入到数据库中(SQLite)
数据库·python·excel
一个天蝎座 白勺 程序猿30 分钟前
Apache IoTDB(16):时序数据库的数据删除从单点精准清除到企业级数据生命周期管理
数据库·apache·时序数据库·iotdb
努力进修33 分钟前
【MySQL】90% 的 MySQL 性能问题都和它有关!索引的正确打开方式,看完少走 3 年弯路
数据库·mysql