深入理解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 连接,存在安全隐患。

相关推荐
Database_Cool_9 小时前
AnalyticDB MySQL vs StarRocks/ByteHouse:云数仓选型指南——全托管 vs 自建方案
数据库·数据仓库·mysql·阿里云
AI人工智能+电脑小能手10 小时前
【大白话说Java面试题 第99题】【Mysql篇】第29题:如何选择合适的分布式主键方案?
java·数据库·分布式·mysql·面试
拾贰_C12 小时前
【mysql | windows | installation】 MySQL5.安装
数据库·windows·mysql
yuezhilangniao13 小时前
MySQL 8.0.32 二进制安装脚本 和初始化 操作系统版本rocky86
数据库·mysql·adb
学代码的真由酱14 小时前
MySQL数据库进阶-数据库设计实践-Java
数据库·mysql·数据库设计
遇事不決洛必達14 小时前
【数据库系列】本地映射云服务器Mysql的方法
服务器·数据库·mysql·定时任务
yuezhilangniao15 小时前
xtr备份prepare到底变化了啥
mysql
yyk的萌15 小时前
创建属于自己的mysql的mcp
mysql·adb·ai·mcp
流烟默15 小时前
腾讯云Centos7.6使用yum安装MySQL8
mysql·centos·腾讯云
仙俊红15 小时前
如何优化 MySQL 深分页 SQL
android·sql·mysql