0

0

mysql如何加固MySQL默认安装环境_mysql_secure_installation实战

P粉602998670

P粉602998670

发布时间:2026-03-11 09:30:13

|

699人浏览过

|

来源于php中文网

原创

mysql_secure_installation运行后密码仍为空,因脚本不自动读取首次启动生成的临时root密码,须先手动登录并重置密码才能正常执行;后续步骤需谨慎处理匿名用户、远程root访问、test库及已有用户权限。

mysql如何加固mysql默认安装环境_mysql_secure_installation实战

mysql_secure_installation 运行后密码还是空?

默认安装的 MySQL(尤其是 5.7+)在首次启动时会生成一个临时 root 密码,但 mysql_secure_installation 并不会自动读取它——你得手动登录一次,再运行脚本。否则脚本直接报错 Access denied for user 'root'@'localhost',然后卡住。

实操建议:

  • 先查临时密码:sudo grep 'temporary password' /var/log/mysqld.log(CentOS/RHEL)或 sudo cat /var/log/mysql/error.log | grep 'temporary'(Ubuntu/Debian)
  • 用该密码登录:mysql -u root -p,然后立刻执行 ALTER USER 'root'@'localhost' IDENTIFIED BY '你的强密码';
  • 退出后,再运行 mysql_secure_installation,此时它才能正常连接并交互式加固

脚本里选“Remove anonymous users”到底删了啥?

MySQL 默认建了几个匿名用户(''@'localhost'''@'hostname'),它们没用户名,只靠 host 匹配,权限可能意外放通。比如本地任意程序连 MySQL 不输用户名也能进——尤其在 Docker 或共享主机环境下很危险。

实操建议:

  • Y 删除是安全的,除非你明确依赖匿名用户做某些老脚本兼容(极少见)
  • 删完记得验证:SELECT User,Host FROM mysql.user WHERE User=''; 应返回空集
  • 注意:这个操作不影响 root 或其他已命名用户,也不改任何数据库数据

Disallow root login remotely 为什么不能无脑选 Y?

Y 会把 'root'@'%''root'@'::1' 全干掉,只留 'root'@'localhost'。问题在于:很多运维工具(如 Navicat、DBeaver)、监控系统、甚至部分云平台控制台,都是通过 TCP 连 MySQL 的——它们走的是 127.0.0.1(不是 localhost),而 MySQL 把 127.0.0.1 当作远程 host 处理,不匹配 localhost 的 socket 认证规则。

Quinvio AI
Quinvio AI

AI辅助下快速创建视频,虚拟代言人

下载

实操建议:

  • 如果必须远程管理,别急着选 Y;先手动限制 root 远程访问:DELETE FROM mysql.user WHERE User='root' AND Host NOT IN ('localhost', '127.0.0.1');
  • 再为管理需求单独建一个低权限账号:CREATE USER 'admin'@'%' IDENTIFIED BY '强密码'; GRANT SELECT,SHOW VIEW ON *.* TO 'admin'@'%';
  • 最后刷新:FLUSH PRIVILEGES;

Test database 被删后,为什么有些程序启动失败?

mysql_secure_installation 默认删掉 test 库和 test_% 开头的库。但不少开发框架(比如旧版 Laravel、某些 Django 测试配置)默认用 test 作测试库名,或者代码里硬写了 USE test;。删完就抛 Unknown database 'test' 错误。

实操建议:

  • 生产环境删它是对的,但上线前务必检查应用的数据库配置、初始化 SQL、测试脚本是否依赖 test
  • 临时方案:删完后手动重建 test 库(仅限开发/测试机):CREATE DATABASE test;
  • 更稳妥做法:把应用里的 test 替成真实业务库名,或统一用 CREATE DATABASE IF NOT EXISTS test; 初始化

真正容易被忽略的,是 mysql_secure_installation 不动 existing user 权限——它只处理 root、anonymous、test 相关项。如果你之前手动建过用户,或者用一键包(如 XAMPP、MAMP)装过,那些账号的密码强度、host 通配符(%)、甚至空密码都还在。加固不是点几下就完事,得配合 SELECT User,Host,authentication_string FROM mysql.user; 手动巡检。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

339

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

293

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

772

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

385

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

140

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

85

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

79

2025.08.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

392

2026.03.04

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 846人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号