深入理解MySQL 8.0:日志管理、性能优化与安全管理全解析

36. 日志类型及用途

  • 错误日志:记录启动失败、崩溃等严重问题(默认开启)。

  • 慢查询日志:记录执行时间超过阈值的 SQL(用于优化)。

  • 二进制日志:记录数据变更(用于主从复制和恢复)。

  • 常规查询日志:记录所有 SQL 语句(慎用,影响性能)。


37. MySQL 8.0 默认开启的日志

  • 错误日志/var/log/mysql/error.log

  • 二进制日志/var/lib/mysql/binlog.000001


38. 常规查询日志 vs 慢查询日志

  • 常规查询日志:记录所有 SQL 语句(包括连接信息)。

  • 慢查询日志 :仅记录执行时间超过 long_query_time 的 SQL(默认 10 秒)。


39. 日志同时保存到文件和表

  • 配置

    复制代码
    [mysqld]  
    log_output=FILE,TABLE  
    slow_query_log=1  
    general_log=1  
  • 查看日志表

    sql 复制代码
    SELECT * FROM mysql.slow_log;  
    SELECT * FROM mysql.general_log;  

40. 刷新日志命令

  • 命令FLUSH LOGS;mysqladmin flush-logs

  • 影响

    • 创建新的二进制日志文件。

    • 重新打开常规查询日志和慢查询日志文件。


41. Performance Schema 的作用

  • 目的:实时监控服务器性能(如锁等待、内存使用)。

  • 常用表

    • events_waits_current:当前等待事件。

    • file_summary_by_event_name:文件 I/O 统计。


42. sys Schema 的作用

  • 功能:简化 Performance Schema 数据的查看。

  • 示例视图

    • sys.innodb_lock_waits:显示锁冲突信息。

    • sys.schema_table_statistics:表访问统计。


43. 审计功能配置

  • 正确audit_log_filter_linux_install.sql 脚本用于配置基于规则的审计。

  • 步骤

    1. 执行脚本:mysql -u root -p < audit_log_filter_linux_install.sql

    2. 启用审计插件:INSTALL PLUGIN audit_log SONAME 'audit_log.so';


44. MySQL Enterprise Monitor 功能

  • 持续监控:实时跟踪数据库性能。

  • 自动预警:根据阈值发送告警(如 CPU 使用率超过 90%)。

  • 可视化分析:生成查询执行时间图表。

  • 账户管理:审计用户权限变更。


45. SHOW PROCESSLIST 输出列

  • Id:连接 ID。

  • User:执行 SQL 的用户。

  • Host:客户端 IP。

  • db:当前使用的数据库。

  • Command :线程状态(如 QuerySleep)。

  • Time:线程处于当前状态的秒数。

  • State :操作详情(如 Sending data)。

  • Info:正在执行的 SQL 片段。


46. 用户账户存储位置

  • 位置mysql.user 表。

  • 查看所有用户

    sql 复制代码
    SELECT User, Host FROM mysql.user;  

47. 检查通配符用户

  • 方法

    sql 复制代码
    SELECT User, Host FROM mysql.user WHERE Host LIKE '%';  
  • 风险'user'@'%' 允许从任何 IP 连接,存在安全隐患。

相关推荐
Fleshy数模10 小时前
CentOS7 安装配置 MySQL5.7 完整教程(本地虚拟机学习版)
linux·mysql·centos
az44yao10 小时前
mysql 创建事件 每天17点执行一个存储过程
mysql
秦老师Q12 小时前
php入门教程(超详细,一篇就够了!!!)
开发语言·mysql·php·db
橘子1312 小时前
MySQL用户管理(十三)
数据库·mysql
Dxy123931021612 小时前
MySQL如何加唯一索引
android·数据库·mysql
我真的是大笨蛋13 小时前
深度解析InnoDB如何保障Buffer与磁盘数据一致性
java·数据库·sql·mysql·性能优化
怣5013 小时前
MySQL数据检索入门:从零开始学SELECT查询
数据库·mysql
人道领域13 小时前
javaWeb从入门到进阶(SpringBoot事务管理及AOP)
java·数据库·mysql
千寻技术帮14 小时前
10404_基于Web的校园网络安全防御系统
网络·mysql·安全·web安全·springboot
spencer_tseng15 小时前
MySQL table backup
mysql