phpMyAdmin 本身不记录用户执行的每条 SQL,所有查询均由后端 MySQL/MariaDB 执行,SQL 审计必须依赖数据库服务层日志:MySQL 启用 general_log,MariaDB 推荐 slow_query_log + long_query_time=0。phpMyAdmin 没有内置 SQL 审计日志功能直接说结论:phpmyadmin 本身不记录用户执行的每条 sql,它只是一个 web 前端,所有查询都转发给后端 mysql/mariadb 执行。想审计 sql,必须依赖数据库服务层的日志能力,而不是 phpmyadmin 配置。开启 MySQL 的 general_log 是最直接的方案MySQL 的 general_log 会记录所有到达服务器的语句(含连接、查询、退出等),正好覆盖 phpMyAdmin 用户操作的全部 SQL。实操建议:登录 MySQL(用 root 或有 SUPER 权限的账号)执行:SET GLOBAL general_log = 'ON';<br>SET GLOBAL log_output = 'TABLE';(推荐先设为 'TABLE',日志写入 mysql.general_log 表,避免文件权限问题)如果要存到文件,改用:SET GLOBAL log_output = 'FILE';<br>SET GLOBAL general_log_file = '/var/log/mysql/general.log';注意确保 MySQL 进程对路径有写权限,且 SELinux/AppArmor 不拦截general_log 开启后会影响性能,尤其高并发时;仅用于临时审计,勿长期开启日志表默认无索引,查最近操作可用:SELECT * FROM mysql.general_log ORDER BY event_time DESC LIMIT 50;MariaDB 用户优先考虑 slow_query_log + long_query_time=0MariaDB 10.11+ 对 slow_query_log 做了增强:设 long_query_time = 0 可记录所有查询(包括快的),比 general_log 更轻量,且支持按用户过滤(需配合 log_slow_filter = user)。关键点:立即学习"PHP免费学习笔记(深入)"; Vozo Vozo是一款强大的AI视频编辑工具,可以帮助用户轻松重写、配音和编辑视频。
相关推荐
014-code1 小时前
CompletableFuture 实战模板(超时、组合、异常链处理)それども2 小时前
DELETE 和 TRUNCATE TABLE区别wenha2 小时前
数据库隔离级别2401_871492852 小时前
Layui如何修改Layui默认的UI主题颜色(换肤功能实现)南子北游3 小时前
Python学习(基础语法1)Edward111111113 小时前
4.27mysql ,数据库,数据源小徐敲java3 小时前
踩坑实录:MySQL8.0 导入SQL报错 2006 - MySQL server has gone away 完美解决别来无恙blwy3 小时前
windows MongoDB升级-自动升级脚本-自动检测升级到任意版本步辞3 小时前
Redis如何利用LFU算法优化缓存命中率